# 24-bit 192kHz 2Vrms Multi-Channel CODEC ## **DESCRIPTION** The WM8594 is a high performance multi-channel audio CODEC with flexible input/output selection and digital and analogue volume control. Features include a 24-bit stereo ADC with digital gain control, two 24-bit DACs with independent digital volume control, and a range of input/output channel selection options with analogue volume control, for flexible routing within current and future audio systems. The WM8594 accepts five stereo audio inputs at line levels up to 2Vrms. One stereo input can be routed to the ADC. All inputs can be routed to the output. The WM8594 outputs three stereo audio channels at line levels up to 2Vrms, which can be selected from any of the analogue inputs and DAC outputs. Additionally, one stereo output is available with a headphone driver. The DAC channels include independent digital volume control, and all three stereo output channels include analogue volume control with soft ramp. The WM8594 supports up to 2Vrms analogue inputs, 2Vrms outputs, with sampling rates from 32kHz to 192kHz for the DACs, and 32kHz to 96kHz for the ADC. The WM8594 is ideal for audio applications requiring high performance and flexible routing options, including flat panel digital TV and DVD recorder. The device is controlled via a serial interface with support for 2-wire and 3-wire control with full readback. Control of mute, powerdown and reset can also be achieved by pin selection. The WM8594 is available in a 48-lead TQFP package. ## **FEATURES** - Multi-channel CODEC with 5 stereo input selector and 3 stereo output selector - 4-channel DAC, 2-channel ADC - Five stereo 2Vrms stereo inputs with analogue bypass to three stereo 2Vrms outputs - Stereo headphone driver - Audio performance - DAC: 100dB SNR typical ('A' weighted @ 48kHz) - DAC: -90dB THD typical - ADC: 100dB SNR typical ('A' weighted @ 48kHz) - ADC: -90dB THD typical - Independent sampling rates for ADC, DAC1 and DAC2 - DACs sampling frequency 32kHz to 192kHz - ADC sampling frequency 32kHz to 96kHz - ADC digital gain control: +30dB to -97dB - DAC digital volume control: +12dB to -100dB - Analogue Volume control with soft ramp: +6dB to -73.5dB - All volume controls include zero cross detection to prevent pops and clicks - 2 and 3-wire serial control interface with readback and hardware reset, mute and powerdown pins - Master or slave clocking modes - Programmable format audio data interface modes - I<sup>2</sup>S, LJ, RJ, DSP - 3.3V / 9V analogue, 3.3V digital supply operation - 48-lead TQFP package # **APPLICATIONS** - Digital Flat Panel TV - DVD-RW # **BLOCK DIAGRAM** # **TABLE OF CONTENTS** | DESCRIPTION | 1 | |----------------------------------------------------------------------|-----------| | FEATURES | | | APPLICATIONS | | | BLOCK DIAGRAM | 2 | | TABLE OF CONTENTS | 3 | | PIN CONFIGURATION | 4 | | ORDERING INFORMATION | 4 | | PIN DESCRIPTION | 5 | | ABSOLUTE MAXIMUM RATINGS | | | RECOMMENDED OPERATING CONDITIONS | | | SUPPLY CURRENT CONSUMPTION | | | ELECTRICAL CHARACTERISTICS | | | TERMINOLOGY | | | MASTER CLOCK TIMING | | | DIGITAL AUDIO INTERFACE TIMING - SLAVE MODE | 12 | | DIGITAL AUDIO INTERFACE TIMING - MASTER MODE | | | CONTROL INTERFACE TIMING – 2-WIRE MODE | 14 | | CONTROL INTERFACE TIMING – 3-WIRE MODE | 15 | | POWER ON RESET (POR) | 16 | | DEVICE DESCRIPTION | <b>17</b> | | INTRODUCTION | 17 | | CONTROL INTERFACE | | | 2-WIRE (SM-BUS COMPATIBLE) SERIAL CONTROL INTERFACE MODE | | | 3-WIRE (SPI COMPATIBLE) SERIAL CONTROL INTERFACE MODE | | | GLOBAL ENABLE CONTROL | | | DIGITAL AUDIO INTERFACE | | | DIGITAL AUDIO DATA SAMPLING RATES | | | DIGITAL AUDIO DATA FORMATS | | | DAC FEATURES | | | ADC FEATURESANALOGUE ROUTING CONTROL | | | POP AND CLICK PERFORMANCE | | | REGISTER MAP | | | DIGITAL FILTER CHARACTERISTICS | | | | | | APPLICATIONS INFORMATION RECOMMENDED EXTERNAL COMPONENTS | | | RECOMMENDED EXTERNAL COMPONENTS RECOMMENDED ANALOGUE LOW PASS FILTER | | | EXTENDED INPUT IMPEDANCE CONFIGURATION | /5<br>75 | | RELEVANT APPLICATION NOTES | | | PACKAGE DIMENSIONS | | | IMPORTANT NOTICE | | | ADDRESS: | | | ADDINEOG | 10 | # **PIN CONFIGURATION** # **ORDERING INFORMATION** | DEVICE | TEMPERATURE<br>RANGE | PACKAGE | MOISTURE SENSITIVITY<br>LEVEL | PEAK SOLDERING<br>TEMPERATURE | |---------------|----------------------|------------------------------------------|-------------------------------|-------------------------------| | WM8594SEFT/V | -25 to +85°C | 48-lead TQFP<br>(Pb-free) | MSL1 | 260°C | | WM8594SEFT/RV | -25 to +85°C | 48-lead TQFP<br>(Pb-free, tape and reel) | MSL1 | 260°C | Note: Reel quantity = 2,200 # **PIN DESCRIPTION** | PIN | NAME | TYPE | DESCRIPTION | |-----|----------|----------------------|------------------------------------------------------| | 1 | ADCLRC | Digital Input/Output | ADC audio interface left/right clock input/output | | 2 | ADCBCLK | Digital Input/Output | ADC audio interface bit clock input/output | | 3 | DOUT | Digital Output | ADC data output | | 4 | DACMCLK1 | Digital Input | DAC1 master clock | | 5 | DACLRC1 | Digital input | DAC1 audio interface left/right clock input | | 6 | DACBCLK1 | Digital Input | DAC1 audio interface bit clock input | | 7 | DIN1 | Digital Input | DAC 1 data input | | 8 | DACMCLK2 | Digital Input | DAC2 master clock | | 9 | DACLRC2 | Digital input | DAC2 audio interface left/right clock input | | 10 | DACBCLK2 | Digital Input | DAC2 audio interface bit clock input | | 11 | DIN2 | Digital Input | DAC 2 data input | | 12 | DVDD | Supply | Digital supply | | 13 | DGND | Supply | Digital ground | | 14 | /PWDN | Digital Input | Hardware standby mode | | 15 | MUTE | Digital Input | Hardware DAC mute | | 16 | /RESET | Digital Input | Hardware reset | | 17 | AVDD2 | Supply | Analogue 9V supply | | 18 | AGND2 | Supply | Analogue ground | | 19 | VOUT3R | Analogue Output | Output selector channel 3 right output | | 20 | VOUT3L | Analogue Output | Output selector channel 3 left output | | 21 | VOUT2R | Analogue Output | Output selector channel 2 right output | | 22 | VOUT2L | Analogue Output | Output selector channel 2 left output | | 23 | VOUT1R | Analogue Output | Output selector channel 1 right output | | 24 | VOUT1L | Analogue Output | Output selector channel 1 left output | | 25 | VIN1L | Analogue Input | Input selector channel 1 left input | | 26 | VIN1R | Analogue Input | Input selector channel 1 right input | | 27 | VIN2L | Analogue Input | Input selector channel 2 left input | | 28 | VIN2R | Analogue Input | Input selector channel 2 right input | | 29 | VIN3L | Analogue Input | Input selector channel 3 left input | | 30 | VIN3R | Analogue Input | Input selector channel 3 right input | | 31 | VIN4L | Analogue Input | Input selector channel 4 left input | | 32 | VIN4R | Analogue Input | Input selector channel 4 right input | | 33 | VIN5L | Analogue Input | Input selector channel 5 left input | | 34 | VIN5R | Analogue Input | Input selector channel 5 right input | | 35 | ADCREFP | Analogue Input | Positive reference for ADC | | 36 | ADCVMID | Analogue Output | Midrail divider decoupling pin for ADC | | 37 | ADCREFN | Analogue Input | Ground reference for ADC | | 38 | DACREFP | Analogue Input | Positive reference for DACs | | 39 | DACVMID | Analogue Output | Midrail divider decoupling pin for DACs | | 40 | DACREFN | Analogue Input | Ground reference for DACs | | 41 | AVDD1 | Supply | Analogue 3.3V supply | | 42 | AGND1 | Supply | Analogue ground | | 43 | MODE | Digital Input | Software mode select (High = 3-wire, Low = 2-wire) | | 44 | SDOUT | Digital Output | Software mode: serial control interface data output | | 45 | /CS | Digital Input | Software mode: serial control interface chip select | | 46 | SCLK | Digital Input | Software mode: serial control interface clock signal | | 47 | SDIN | Digital Input | Software mode: serial control interface data signal | | 48 | ADCMCLK | Digital Input | ADC master clock input | # **ABSOLUTE MAXIMUM RATINGS** Absolute Maximum Ratings are stress ratings only. Permanent damage to the device may be caused by continuously operating at or beyond these limits. Device functional operating limits and guaranteed performance specifications are given under Electrical Characteristics at the test conditions specified. ESD Sensitive Device. This device is manufactured on a CMOS process. It is therefore generically susceptible to damage from excessive static voltages. Proper ESD precautions must be taken during handling and storage of this device. Wolfson tests its package types according to IPC/JEDEC J-STD-020B for Moisture Sensitivity to determine acceptable storage conditions prior to surface mount assembly. These levels are: MSL1 = unlimited floor life at <30°C / 85% Relative Humidity. Not normally stored in moisture barrier bag. MSL2 = out of bag storage for 1 year at <30°C / 60% Relative Humidity. Supplied in moisture barrier bag. MSL3 = out of bag storage for 168 hours at <30°C / 60% Relative Humidity. Supplied in moisture barrier bag. The Moisture Sensitivity Level for each package type is specified in Ordering Information. | CONDITION | MIN | MAX | |------------------------------------------------------|------------|--------------| | Digital supply voltage, DVDD | -0.3V | +4.5V | | Analogue supply voltage, AVDD1 | -0.3V | +7V | | Analogue supply voltage, AVDD2 | -0.3V | +15V | | Voltage range digital inputs | DGND -0.3V | DVDD + 0.3V | | Voltage range analogue inputs | TBD | AVDD1 + 0.2V | | Master Clock Frequency | | 38.462MHz | | Ambient temperature (supplies applied) | -55°C | +125°C | | Storage temperature | -65°C | +150°C | | Pb free package body temperature (reflow 10 seconds) | | +260°C | | Package body temperature (soldering 2 minutes) | | +183°C | #### Note: # THERMAL PERFORMANCE | PARAMETER | SYMBOL | TEST<br>CONDITIONS | MIN | TYP | MAX | UNIT | |------------------------------------------|----------------|--------------------|-----|--------------------|-----|------| | Thermal resistance – junction to ambient | $R_{ heta JA}$ | | | 51.7<br>See note 1 | | °C/W | #### Notes: - 1. Figure given for package mounted on 4-layer FR4 according to JESD51-7. (No forced air flow is assumed). - 2. Thermal performance figures are estimated. <sup>1.</sup> Analogue and digital grounds must always be within 0.3V of each other. # RECOMMENDED OPERATING CONDITIONS | PARAMETER | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-----------------------------|----------------|-----------------|------|-----|-----|------| | Digital power supply | DVDD | | 2.97 | 3.3 | 3.6 | V | | Analogue power supply | AVDD1 | | 2.97 | 3.3 | 3.6 | V | | Analogue power supply | AVDD2 | | 8.1 | 9 | 9.9 | V | | Ground | DGND/AGND1/ | | | 0 | | V | | | AGND2 | | | | | | | Operating temperature range | T <sub>A</sub> | | -25 | | +85 | °C | #### Notes: - 1. Digital supply (DVDD) must never be more than 0.3V greater than AVDD1 in normal operation. - 2. Digital ground (DGND) and analogue grounds (AGND1, AGND2) must never be more than 0.3V apart. # **SUPPLY CURRENT CONSUMPTION** | PARAMETER | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------|--------------------|-----------------|-----|-----|-----|------| | Digital supply current | I <sub>DVDD</sub> | | | TBD | | mA | | Analogue supply current | I <sub>AVDD1</sub> | | | TBD | | mA | | Analogue supply current | I <sub>AVDD2</sub> | | | TBD | | mA | | Standby current | | | | TBD | | μA | # **ELECTRICAL CHARACTERISTICS** #### **Test Conditions** AVDD2=9V, AVDD1=DVDD=3.3V, AGND1=AGND2=0V, DGND=0V, T<sub>A</sub>=+25°C, 1kHz signal, fs=48kHz, MCLK=256fs unless otherwise stated | PARAMETER | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |--------------------------------------------|-----------------|-----------------------------------|------------|-------------------|------------|------| | Digital logic levels | | | | | | | | Input low level | V <sub>IL</sub> | | | | 0.3xDVDD | V | | Input high level | V <sub>IH</sub> | | 0.7xDVDD | | | V | | Output low level | $V_{OL}$ | | | | 0.1 x DVDD | V | | Output high level | V <sub>OH</sub> | | 0.9 x DVDD | | | V | | Digital input leakage current | | | | TBD | | μA | | Digital input leakage capacitance | | | | TBD | | pF | | Analogue Reference Levels | | 1 | 1 | • | | | | ADC Midrail Voltage | ADCVMID | | | AVDD1/2 | | V | | ADC Buffered Positive<br>Reference Voltage | ADCREFP | | | ADCVMID | | V | | DAC Midrail Voltage | DACVMID | | | DACREFP/2 | | V | | Potential divider resistance | | AVDD1 to ADCVMID ADCVMID to AGND1 | | 100 | | kΩ | | | | DACVREFP to DACVMID | | 50 | | kΩ | | | | DACVMID to DACVREFN | | (Note 2) | | | | | | VMID_SEL[1:0] = 01 | | | | | | Analogue Line Outputs | | | | | | | | Output signal level (0dB) | | $R_L = 10k\Omega$ | TBD | 2.0x<br>AVDD2 / 9 | TBD | Vrms | | Maximum capacitance load | | | | | 11 | nF | | Minimum resistance load | | | 1 | | | kΩ | # **Test Conditions** AVDD2=9V, AVDD1=DVDD=3.3V, AGND1=AGND2=0V, DGND=0V, T<sub>A</sub>=+25°C, 1kHz signal, fs=48kHz, MCLK=256fs unless otherwise stated | PARAMETER | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |------------------------------------------|--------|--------------------------------------|------|-----------|-----|----------| | Analogue Headphone Outputs | 1 | 1 | | | | 1 | | Output signal level (0dB) | | $R_L = 32\Omega$ | TBD | 0.8x | TBD | Vrms | | , | | | | AVDD2/9 | | | | Minimum resistance load | | | 16 | | | Ω | | Analogue Inputs | | | | | | • | | Input signal level (0dB) | | | | 2.0 x | TDD | \/===== | | | | | | AVDD1/3.3 | TBD | Vrms | | Input impedance | | | 10 | 11 | 12 | kΩ | | Extended input impedance | | External resistor = | | 21 | | kΩ | | (Note 3) | | 10kΩ | | | | | | Input capacitance | | | | TBD | | nF | | DAC Performance | | | | | | | | Signal to Noise Ratio <sup>1,5</sup> | SNR | A-weighted | TBD | 100 | | dB | | | | @ fs = 48kHz | | | | | | | | A-weighted | | 100 | | dB | | | | @ fs = 96kHz | | | | | | | | A-weighted | | 100 | | dB | | | | @ fs = 192kHz | | | | | | Dynamic Range <sup>2,5</sup> | DNR | A-weighted, -60dB full | TBD | 100 | | dB | | | | scale input | | | | <u> </u> | | Total Harmonic Distortion <sup>3,5</sup> | THD | 1kHz, 0dBFS | | -90 | TBD | dB | | | | @ fs = 48kHz | | | | | | | | 1kHz, 0dBFS | | -90 | | dB | | | | @ fs = 96kHz | | | | | | | | 1kHz, 0dBFS | | -90 | | dB | | | | @ fs = 192kHz | | | | | | Channel Separation <sup>4,5</sup> | | | | 100 | | dB | | Channel Level Matching | | | | 0.1 | | dB | | Channel Phase Deviation | | | | 0.05 | | Degree | | Power supply rejection ratio | PSRR | 1kHz, 100mVpp | TBD | 50 | | dB | | | | 20Hz to 20kHz, | | TBD | | dB | | | | 100mVpp | | | | | | ADC Performance | 1 | T | | | | 1 | | Signal to Noise Ratio <sup>1,5</sup> | SNR | A-weighted, 0dB gain | TBD | 100 | | dB | | | | @ fs = 48kHz | | | | in . | | | | A-weighted, 0dB gain<br>@ fs = 96kHz | | 97 | | dB | | Dynamic Range <sup>2,5</sup> | DNR | A-weighted, -60dB full | TBD | 100 | | dB | | Dynamic Nange | אוע | scale input | טטו | 100 | | UD | | Total Harmonic Distortion <sup>3,5</sup> | THD | 1kHz, -1dBFS | | -90 | TBD | dB | | | | @ fs = 48kHz | | | == | | | | | 1kHz, -1dBFS | | -87 | | dB | | | | @ fs = 96kHz | | '. | | | | Channel Separation <sup>4,5</sup> | | | | 100 | | dB | | Channel Level Matching | | | | 0.1 | | dB | | Channel Phase Deviation | 1 | | | 0.05 | | Degree | | Power Supply Rejection Ratio | PSRR | | TBD | 50 | | dB | | . S. S. Supply Rejodion Railo | . 5141 | | . 50 | TBD | | dB | | Analogue Bypass Paths | I | 1 | | 100 | | 1 40 | | Signal to Noise Ratio <sup>1,5</sup> | SNR | A-weighted | | 100 | | dB | | Dynamic Range <sup>2,5</sup> | DNR | A-weighted A-weighted | | 100 | | dB | | | I DINK | A-WEIGHTEG | | IUU | | ı uD | **Test Conditions** AVDD2=9V, AVDD1=DVDD=3.3V, AGND1=AGND2=0V, DGND=0V, T<sub>A</sub>=+25°C, 1kHz signal, fs=48kHz, MCLK=256fs unless otherwise stated | PARAMETER | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |--------------------------------------|--------|------------------------------------------------|-----|-------|-----|--------| | Channel Separation <sup>4,5</sup> | | | | 100 | | dB | | Channel Level Matching | | | | 0.1 | | dB | | Channel Phase Deviation | | | | 0.05 | | Degree | | Headphone Amplifier | | <u> </u> | | | • | • | | Output signal level (0dB) | | | | 0.8 | | Vrms | | Signal to Noise Ratio <sup>1,5</sup> | SNR | A-weighted | | | | dB | | Total Harmonic Distortion | THD | $P_O=20$ mW, $R_L=16\Omega$ | | | | dB | | | | $P_O=20$ mW, $R_L=32\Omega$ | | | | dB | | Channel Separation <sup>4,5</sup> | | | | | | dB | | Power Supply Rejection Ratio | PSRR | | | TBD | | dB | | Digital Volume Control | | <u> </u> | | | • | • | | ADC minimum digital volume | | | | -97 | | dB | | ADC maximum digital volume | | | | +30 | | dB | | ADC volume step size | | | | 0.5 | | dB | | DAC minimum digital volume | | | | -100 | | dB | | DAC maximum digital volume | | | | +12 | | dB | | DAC volume step size | | | | 0.5 | | dB | | Analogue Volume Control | | <u> </u> | | | • | • | | Minimum gain | | | | -73.5 | | dB | | Maximum gain | | | | +6 | | dB | | Step size | | | | 0.5 | | dB | | Mute attenuation | | | | TBD | | dB | | Crosstalk | | <u>. </u> | | | • | | | DAC to ADC | | 1kHz signal, | | 100 | | dB | | | | ADC fs=48kHz, | | | | | | | | DAC fs=44.1kHz | | | | | | | | 20kHz signal, | | 100 | | dB | | | | ADC fs=48kHz, | | | | | | | | DAC fs=44.1kHz | | | | | | ADC to DAC | | 1kHz signal, | | 100 | | dB | | | | ADC fs=48kHz, | | | | | | | | DAC fs=44.1kHz | | | | | | | | 20kHz signal, | | 100 | | dB | | | | ADC fs=48kHz, | | | | | | | | DAC fs=44.1kHz | | | | | # **TERMINOLOGY** - Signal-to-noise ratio (dBFS) SNR is the difference in level between a reference full scale output signal and the device output with no signal applied. This ratio is also called idle channel noise. (No Auto-zero or Automute function is employed in achieving these results). - 2. Dynamic range (dBFS) DNR is a measure of the difference in level between the highest and lowest components of a signal. Normally a THD measurement at -60dBFS. The measured signal is then corrected by adding 60dB to the result, e.g. THD @ -60dBFS = -30dB, DNR = 90dB. - 3. Total Harmonic Distortion (dBFS) THD is the difference in level between a reference full scale output signal and the first seven odd harmonics of the output signal. To calculate the ratio, the fundamental frequency of the output signal is notched out and an RMS value of the next seven odd harmonics is calculated. - 4. Channel Separation (dB) Also known as Cross-Talk. This is a measure of the amount one channel is isolated from the other. Normally measured by sending a full scale signal down one channel and measuring the other. 5. All performance measurements carried out with 20kHz low pass filter, and where noted an A-weighted filter. Failure to use such a filter will result in higher THD and lower SNR and Dynamic Range readings than are found in the Electrical Characteristics. The low pass filter removes out of band noise; although it is not audible it may affect dynamic specification values. # Notes: - 1. All minimum and maximum values are subject to change. - 2. This resistance is selectable using VMID\_SEL[1:0] see Figure 49 for full details. - 3. See p75 for details of extended input impedance configuration. # **MASTER CLOCK TIMING** Figure 1 MCLK Timing # **Test Conditions** AVDD1, DVDD = 3.3V, AVDD2 = 9V, AGND1, AGND2, DGND = 0V, $T_A = +25^{\circ}C$ | PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT | |---------------------------------|--------------------|-------|-----|-------|------| | Master Clock Timing Information | | | | | | | MCLK System clock cycle time | t <sub>MCLKY</sub> | 27 | | 120 | ns | | MCLK Duty cycle | | 40:60 | | 60:40 | % | | MCLK Period Jitter | | | | 200 | ps | | MCLK Rise/Fall times | | | | 10 | ns | **Table 1 Master Clock Timing Requirements** # **DIGITAL AUDIO INTERFACE TIMING – SLAVE MODE** Figure 2 Slave Mode Digital Audio Data Timing # **Test Conditions** AVDD1, DVDD = 3.3V, AVDD2 = 9V, AGND1, AGND2, DGND = 0V, $T_A$ = $+25^{\circ}C$ , Slave Mode, fs = 48kHz, ADCMCLK, DACMCLK = 256fs, 24-bit data, unless otherwise stated. | PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT | |--------------------------------------------------------------------------------------------|------------------|-----|-----|-----|------| | Audio Data Input Timing Information | | | | | | | ADCBCLK / DACBCLK1 / DACBCLK2 cycle time | t <sub>BCY</sub> | 80 | | | ns | | ADCBCLK / DACBCLK1 / DACBCLK2 pulse width high | t <sub>BCH</sub> | 30 | | | ns | | ADCBCLK / DACBCLK1 / DACBCLK2 pulse width low | t <sub>BCL</sub> | 30 | | | ns | | ADCBCLK / DACBCLK1 / DACBCLK2 rise/fall times | | | | 5 | ns | | ADCLRCLK / DACLRCLK1 / DACLRCLK2 set-up time to ADCBCLK / DACBCLK1 / DACLRCLK2 rising edge | $t_{LRSU}$ | 22 | | | ns | | ADCLRCLK / DACLRCLK1 / DACLRCLK2 hold time from ADCBCLK / DACBCLK1 / DACBCLK2 rising edge | t <sub>LRH</sub> | 25 | | | ns | | ADCLRCLK / DACLRCLK1 / DACLRCLK2 rise/fall times | | | | 5 | ns | | DIN1/2 hold time from DACBCLK1 / DACBCLK2 rising edge | t <sub>DH</sub> | 25 | | | ns | | DOUT propagation delay from ADCBCLK falling edge | t <sub>DD</sub> | 4 | | 16 | ns | **Table 2 Slave Mode Audio Interface Timing** # **DIGITAL AUDIO INTERFACE TIMING - MASTER MODE** Figure 3 Master Mode Digital Audio Data Timing #### **Test Conditions** AVDD1, DVDD = 3.3V, AVDD2 = 9V, AGND1, AGND2, DGND = 0V, $T_A$ = $+25^{\circ}C$ , Slave Mode, fs = 48kHz, ADCMCLK, DACMCLK = 256fs, 24-bit data, unless otherwise stated. | PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT | |-----------------------------------------------------------------------------------------------------|------------------|-----|-----|-----|------| | Audio Data Input Timing Information | | | | | | | ADCLRCLK / DACLRCLK1 / DACLRCLK2 propagation delay from ADCBCLK / DACBCLK1 / DACLRCLK2 falling edge | t <sub>DL</sub> | 4 | | 16 | ns | | DOUT propagation delay from ADCBCLK falling edge | t <sub>DDA</sub> | 4 | | 16 | ns | | DIN1 / DIN2 setup time to DACBCLK1 / DACBCLK2 rising edge | t <sub>DST</sub> | 22 | | | ns | | DIN1 / DIN2 hold time to DACBCLK1 / DACBCLK2 rising edge | t <sub>DHT</sub> | 25 | | | ns | **Table 3 Master Mode Audio Interface Timing** # **CONTROL INTERFACE TIMING – 2-WIRE MODE** Figure 4 Control Interface Timing – 2-Wire Serial Control Mode # **Test Conditions** AVDD1, DVDD = 3.3V, AVDD2 = 9V, AGND1, AGND2, DGND = 0V, $T_A$ = $+25^{\circ}C$ , Slave Mode, fs = 48kHz, ADCMCLK, DACMCLK = 256fs, 24-bit data, unless otherwise stated. | PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT | |-----------------------------------------------|-------------------|-------|-----|-------|------| | Program Register Input Information | | | | • | | | SCLK pulse cycle time | tscy | 2500 | | | ns | | SCLK duty cycle | | 40/60 | | 60/40 | % | | SCLK frequency | | | | 400 | kHz | | Hold Time (Start Condition) | t <sub>STHO</sub> | 600 | | | ns | | Setup Time (Start Condition) | t <sub>STSU</sub> | 600 | | | ns | | Data Setup Time | t <sub>DSU</sub> | 100 | | | ns | | SDIN, SCLK Rise Time | | | | 300 | ns | | SDIN, SCLK Fall Time | | | | 300 | ns | | Setup Time (Stop Condition) | t <sub>STOP</sub> | 600 | | | ns | | Data Hold Time | t <sub>DHO</sub> | | | 900 | ns | | Pulse width of spikes that will be suppressed | t <sub>ps</sub> | 2 | | 8 | ns | Table 4 Control Interface Timing – 2-Wire Serial Control Mode # **CONTROL INTERFACE TIMING – 3-WIRE MODE** Figure 5 Control Interface Timing – 3-Wire Serial Control Mode # **Test Conditions** AVDD1, DVDD = 3.3V, AVDD2 = 9V, AGND1, AGND2, DGND = 0V, $T_A = +25$ °C, Slave Mode, fs = 48kHz, ADCMCLK, DACMCLK = 256fs, 24-bit data, unless otherwise stated. | PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT | | | | |-----------------------------------------------|------------------|-------|-----|-------|------|--|--|--| | Program Register Input Information | | | | | | | | | | SCLK rising edge to CSB rising edge | t <sub>SCS</sub> | 60 | | | ns | | | | | SCLK pulse cycle time | t <sub>SCY</sub> | 80 | | | ns | | | | | SCLK duty cycle | | 40/60 | | 60/40 | % | | | | | SDIN to SCLK set-up time | t <sub>DSU</sub> | 20 | | | ns | | | | | SDIN hold time from SCLK rising edge | t <sub>DHO</sub> | 20 | | | ns | | | | | SDOUT propagation delay from SCLK rising edge | t <sub>DL</sub> | | | 5 | ns | | | | | CSB pulse width high | t <sub>CSH</sub> | 20 | | | ns | | | | | CSB rising/falling to SCLK rising | tcss | 20 | | | ns | | | | | Pulse width of spikes that will be suppressed | t <sub>ps</sub> | 2 | | 8 | ns | | | | Table 5 Control Interface Timing – 3-Wire Serial Control Mode # **POWER ON RESET (POR)** Figure 1 Power Supply Timing Requirements ### **Test Conditions** $DVDD = 3.3V, \ AVDD1 = 3.3V, \ AVDD2 = 9V \ DGND = AGND1 = AGND2 = 0V, \ T_A = +25^{\circ}C, \ T_{A\_max} = +125^{\circ}C, \ T_{A\_min} = -25^{\circ}C \ AVDD1_{max} = DVDD_{max} = 3.63V, \ AVDD1_{min} = DVDD_{min} = 2.97V, \ AVDD2_{max} = 9.9V, \ AVDD2_{min} = 8.1V$ | PARAMETER | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-----------------------------------------------|----------------------|--------------------|------|------|------|------| | Power Supply Input Timing | Information | | | • | | | | VDD level to POR defined (DVDD rising) | V <sub>pord</sub> | Measured from DGND | 0.27 | 0.36 | 0.60 | V | | VDD level to POR rising edge (DVDD rising) | $V_{pord\_hi}$ | Measured from DGND | 1.34 | 1.88 | 2.32 | V | | VDD level to POR falling edge (DVDD falling) | V <sub>pord_lo</sub> | Measured from DGND | 1.32 | 1.86 | 2.30 | V | | VDD level to POR rising edge (AVDD1 rising) | V <sub>por1_hi</sub> | Measured from DGND | 1.65 | 1.68 | 1.85 | V | | VDD level to POR falling edge (AVDD1 falling) | V <sub>por1_lo</sub> | Measured from DGND | 1.63 | 1.65 | 1.83 | V | | VDD level to POR rising edge (AVDD2 rising) | V <sub>por2_hi</sub> | Measured from DGND | 1.80 | 1.86 | 2.04 | V | | VDD level to POR falling edge (AVDD2 falling) | V <sub>por2_lo</sub> | Measured from DGND | 1.76 | 1.8 | 2.02 | V | **Table 6 Power on Reset** #### **DEVICE DESCRIPTION** #### INTRODUCTION The WM8594 is a high performance multi-channel audio CODEC with 2Vrms line level inputs and outputs and flexible analogue input / output switching. The device comprises a 24-bit stereo ADC, two 24-bit stereo DACs with independent sampling rates and digital volume control, and a flexible analogue input and output multiplexer. Analogue inputs and outputs are all at 2Vrms line level, minimising external component count. The DACs can operate from independent left/right clocks, bit clocks and master clocks with independent data inputs. Alternatively, the DACs can be synchronised to use the same clocks with independent data inputs. Each of the DAC audio interfaces can be configured to operate in ether master or slave clocking modes. In master mode, left/right clocks and bit clocks are all outputs. In slave mode, left/right clocks and bit clocks are all inputs. The ADC uses a separate left/right clock, bit clock and master clock, allowing independent recording and playback in audio applications. The ADC audio interface can be configured to operate in either master or slave clocking mode. In master mode, left/right clocks and bit clocks are all outputs. In slave mode, left/right clocks and bit clocks are all inputs. The ADC includes digital gain control, allowing signals to be gained and attenuated between +30dB and -97dB in 0.5dB steps. The DACs include independent digital volume control, which is adjustable between +12dB and -100 dB in 0.5dB steps. The DACs can be configured to output stereo audio data and a range of mono audio options. The input multiplexer accepts five stereo line level inputs at up to 2Vrms. One stereo input can be routed to the ADC, and all five stereo inputs can be routed to the output multiplexer. The output multiplexer includes analogue volume control with zero cross, adjustable between +6dB and -73.5dB in 0.5dB steps, and configurable soft ramp rate. Analogue audio is output at 2Vrms line level. Control of the internal functionality of the device is by 2-wire serial control interface with readback. The interface may be asynchronous to the audio data interface as control data will be resynchronised to the audio processing internally. In addition, control of mute, power-down and reset may also be achieved by pin selection. Operation using system clocks of 128fs, 192fs, 256fs, 384fs, 512fs, 768fs or 1152fs is provided. ADC and both DACs may be clocked independently. Sampling rates from 32kHz to 192kHz are supported for both DACs provided the appropriate master clocks are input. Sampling rates from 32kHz to 96kHz are supported for the ADC provided the appropriate master clock is input. The audio data interface supports right justified, left justified, and I<sup>2</sup>S interface formats along with a highly flexible DSP serial port interface format. #### **CONTROL INTERFACE** Control of the WM8594 is achieved by a 2-wire SM-bus-compliant or 3-wire SPI compliant serial interface with readback. Software interface mode is selected using the MODE pin as shown in Table 7 below: | MODE | INTERFACE FORMAT | |------|------------------| | Low | 2 wire | | High | 3 wire | Table 7 Control Interface Mode Selection # 2-WIRE (SM-BUS COMPATIBLE) SERIAL CONTROL INTERFACE MODE Many devices can be controlled by the same bus, and each device has a unique 7-bit address. #### **REGISTER WRITE** The controller indicates the start of data transfer with a high to low transition on SDIN while SCLK remains high. This indicates that a device address and data will follow. All devices on the 2-wire bus respond to the start condition and shift in the next eight bits on SDIN (7-bit address and read/write bit, MSB first). If the device address received matches the address of the WM8594, the WM8594 responds by pulling SDIN low on the next clock pulse (ACK). If the address is not recognised, the WM8594 returns to the idle condition and waits for a new start condition with valid address. When the WM8594 has acknowledged a correct address, the controller sends the first byte of control data (B23 to B16, i.e. the WM8594 register address). The WM8594 then acknowledges the first data byte by pulling SDIN low for one SCLK pulse. The controller then sends a second byte of control data (B15 to B8, i.e. the first 8 bits of register data), and the WM8594 acknowledges again by pulling SDIN low for one SCLK pulse. Finally, the controller sends a third byte of control data (B7 to B0, i.e. the final 8 bits of register data), and the WM8594 acknowledges again by pulling SDIN low for one SCLK pulse. The transfer of data is complete when there is a low to high transition on SDIN while SCLK is high. After receiving a complete address and data sequence the WM8594 returns to the idle state and waits for another start condition. If a start or stop condition is detected out of sequence at any point during data transfer (i.e. SDIN changes while SCLK is high), the WM8594 reverts to the idle condition. The WM8594 device address is 34h (0110100) or 36h (0110110), selectable by control of /CS. | /CS (PIN 45) | 2-WIRE BUS ADDRESS | |--------------|--------------------| | 0 | 34h (0110100) | | 1 | 36h (0110110) | Table 8 2-Wire Control Interface Bus Address Selection Figure 7. As with normal register writes, the controller indicates the start of data transfer with a high to low transition on SDIN while SCLK remains high, and all devices on the bus receive the device address When the WM8594 has acknowledged a correct address, the controller sends the first byte of control data (A6 to A0, i.e. the WM8594 initial register address). The WM8594 then acknowledges the first control data byte by pulling SDIN low for one SCLK pulse. The controller then sends a byte of register data. The WM8594 acknowledges the first byte of register data, auto-increments the register address to be written to, and waits for the next byte of register data. Subsequent bytes of register data can be written to consecutive registers of the WM8594 without setting up the device and register address. The transfer of data is complete when there is a low to high transition on SDIN while SCLK is high. Figure 7 2-Wire Auto-Increment Register Write #### **REGISTER READBACK** The WM8594 allows readback of all registers with data output on the bidirectional SDIN pin. The protocol is similar to that used to write to the device. The controller will issue the device address followed by a write bit, and the register index will then be passed to the WM8594. At this point the controller will issue a repeated start condition and resend the device address along with a read bit. The WM8594 will acknowledge this and the WM8594 will become a slave transmitter. The WM8594 will place the data from the indexed register onto SDIN MSB first. When the controller receives the first byte of data, it acknowledges it. When the controller receives the second and final byte of data it will not acknowledge receipt of the data indicating that it will resume master transmitter control of SDIN. The controller will then issue a stop command completing the read cycle. Figure 8 2-wire Read Protocol # **AUTO-INCREMENT REGISTER READBACK** It is possible to read from multiple consecutive registers in continuous readback mode. Continuous readback mode is selected by setting AUTO\_INC. In continuous readback mode, the WM8594 will return the indexed register first, followed by consecutive registers in increasing index order until the controller issues a stop sequence. Figure 9 2-Wire Auto-Increment Register Readback # 3-WIRE (SPI COMPATIBLE) SERIAL CONTROL INTERFACE MODE REGISTER WRITE SDIN is used for the program data, SCLK is used to clock in the program data and /CS is use to latch in the program data. SDIN is sampled on the rising edge of SCLK. The 3-wire interface write protocol is shown in Figure 10. Figure 10 3-Wire Serial Interface Write Protocol - W indicates write operation. - A[6:0] is the register index. - B[15:0] is the data to be written to the register indexed. - /CS is edge sensitive the data is latched on the rising edge of /CS. #### **REGISTER READ-BACK** The read-only status registers can be read back via the SDOUT pin. Read Back is enabled when the R/W bit is high. The data can then be read by writing to the appropriate register address, to which the device will respond with data. Figure 11 3-Wire Serial Interface Readback Protocol # **REGISTER RESET** Any write to register R0 (00h) will reset the WM8594. All register bits are reset to their default values. #### **DEVICE ID AND REVISION** Reading from register R0 returns the device ID. Reading from register R1 returns the device revision number. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|------|-----------|----------|------------------------------------------------| | R0 | 15:0 | DEVICE_ID | 10000101 | Device ID | | DEVICE_ID | | [15:0] | 10010100 | A read of this register will return the device | | 00h | | | | ID, 0x8594. | | R1 | 7:0 | REVNUM | N/A | Device Revision | | REVISION | | [7:0] | | A read of this register will return the device | | 01h | | | | revision number. This number is sequentially | | | | | | incremented if the device design is updated. | **Table 9 Device ID and Revision Number** #### **GLOBAL ENABLE CONTROL** The WM8594 includes a number of enable and disable mechanisms to allow the device to be powered on and off in a pop-free manner. A global enable control bit enables the ADC, DAC and analogue paths. For full details of pop-free operation, see 'Pop and Click Performance' on page 44. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------|---------|------------------------------------------------------| | R12 | 0 | GLOBAL_ | 0 | Device Global Enable | | ENABLE<br>0Ch | | EN | | 0 = ADC, DAC and PGA ramp control circuitry disabled | | | | | | 1 = ADC, DAC and PGA ramp control circuitry enabled | **Table 10 Global Enable Control** ## **DIGITAL AUDIO INTERFACE** Digital audio data is transferred to and from the WM8594 via the digital audio interface. The DACs have independent data inputs and master clocks, bit clocks and left/right frame clocks, and operate in both master or slave mode The ADC has independent master clock, bit clock and left/right frame clock in addition to its data output, and can operate in both master and slave modes. # **MASTER MODE** The ADC audio interface requires both a left/right frame clock (ADCLRCLK) and a bit clock (ADCBCLK). These can be supplied externally (slave mode) or they can be generated internally (master mode). Selection of master and slave mode is achieved by setting ADC\_MSTR in ADC Control Register 15. The frequency of ADCLRCLK in master mode is dependent upon the ADC master clock frequency and the ADC\_SR[2:0] bits. The frequency of ADCBCLK in master mode can be selected by ADC\_BCLKDIV[1:0]. The DAC audio interfaces require both left/right frame clocks (DACLRCLK1, DACLRCLK2) and bit clocks (DACBCLK1, DACBCLK2). These can be supplied externally (slave mode) or they can be generated internally (master mode). Selection of master and slave mode is achieved by setting DAC1\_MSTR in DAC1 Control Register 4 and DAC2\_MSTR in DAC2 Control Register 9. The frequency of DACLRCLK1 in master mode is dependent upon the DAC1 master clock frequency and the DAC1\_SR[2:0] bits. Similarly the frequency of DACLRCLK2 in master mode is dependent upon the DAC2 master clock frequency and the DAC2\_SR[2:0] bits. The frequency of DACBCLK1 and DACBCLK2 in master mode can be selected by DAC1\_BCLKDIV[1:0] and DAC2\_BCLKDIV[1:0]. | | EGISTER<br>DDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |------|-------------------|-----|---------|---------|-------------------------------------------------------------| | | R3 | 2:0 | DAC1_ | 000 | DAC MCLK:LRCLK Ratio | | DA | C1_CTRL2 | | SR[2:0] | | 000 = Auto detect | | | 03h | | | | 001 = 128fs | | | | | | | 010 = 192fs | | | | | | | 011 = 256fs | | | | | | | 100 = 384fs | | | | | | | 101 = 512fs | | | | | | | 110 = 768fs | | | | | | | 111 = 1152fs | | | | 5:3 | DAC1_ | 000 | DAC1 BCLK Rate | | | | | BCLKDIV | | 000 = MCLK / 4 | | | | | [2:0] | | 001 = MCLK / 8 | | | | | | | 010 = 32fs | | | | | | | 011 = 64fs | | | | | | | 100 = 128fs | | | | | | | All other values of DAC1_BCLKDIV[2:0] are | | | | | | | reserved | | | R4 | 0 | DAC1_ | 0 | DAC1 Master Mode Select | | DA | C1_CTRL3<br>04h | | MSTR | | 0 = Slave mode, DACBCLK1 and DACLRCLK1 are inputs to WM8594 | | | | | | | 1 = Master mode, DACBCLK1 and | | | D0 | 0.0 | DACO | 000 | DACLECLK1 are outputs from WM8594 | | D.4. | R8 | 2:0 | DAC2_ | 000 | DAC MCLK:LRCLK Ratio | | DA | C1_CTRL2 | | SR[2:0] | | 000 = Auto detect | | | 08h | | | | 001 = 128fs | | | | | | | 010 = 192fs | | | | | | | 011 = 256fs<br>100 = 384fs | | | | | | | 100 = 36415<br>101 = 512fs | | | | | | | 110 = 768fs | | | | | | | 111 = 1152fs | | | | 5:3 | DAC2_ | 000 | DAC2 BCLK Rate | | | | 5.5 | BCLKDIV | 000 | 000 = MCLK / 4 | | | | | [2:0] | | 000 = MCLK / 4<br>001 = MCLK / 8 | | | | | [2.0] | | 010 = 32fs | | | | | | | 011 = 64fs | | | | | | | 100 = 128fs | | | | | | | All other values of DAC2_BCLKDIV[2:0] are | | | | | | | reserved | | | R9 | 0 | DAC2_ | 0 | DAC2 Master Mode Select | | DA | C2_CTRL3 | | MSTR | | 0 = Slave mode, DACBCLK2 and | | | _<br>09h | | | | DACLRCLK2 are inputs to WM8594 | | | | | | | 1 = Master mode, DACBCLK2 and | | | | | | | DACLRCLK2 are outputs from WM8594 | | | R14 | 2:0 | ADC_ | 000 | ADC MCLK:LRCLK Ratio | | AD | C_CTRL2 | | SR[2:0] | | 000 = Auto detect | | | 0Eh | | | | 001 = 128fs | | | | | | | 010 = 192fs | | | | | | | 011 = 256fs | | | | | | | 100 = 384fs | | | | | | | 101 = 512fs | | | | | | | 110 = 768fs | | 1 | | | | | | | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|----------|---------|---------------------------------------------------| | | 5:3 | ADC_BCLK | 000 | ADC BCLK Rate | | | | DIV[2:0] | | 000 = MCLK / 4 | | | | | | 001 = MCLK / 8 | | | | | | 010 = 32fs | | | | | | 011 = 64fs | | | | | | 100 = 128fs | | | | | | All other values of ADC_BCLKDIV[2:0] are reserved | | R15 | 0 | ADC_ | 0 | ADC Master Mode Select | | ADC_CTRL3 | | MSTR | | 0 = Slave mode, ADCBCLK and ADCLRCLK | | 0Fh | | | | are inputs to WM8594 | | | | | | 1 = Master mode, ADCBCLK and | | | | | | ADCLRCLK are outputs from WM8594 | **Table 11 ADC Master Mode Control** #### **SLAVE MODE** In slave mode, the master clock to left/right clock ratio can be auto-detected or set manually by register write. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------|---------|----------------------| | R3 | 2:0 | DAC1_ | 000 | DAC MCLK:LRCLK Ratio | | DAC1_CTRL2 | | SR[2:0] | | 000 = Auto detect | | 03h | | | | 001 = 128fs | | R8 | 2:0 | DAC2_ | 000 | 010 = 192fs | | DAC2_CTRL2 | | SR[2:0] | | 011 = 256fs | | 08h | | | | 100 = 384fs | | | | | | 101 = 512fs | | | | | | 110 = 768fs | | | | | | 111 = 1152fs | | R14 | 2:0 | ADC_ | 000 | ADC MCLK:LRCLK Ratio | | ADC_CTRL2 | | SR[2:0] | | 000 = Auto detect | | 0Eh | | | | 001 = reserved | | | | | | 010 = reserved | | | | | | 011 = 256fs | | | | | | 100 = 384fs | | | | | | 101 = 512fs | | | | | | 110 = 768fs | | | | | | 111 = Reserved | Table 12 Slave Mode MCLK to LRCLK Ratio Control # **DIGITAL AUDIO DATA SAMPLING RATES** In a typical digital audio system there is one central clock source producing a reference clock to which all audio data processing is synchronised. This clock is often referred to as the audio system's master clock. The WM8594 uses independent master clocks for ADC and DACs. The external master clocks can be applied directly to the ADCMCLK, DACMCLK1 and DACMCLK2 input pins. In a system where there are a number of possible sources for the reference clock, it is recommended that the clock source with the lowest jitter be used for the master clock to optimise the performance of the WM8594. In slave clocking mode the WM8594 has a master detection circuit that automatically determines the relationship between the master clock frequency (ADCMCLK, DACMCLK1, DACMCLK2) and the sampling rate (ADCLRCLK, DACLRCLK1, DACLRCLK2), to within +/- 32 system clock periods. The master clocks must be synchronised with the left/right clocks, although the device is tolerant of phase variations or jitter on the master clocks. The ADC supports master clock to sampling clock ratios of 256fs to 768fs and sampling rates of 32kHz to 96kHz, provided the internal signal processing of the ADC is programmed to operate at the correct rate. The DACs support master clock to sampling clock ratios of 128fs to 1152fs and sampling rates of 32kHz to 192kHz, provided the internal signal processing of the DACs is programmed to operate at the correct rate. Table 13 shows typical master clock frequencies and sampling rates supported by the WM8594 ADC. Table 14 shows typical master clock frequencies and sampling rates supported by the WM8594 DACs. | | MASTER CLOCK FREQUENCY (MHZ) | | | | | | | |--------------------------|------------------------------|-------------|-------------|-------------|--|--|--| | Sampling Rate (ADCLRCLK) | 256fs | 384fs | 512fs | 768fs | | | | | 32kHz | 8.192 | 12.288 | 16.384 | 24.576 | | | | | 44.1kHz | 11.2896 | 16.9344 | 22.5792 | 33.8688 | | | | | 48kHz | 12.288 | 18.432 | 24.576 | 36.864 | | | | | 88.2kHz | 22.5792 | 33.8688 | Unavailable | Unavailable | | | | | 96kHz | 24.576 | Unavailable | Unavailable | Unavailable | | | | **Table 13 ADC Master Clock Frequency Versus Sampling Rate** | Sampling Rate | | | MASTER C | NCY (MHZ) | | | | |--------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | (DACLRCLK1<br>DACLRCLK2) | 128fs | 192fs | 256fs | 384fs | 512fs | 768fs | 1152fs | | 32kHz | Unavailable | Unavailable | 8.192 | 12.288 | 16.384 | 24.576 | 36.864 | | 44.1kHz | Unavailable | 8.4672 | 11.2896 | 16.9344 | 22.5792 | 33.8688 | Unavailable | | 48kHz | Unavailable | 9.216 | 12.288 | 18.432 | 24.576 | 36.864 | Unavailable | | 88.2kHz | 11.2896 | 16.9344 | 22.5792 | 33.8688 | Unavailable | Unavailable | Unavailable | | 96kHz | 12.288 | 18.432 | 24.576 | 36.864 | Unavailable | Unavailable | Unavailable | | 176.4kHz | 22.5792 | 33.8688 | Unavailable | Unavailable | Unavailable | Unavailable | Unavailable | | 192kHz | 24.576 | 36.864 | Unavailable | Unavailable | Unavailable | Unavailable | Unavailable | Table 14 DAC Master Clock Frequency Versus Sampling Rate #### **DIGITAL AUDIO DATA FORMATS** The WM8594 supports a range of common audio interface formats: - I<sup>2</sup>S - Left Justified (LJ) - Right Justified (RJ) - DSP Mode A - DSP Mode B All formats send the MSB first and support word lengths of 16, 20, 24 and 32 bits, with the exception of 32 bit RJ mode, which is not supported. Audio data for each stereo channel is time multiplexed with the interface's left/right clock indicating whether the left or right channel is present. The left/right clock is also used as a timing reference to indicate the beginning or end of the data words. In LJ, RJ and I<sup>2</sup>S modes, the minimum number of bit clock periods per left/right clock period is two times the selected word length. The left/right clock must be high for a minimum of bit clock periods equivalent to the word length, and low for the same period. For example, for a word length of 24 bits, the left/right clock must be high for a minimum of 24 bit clock periods and low for a minimum of 24 bit clock periods. Any mark to space ratio is acceptable for the left/right clock provided these requirements are met. In DSP modes A and B, left and right channels must be time multiplexed and input on DIN1. LRCLK is used as a frame synchronisation signal to identify the MSB of the first input word. The minimum number of bit clock periods per left/right clock period is two times the selected word length. Any mark to space ratio is acceptable for the left/right clock provided the rising edge is correctly positioned. #### **I2S MODE** In I<sup>2</sup>S mode, the MSB of input data is sampled on the second rising edge of bit clock following a left/right clock transition. The MSB of output data changes on the first falling edge of bit clock following a left/right clock transition, and may be sampled on the next rising edge of bit clock. Left/right clocks are low during the left channel audio data samples and high during the right channel audio data samples. Figure 12 I2S Mode Timing # **LEFT JUSTIFIED (LJ) MODE** In LJ mode, the MSB of the input data is sampled by the WM8594 on the first rising edge of bit clock following a left/right clock transition. The MSB of output data changes on the same falling edge of bit clock as left/right clock and may be sampled on the next rising edge of bit clock. Left/right clock is high during the left channel audio data samples and low during the right channel audio data samples. Figure 13 LJ Mode Timing #### **RIGHT JUSTIFIED (RJ) MODE** In RJ mode the LSB of input data is sampled on the rising edge of bit clock preceding a left/right clock transition. The LSB of output data changes on the falling edge of bit clock preceding a left/right clock transition, and may be sampled on the next rising edge of bit clock. Left/right clock is high during the left channel audio data samples and low during the right channel audio data samples. Figure 14 RJ Mode Timing #### **DSP MODE A** In DSP Mode A, the MSB of channel 1 left data input is sampled on the second rising edge of bit clock following a left/right clock rising edge. Channel 1 right data then follows. The MSB of output data changes on the first falling edge of bit clock following a left/right clock transition and may be sampled on the rising edge of bit clock. The right channel data is contiguous with the left channel data. Figure 15 DSP Mode A Timing #### **DSP MODE B** In DSP Mode B, the MSB of channel 1 left data input is sampled on the first bit clock rising edge following a left/right clock rising edge. Channel 1 right data then follows. The MSB of output data changes on the same falling edge of BCLK as the low to high left/right clock transition and may be sampled on the rising edge of bit clock. The right channel data is contiguous with the left channel data. Figure 16 DSP Mode B Timing # **DIGITAL AUDIO INTERFACE CONTROL** The control of the audio interface formats is achieved by register write. Dynamically changing the audio data format may cause erroneous operation and is not recommended. Interface timing is such that the input data and left/right clock are sampled on the rising edge of the interface bit clock. Output data changes on the falling edge of the interface bit clock. By setting the appropriate bit clock and left/tight clock polarity bits, the WM8594 ADC and DACs can sample data on the opposite clock edges. The control of audio interface formats and clock polarities is summarised in Table 15. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|----------|---------|----------------------------------------------------------------| | R2 | 1:0 | DAC1_ | 10 | DAC1 Audio Interface Format | | DAC1_CTRL1 | | FMT[1:0] | | 00 = Right Justified | | 02h | | | | 01 = Left Justified | | | | | | $10 = I^2S$ | | | | | | 11 = DSP | | | 3:2 | DAC1_ | 10 | DAC1 Audio Interface Word Length | | | | WL[1:0] | | 00 = 16-bit | | | | | | 01 = 20-bit | | | | | | 10 = 24-bit | | | | | | 11 = 32-bit (not available in Right Justified mode) | | | 4 | DAC1_BCP | 0 | DAC1 BCLK Polarity | | | | | | 0 = DACBCLK not inverted - data latched on rising edge of BCLK | | | | | | 1 = DACBCLK inverted - data latched on | | | | | | falling edge of BCLK | | | 5 | DAC1_LRP | 0 | DAC1 LRCLK Polarity | | | | | | 0 = DACLRCLK not inverted | | | | | | 1 = DACLRCLK inverted | | R7 | 1:0 | DAC2_ | 10 | DAC2 Audio Interface Format | | DAC2_CTRL1 | | FMT[1:0] | | 00 = Right Justified | | 07h | | | | 01 = Left Justified | | | | | | $10 = I^2 S$ | | | | | | 11 = DSP | | | 3:2 | DAC2_ | 10 | DAC2 Audio Interface Word Length | | | | WL[1:0] | | 00 = 16-bit | | | | | | 01 = 20-bit | | | | | | 10 = 24-bit | | | | | | 11 = 32-bit (not available in Right Justified mode) | | | 4 | DAC2_BCP | 0 | DAC2 BCLK Polarity | | | | | | 0 = DACBCLK not inverted - data latched on rising edge of BCLK | | | | | | 1 = DACBCLK inverted - data latched on falling edge of BCLK | | | 5 | DAC2_LRP | 0 | DAC2 LRCLK Polarity | | | | | | 0 = DACLRCLK not inverted | | | | | | 1 = DACLRCLK inverted | | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|----------|---------|----------------------------------------------------------------| | R13 | 1:0 | ADC_ | 10 | ADC Audio Interface Format | | ADC_CTRL1 | | FMT[1:0] | | 00 = Right Justified | | 0Dh | | | | 01 = Left Justified | | | | | | $10 = I^2 S$ | | | | | | 11 = DSP | | | 3:2 | ADC_ | 10 | ADC Audio Interface Word Length | | | | WL[1:0] | | 00 = 16-bit | | | | | | 01 = 20-bit | | | | | | 10 = 24-bit | | | | | | 11 = 32-bit (not available in Right Justified mode) | | | 4 | ADC_BCP | 0 | ADC BCLK Polarity | | | | | | 0 = ADCBCLK not inverted - data latched on rising edge of BCLK | | | | | | 1 = ADCBCLK inverted - data latched on falling edge of BCLK | | | 5 | ADC_LRP | 0 | ADC LRCLK Polarity | | | | | | 0 = ADCLRCLK not inverted | | | | | | 1 = ADCLRCLK inverted | **Table 15 Audio Interface Control** # **DAC FEATURES** The WM8594 includes two 24-bit DACs with independent clocks and independent data inputs. The DACs include digital volume control with zero cross and soft mute, de-emphasis support, and the capability to select the output channels to be stereo or a range of mono options. The DACs are enabled by writing to DAC1\_EN and DAC2\_EN. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------|---------|-------------------| | R2 | 8 | DAC1_EN | 0 | DAC1 Enable | | DAC1_CTRL1 | | | | 0 = DAC disabled | | 02h | | | | 1 = DAC enabled | | R7 | 8 | DAC2_EN | 0 | DAC2 Enable | | DAC2_CTRL1 | | | | 0 = DAC2 disabled | | 07h | | | | 1 = DAC2 enabled | **Table 16 DAC Enable Control** # **DIGITAL VOLUME CONTROL** The WM8594 DACs include independent digital volume control, allowing the digital gain to be adjusted between -100dB and +12dB in 0.5dB steps. All four DAC channels can be controlled independently. Alternatively, global update bits allow the user to write all volume changes before the volume is updated. Volume control includes optional zero cross functionality. When zero cross is enabled, volume changes are not applied until the output level crosses VMID. Zero cross helps to prevent pop and click noise when changing volume settings. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|-----------|----------|-------------------------------------------------------| | R5 | 7:0 | DAC1L | 11001000 | DAC Digital Volume | | DAC1L_VOL | | _VOL[7:0] | | 0000 0000 = -100dB | | 05h | | | | 0000 0001 = -99.5dB | | R6 | 7:0 | DAC1R | | 0000 0010 = -99dB | | DAC1R_VOL | | _VOL[7:0] | | 0.5dB steps | | 06h | | | | 1100 1000 = 0dB | | R10 | 7:0 | DAC2L | | 0.5dB steps | | DAC2L_VOL | | _VOL[7:0] | | 1101 1111 = +11.5dB | | 0Ah | | | | 111X XXXX = +12dB | | R11 | 7:0 | DAC2R | | | | DAC2R_VOL | | _VOL[7:0] | | | | 0Bh | | | | | | R5 | 8 | DAC1L_VU | 0 | DAC Digital Volume Update | | DAC1L_VOL | | | | 0 = Latch DAC volume setting into Register | | 05h | | | | Map but do not update volume | | R6 | 8 | DAC1R_VU | | 1 = Latch DAC volume setting into Register | | DAC1R_VOL | | | | Map and update left and right channels simultaneously | | 06h | | | | Simulaticousty | | R10 | 8 | DAC2L_VU | | | | DAC2L_VOL | | | | | | 0Ah | | | | | | R11 | 8 | DAC2R_VU | | | | DAC2R_VOL | | | | | | 0Bh | | | | | | R2 | 7 | DAC1 | 1 | DAC Digital Volume Control Zero Cross | | DAC1_CTRL1 | | _ZCEN | | Enable | | 02h | | | | 0 = Do not use zero cross | | R7 | 7 | DAC2 | | 1 = Use zero cross | | DAC2_CTRL1 | | _ZCEN | | | | 07h | | | | | **Table 17 DAC Digital Volume Control** # SOFTMUTE A soft mute can be applied to DAC1 and DAC2 independently. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|-------|---------|----------------------| | R2 | 9 | DAC1_ | 0 | DAC Softmute | | DAC1_CTRL1 | | MUTE | | 0 = Normal operation | | 02h | | | | 1 = Softmute applied | | R7 | 9 | DAC2_ | 0 | | | DAC2_CTRL1 | | MUTE | | | | 07h | | | | | **Table 18 DAC Softmute Control** #### **DIGITAL MONOMIX CONTROL** Each DAC can be independently set to output a range of mono and stereo options. Each DAC output channel can output left channel data, right channel data or a mix of left and right channel data. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-------|-----------|---------|---------------------------------| | R2 | 11:10 | DAC1_OP | 00 | DAC1 Digital Monomix | | DAC1_CTRL1 | | _MUX[1:0] | | 00 = Stereo (Normal Operation) | | 02h | | | | 01 = Mono (Left data to DAC1R) | | | | | | 10 = Mono (Right data to DAC1L) | | | | | | 11 = Digital Monomix, (L+R)/2 | | R7 | 11:10 | DAC2_OP | 00 | DAC2 Digital Monomix | | DAC2_CTRL1 | | _MUX[1:0] | | 00 = Stereo (Normal Operation) | | 07h | | | | 01 = Mono (Left data to DAC2R) | | | | | | 10 = Mono (Right data to DAC2L) | | | | | | 11 = Digital Monomix, (L+R)/2 | **Table 19 Digital Monomix Control** #### **DE-EMPHASIS** A digital de-emphasis filter may be applied to the DAC outputs when the sampling frequency is 44.1kHz. The de-emphasis filter for each DAC can be applied independently. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------|---------|-------------------------------| | R2 | 6 | DAC1 | 0 | DAC1 De-emphasis | | DAC1_CTRL1 | | _DEEMPH | | 0 = No de-emphasis | | 02h | | | | 1 = Apply 44.1kHz de-emphasis | | R7 | 6 | DAC2 | 0 | DAC2 De-emphasis | | DAC2_CTRL1 | | _DEEMPH | | 0 = No de-emphasis | | 07h | | | | 1 = Apply 44.1kHz de-emphasis | **Table 20 De-emphasis Control** ### **CLOCK SWITCHING** The input clocks to the DAC (DACMCLK1, DACMCLK2, DACBCLK1, DACBCLK2, DACLRCLK1, DACLRCLK1, DACLRCLK2) can be switched between sources if the DACs are required to source data from multiple DSPs or application processors. Uncontrolled switching of clocks is not recommended as this can result in glitches being applied to the DACs. The WM8594 can be configured to ignore the clock inputs so that the clocks can be switched externally. This means that the WM8594 is not affected by any glitches that arise as a result of switching clocks. The DACs should be configured to ignore the input clocks for the duration of the period taken to switch the clocks. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------|---------|--------------------------------| | R38 | 0 | DAC1_ | 0 | DAC Clock Input Safe Switching | | DAC1_CLK | | SAFE_SW | | 0 = Ignore DAC clock inputs | | 26h | | | | 1 = Use DAC clock inputs | | R39 | 0 | DAC2_ | 0 | | | DAC2_CLK | | SAFE_SW | | | **Table 21 DAC Clock Switching Control** # **ADC FEATURES** The WM8594 features a stereo 24-bit sigma-delta ADC, digital volume control with zero cross, a selectable high pass filter to remove DC offsets, and support for both master and slave clocking modes. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|--------|---------|------------------| | R13 | 6 | ADC_EN | 0 | ADC Enable | | ADC_CTRL1 | | | | 0 = ADC disabled | | 0Dh | | | | 1 = ADC enabled | **Table 22 ADC Enable Control** #### **DIGITAL VOLUME CONTROL** The ADC digital volume can be adjusted between +30dB and -97dB in 0.5dB steps. Left and right channels can be controlled independently. Volume changes can be applied immediately to each channel, or volume changes can be written to both channels before writing to an update bit in order to change the volume in both channels simultaneously. Volume control includes optional zero cross functionality. When zero cross is enabled, volume changes are not applied until the output level crosses the DC level of the ADC output. Zero cross helps to prevent pop and click noise when changing volume settings. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|-----------|----------|----------------------------------------------------------| | R16 | 7:0 | ADCL | 11000011 | ADC Digital Volume | | ADCL_VOL | | _VOL[7:0] | | 0000 0000 = Digital mute | | 10h | | | | 0000 0001 = -97dB | | R17 | 7:0 | ADCR | 11000011 | 0000 0010 = -96.5dB | | ADCR_VOL | | _VOL[7:0] | | 0.5dB steps | | 11h | | | | 1100 0011 = 0dB | | | | | | 0.5dB steps | | | | | | 1111 1110 = +29.5dB | | | | | | 1111 1111 = +30dB | | R16 | 8 | ADCL_VU | 0 | ADC Digital Volume Update | | ADCL_VOL | | | | 0 = Latch ADC volume setting into Register | | 10h | | | | Map but do not update volume | | R17 | 8 | ADCR_VU | 0 | 1 = Latch ADC volume setting into Register | | ADCR_VOL | | | | Map and update left and right channels simultaneously | | 11h | | | | Simultaneously | | | | | | | | R13 | 13 | ADC_ZC_ | 1 | ADC Digital Volume Control Zero Cross | | ADC_CTRL1 | | EN | | Enable | | 0Dh | | | | 0 = Do not use zero cross, change volume instantly | | | | | | 1 = Use zero cross, change volume when data crosses zero | **Table 23 ADC Digital Volume Control** #### **CHANNEL SWAP AND INVERSION** The WM8594 ADC input channels can be inverted and swapped in a number of ways to provide maximum flexibility of input path to the ADC. The default configuration provides stereo output data with the left and right channel data in the left and right channels. It is possible to swap the left and right channels, invert them independently, or select the same data from both channels. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-------|----------|---------|------------------------------------------------| | R13 | 7 | ADC_ | 0 | ADC Left/Right Swap | | ADC_CTRL1 | | LRSWAP | | 0 = Normal | | 0Dh | | | | 1 = Swap left channel data into right channel | | | | | | and vice-versa | | | 8 | ADCR_ | 0 | ADCL and ADCR Output Signal Inversion | | | | INV | | 0 = Output not inverted | | | 9 | ADCL_ | 0 | 1 = Output inverted | | | | INV | | | | | 11:10 | ADC_ | 00 | ADC Data Output Select | | | | DATA_ | | 00 = left data from ADCL, right data from | | | | SEL[1:0] | | ADCR | | | | | | 01 = left data from ADCL, right data from ADCL | | | | | | 10 = left data from ADCR, right data from ADCR | | | | | | 11 = left data from ADCR, right data from ADCL | **Table 24 ADC Channel Swap Control** #### **HIGH PASS FILTER** The WM8594 includes a high pass filter to remove DC offsets. The high pass filter response is shown on page 73. It is possible to disable the high pass filter by writing to ADC\_HPD. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------|---------|-------------------------------| | R13 | 12 | ADC_HPD | 0 | ADC High Pass Filter Disable | | ADC_CTRL1 | | | | 0 = High pass filter enabled | | 0Dh | | | | 1 = High pass filter disabled | **Table 25 High Pass Filter Disable Control** #### **CLOCK SWITCHING** The input clocks to the ADC (ADCMCLK, ADCBCLK, ADCLRCLK) can be switched between sources if the ADC is used to supply data to multiple DSPs or application processors. Uncontrolled switching of clocks is not recommended as this may result in clock glitches being applied to the ADC. The WM8594 can be configured to ignore the clock inputs so that the clocks can be switched externally. This means that the WM8594 is not affected by any glitches that arise as a result of switching clocks. The ADC should be configured to ignore the input clocks for the duration of the period taken to switch the clocks. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------|---------|--------------------------------| | R37 | 0 | ADC_ | 0 | ADC Clock Input Safe Switching | | ADC_CLK | | SAFE_SW | | 0 = Ignore ADC Clock Inputs | | 25h | | | | 1 = Use ADC Clock Inputs | **Table 26 ADC Clock Switching Control** # **ANALOGUE ROUTING CONTROL** The WM8594 has a number of analogue paths, allowing flexible routing of a number of analogue input signals and DAC output signals at levels up to 2Vrms. The analogue paths include volume control with zero cross, optional soft ramp and soft mute, and flexible routing of analogue inputs and DAC outputs to analogue outputs. There are a total of ten (five stereo) analogue input channels and four (two stereo) DAC output channels. Two of the ten input channels can be routed to the ADC. Six of the 14 total channels can be routed to the analogue outputs. Figure 17 illustrates the various blocks of the analogue routing paths within the WM8594. The following sections describe the control bits associated with the WM8594 analogue paths. Figure 17 also shows where these control bits take affect on the WM8594. Figure 17 Analogue Routing Paths and Control #### **ANALOGUE VOLUME CONTROL** Each analogue bypass channel includes analogue volume control. Volume changes can be applied to each channel immediately as they are written. Alternatively, all volume changes can be written, and then all volume changes can be applied simultaneously using the volume update feature. Volume control includes optional zero cross functionality. When zero cross is enabled, volume changes are not applied until the output level crosses the DC level of the analogue channel (VMID). Zero cross helps to prevent pop and click noise when changing volume settings. The zero cross function includes a timeout which forces volume changes if a zero cross event does not occur. The timeout period is a maximum of 278ms. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|----------|----------|-----------------------------------------------------------------------------------| | R19 | 7:0 | PGA1L_ | 00001100 | Input PGA Volume | | PGA1L_VOL | | VOL[7:0] | | 0000 0000 = +6dB | | 13h | | ' ' | | 0000 0001 = +5.5dB | | R20 | 7:0 | PGA1R_ | | 0.5dB steps | | PGA1R_VOL | | VOL[7:0] | | 00001100 = 0dB | | 14h | | | | | | R21 | 7:0 | PGA2L_ | | 1001 1110 = -73.5dB | | PGA2L VOL | 7.0 | VOL[7:0] | | 1001 1111 = PGA Mute | | 15h | | VOL[7.0] | | | | R22 | 7:0 | PGA2R_ | | | | PGA2R_VOL | 7.0 | VOL[7:0] | | | | 16h | | VOL[7.0] | | | | R23 | 7:0 | PGA3L_ | | | | | 7.0 | | | | | PGA3L_VOL<br>17h | | VOL[7:0] | | | | R24 | 7.0 | DOAGD | | | | | 7:0 | PGA3R_ | | | | PGA3R_VOL | | VOL[7:0] | | | | 18h | | DO A 41 | 0 | hand BOA Valore Harles | | R19 | 8 | PGA1L_ | 0 | Input PGA Volume Update | | PGA1L_VOL | | VU | | 0 = Latch corresponding volume setting into Register Map but do not update volume | | 13h | | | | 1 = Latch corresponding volume setting | | R20 | 8 | PGA1R_ | | into Register Map and update all channels | | PGA1R_VOL | | VU | | simultaneously | | 14h | _ | | | | | R21 | 8 | PGA2L_ | | | | PGA2L_VOL | | VU | | | | 15h | | | | | | R22 | 8 | PGA2R_ | | | | PGA2R_VOL | | VU | | | | 16h | | | | | | R23 | 8 | PGA3L_ | | | | PGA3L_VOL | | VU | | | | 17h | | | | | | R24 | 8 | PGA3R_ | | | | PGA3R_VOL | | VU | | | | 18h | | | | | | R25 | 2 | PGA1L_ | 1 | PGA Gain Zero Cross Enable | | PGA_CTRL1 | | ZC | | 0 = PGA gain updates occur immediately | | 19h | 3 | PGA1R_ | | 1 = PGA gain updates occur on zero cross | | | | ZC | | | | | 4 | PGA1L_ | | | | | | ZC | | | | | 5 | PGA1R_ | | | | | | ZC | | | | | 6 | PGA1L_ | | | | | | ZC | | | | | 7 | PGA1R_ | | | | | | ZC | | | **Table 27 Analogue Volume Control** #### **VOLUME RAMP** Analogue volume can be adjusted by step change or by soft ramp. The ramp rate is dependent upon the sampling rate. The sampling rate upon which the volume ramp rate is based can be selected between the DAC sampling rate or the ADC sampling rate in either slave mode or master mode. The ramp rates for common audio sample rates are shown in Table 28: | SAMPLE RATE FOR PGA (kHz) | DIVIDE BY | PGA Ramp Rate (ms/dB) | |---------------------------|-----------|-----------------------| | 32 | 8 | 0.50 | | 44.1 | 8 | 0.36 | | 48 | 8 | 0.33 | | 88.2 | 16 | 0.36 | | 96 | 16 | 0.33 | | 176.4 | 32 | 0.36 | | 192 | 32 | 0.33 | **Table 28 Analogue Volume Ramp Rate** For example, when using a sample rate of 48kHz, the time taken for a volume change from and initial setting of 0dB to -20dB is calculated as follows: Volume Change (dB) x PGA Ramp Rate (ms/dB) = 20 x 0.33 = 6.6ms When changing from one PGA ramp clock source to another, it is recommended that PGA\_SAFE\_SW is set to 0. This forces the clock switch over to occur at a point where all relevant clock signals are zero, ensuring glitch-free operation. This process can take up to 32 left/right clock cycles. If a faster change in PGA ramp rate clock source is required, PGA\_SAFE\_SW can be set to 1. This forces the change in clock source to occur immediately regardless of the state of the relevant clock signals internally. Glitch-free operation is not guaranteed under these conditions. If the volume ramp function is not required when increasing or decreasing volume, this block can be bypassed by setting ATTACK\_BYPASS or DECAY\_BYPASS to 1. Figure 18 shows the effect of these register settings: Figure 18 ATTACK\_BYPASS and DECAY\_BYPASS functionality **Note**: When ATTACK\_BYPASS=1 or DECAY\_BYPASS=1, it is recommended that the zero cross function for the PGA is used to eliminate click noise when changing volume settings. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|-----------------|---------|------------------------------------------------------------------| | R25 | 0 | DECAY_ | 0 | PGA Gain Decay Mode | | PGA_CTRL1 | | BYPASS | | 0 = PGA gain will ramp down | | 19h | | | | 1 = PGA gain will step down | | | 1 | ATTACK_ | 0 | PGA Gain Attack Mode | | | | BYPASS | | 0 = PGA gain will ramp up | | | | | | 1 = PGA gain will step up | | R27 | 6:4 | PGA_ | 001 | Sample Rate for PGA | | ADD_CTRL1 | | SR[2:0] | | 000 = 32kHz | | 1Bh | | | | 001 = 44.1kHz | | | | | | 010 = 48kHz | | | | | | 011 = 88.2kHz | | | | | | 100 = 96kHz | | | | | | 101 = 176.4kHz | | | | | | 11X = 192kHz | | | | | | See Table 28 for further information on PGA | | | | | | sample rate versus volume ramp rate. | | R36<br>PGA_CTRL3 | 0 | PGA_<br>SAFE_SW | 0 | PGA Ramp Control Clock Source Mux Force Update | | 24h | | | | 0 = Wait until clocks are safe before switching PGA clock source | | | | | | 1 = Force PGA clock source to change immediately | | | 3:1 | PGA_ | 000 | PGA Ramp Control Clock Source | | | | SEL[2:0] | | 000 = ADCLRCLK | | | | | | 001 = DACLRCLK1 | | | | | | 010 = DACLRCLK2 | | | | | | 011 = reserved | | | | | | 100 = reserved | | | | | | 101 = DACLRCLK1 (when DAC1 is being | | | | | | used in master mode) | | | | | | 110 = DACLRCLK2 (when DAC2 is being | | | | | | used in master mode) | | | | | | 111 = ADCLRCLK (when ADC is being used in master mode) | | | 10 | PGA_UPD | 0 | PGA Ramp Control Clock Source Mux | | | | | | Update | | | | | | 0 = Do not update PGA clock source | | | | | | 1 = Update clock source | **Table 29 Analogue Volume Ramp Control** # **ANALOGUE MUTE CONTROL** The analogue channel PGAs can be muted independently and are muted by default. Alternatively, all mute bits can be set using a master mute bit, $MUTE\_ALL$ . | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------|---------|-----------------------------| | R26 | 0 | MUTE_ | 0 | Master PGA Mute Control | | PGA_CTRL2 | | ALL | | 0 = Unmute all PGAs | | 1Ah | | | | 1 = Mute all PGAs | | | 1 | VOUT1L_ | 1 | Individual PGA Mute Control | | | | MUTE | | 0 = Unmute PGA | | | 2 | VOUT1R_ | 1 | 1 = Mute PGA | | | | MUTE | | | | | 3 | VOUT2L_ | 1 | | | | | MUTE | | | | | 4 | VOUT2R_ | 1 | | | | | MUTE | | | | | 5 | VOUT3L_ | 1 | | | | | MUTE | | | | | 6 | VOUT3R_ | 1 | | | | | MUTE | | | **Table 30 Analogue Mute Control** WM8594 ### **INPUT SELECTOR CONTROL** Each left channel input PGA can select between all left channel analogue inputs, and both left and right DAC inputs. Each right channel input PGA can select between all right channel analogue inputs, and both left and right DAC inputs. All PGAs can be enabled and disabled independently. Note: It is recommended to mute the PGA before changing the input to the PGA to avoid pop/click noises when selecting a different input source. **Figure 19 Input Selector Control** | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|------|----------|---------|----------------------------------| | R28 | 3:0 | PGA1L_ | 0000 | Left Input PGA Source Selection | | INPUT_CTRL1 | | IN_ | | 0000 = No input selected | | 1Ch | | SEL[3:0] | | 0001 = VIN1L selected | | | 11:8 | PGA2L_ | 0000 | 0010 = VIN2L selected | | | | IN_ | | 0011 = VIN3L selected | | | | SEL[3:0] | | 0100 = VIN4L selected | | R29 | 7:4 | PGA3L_ | 0000 | 0101 = VIN5L selected | | INPUT_CTRL2 | | IN_ | | 0110 to 1000 = reserved | | 1Dh | | SEL[3:0] | | 1001 = DAC1L output selected | | | | | | 1010 = DAC1R output selected | | | | | | 1011 = DAC2L output selected | | | | | | 1100 = DAC2R output selected | | | | | | 1101 to 1111 = reserved | | R28 | 7:4 | PGA1R_ | 0000 | Right Input PGA Source Selection | | INPUT_CTRL1 | | IN_ | | 0000 = No input selected | | 1Ch | | SEL[3:0] | | 0001 = VIN1R selected | | R29 | 3:0 | PGA2R_ | 0000 | 0010 = VIN2R selected | | INPUT_CTRL2 | | IN_ | | 0011 = VIN3R selected | | 1Dh | | SEL[3:0] | | 0100 = VIN4R selected | | | 11:8 | PGA3R_ | 0000 | 0101 = VIN5R selected | | | | IN_ | | 0110 to 1000 = reserved | | | | SEL[3:0] | | 1001 = DAC1L output selected | | | | | | 1010 = DAC1R output selected | | | | | | 1011 = DAC2L output selected | | | | | | 1100 = DAC2R output selected | | | | | | 1101 to 1111 = reserved | | R31 | 0 | PGA1L_ | 0 | Input PGA Enable Controls | | INPUT_CTRL4 | | EN | | 0 = PGA disabled | | 1Fh | 1 | PGA1R_ | | 1 = PGA enabled | | | | EN | | | | | 2 | PGA2L_ | | | | | | EN | | | | | 3 | PGA2R_ | | | | | | EN | | | | | 4 | PGA3L_ | | | | | | EN | | | | | 5 | PGA3R_ | | | | | | EN _ | | | Table 31 PGA Input Select Control ### **ADC INPUT SELECTOR CONTROL** The ADC input switch can be configured to allow any combination of two inputs to be input to the ADC. Each input switch channel can be controlled independently. The input switch also includes PGAs to provide a range of analogue gain settings between -6dB and +6dB prior to the ADC. These PGAs can be enabled and disabled independently. Figure 20 ADC Input Selector Control | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|-----------|---------|-------------------------------------| | R30 | 3:0 | ADCL_ | 0000 | ADC Input Select | | INPUT_CTRL3 | | SEL[3:0] | | 0000 = VIN1L | | 1Eh | 7:4 | ADCR_ | 0000 | 0001 = VIN2L | | | | SEL[4:0] | | 0010 = VIN3L | | | | | | 0011 = VIN4L | | | | | | 0100 = VIN5L | | | | | | 0101 to 1000 = reserved | | | | | | 1000 = VIN1R | | | | | | 1001 = VIN2R | | | | | | 1010 = VIN3R | | | | | | 1011 = VIN4R | | | | | | 1100 = VIN5R | | | | | | 1101 to 1111 = reserved | | | 9:8 | ADC_AMP | 10 | ADC Amplifier Gain Control | | | | _VOL[1:0] | | 00 = 0dB | | | | | | 01 = +3dB | | | | | | 10 = +6dB | | | | | | 11 = +12dB | | | 10 | ADC_ | 0 | ADC Input Switch Control | | | | SWITCH_ | | 0 = ADC input switches open | | | | EN | | 1 = ADC input switches closed | | R31 | 6 | ADCL_ | 0 | ADC Input Amplifier Enable Controls | | INPUT_CTRL4 | | AMP_EN | | 0 = Amplifier disabled | | 1Fh | 7 | ADCR_ | 0 | 1 = Amplifier enabled | | | | AMP_EN | | | **Table 32 ADC Input Switch Control** ### **OUTPUT SELECTOR CONTROL** Any analogue PGA channel can be routed to any analogue output. All analogue outputs can be independently enabled and disabled. Additionally, all outputs can be tri-stated to allow the output to be connected to applications where ports can either be inputs or outputs. Note: It is recommended to mute all the outputs before changing the output selector to avoid pop/click noises when selecting a different output source. **Figure 21 Output Selector Control** | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | |---------------------|-----|---------------------|---------|--------------------------------------------------------| | R32<br>OUTPUT_ | 2:0 | VOUT1L_<br>SEL[2:0] | 000 | Output Mux Selection<br>000 = PGA1L | | CTRL1 | 5:3 | VOUT1R_<br>SEL[2:0] | 001 | 001 = PGA1R<br>010 = PGA2L | | | 8:6 | VOUT2L_<br>SEL[2:0] | 010 | 011 = PGA2R<br>100 = PGA3L | | R33<br>OUTPUT_ | 2:0 | VOUT2R_<br>SEL[2:0] | 011 | 100 = 1 GASE<br>101 = PGA3R<br>- 11X = Reserved | | CTRL2<br>21h | 5:3 | VOUT3L_<br>SEL[2:0] | 100 | TIX = Reserved | | | 8:6 | VOUT3R_<br>SEL[2:0] | 101 | | | R34<br>OUTPUT_ | 0 | VOUT1L_<br>TRI | 0 | Output Amplifier Tristate Control 0 = Normal operation | | CTRL3<br>22h | 1 | VOUT1R_<br>TRI | | 1 = Output amplifier tristate enable (Hi-Z) | | | 2 | VOUT2L_<br>TRI | | | | | 3 | VOUT1R_<br>TRI | | | | | 4 | VOUT3L_<br>TRI | | | | | 5 | VOUT3R_<br>TRI | | | | | 7 | VOUT1L_<br>EN | 0 | Output Amplifier Enables 0 = Output amplifier disabled | | | 8 | VOUT1R_<br>EN | | 1 = Output amplifier enabled | | | 9 | VOUT2L_<br>EN | | | | | 10 | VOUT2R_<br>EN | | | | | 11 | VOUT3L_<br>EN | | | | | 12 | VOUT3R_<br>EN | | | **Table 33 Output Selection** #### POP AND CLICK PERFORMANCE The WM8594 includes a number of features designed to minimise pops and clicks in various phases of operation including power up, power down, changing analogue paths and starting/stopping clocks. In order to ensure optimum performance, the following sequences should be followed. #### **POWERUP SEQUENCE** - 1. Apply power to the WM8594 (see Power On Reset). - 2. Set-up initial internal biases: - SOFT\_ST=1 - FAST\_EN=1 - POBCTRL=1 - Enable output drivers to allow the AC coupling capacitors at the output stage to be precharged to DACVMID: - VOUTxL\_EN=1 - VOUTxR\_EN=1 - 4. Enable DACVMID. $500k\Omega$ selected here for optimum pop reduction: - VMID\_SEL=10 - 5. Wait until DACVMID has fully charged. The time is dependent on the capacitor values used to AC-couple the outputs and to decouple DACVMID, and the VMID\_SEL value chosen. An approximate delay of 6xRCms can be used, where R is the DACVMID resistance and C is the decoupling capacitor on DACVMID. For DACVMID resistance of $50k\Omega$ and C=4.7uF, the delay should be approximately 1.5 seconds. - Insert delay - 6. Enable the master bias and DACVMID buffer: - BIAS\_EN=1 - BUFIO EN=1 - 7. Switch the output drivers to use the master bias instead of the power up (fast) bias: - POBCTRL=0 - 8. Enable all functions (DACs, ADC, PGAs) required for use. Outputs are muted by default so the write order is not important. - 9. Unmute the outputs and switch DACVMID resistance to 50k for normal operation: - VOUTxL\_MUTE=0 - VOUTxR MUTE=0 - VMID\_SEL=01 #### **POWERDOWN SEQUENCE** - Mute all outputs: - MUTE\_ALL=1 - 2. Set up biases for power down mode: - FAST\_EN=1 - VMID\_SEL=01 - BIAS\_EN=1 WM8594 - BUFIO\_EN=1 - VMIDTOG=1 - SOFT\_ST=0 - 3. Switch outputs to use fast bias instead of master bias: - POBCTRL=1 - Power down all WM8594 functions (ADC, DACs, PGAs etc.). The outputs are muted so the write order is not important. - Power down VMID to allow the analogue outputs to ramp gently to ground in a pop-free manner. - VMID\_SEL=00 - 6. Wait until DACVMID has fully discharged. The time taken depends on system capacitance. - Insert delay - 7. Clamp outputs to ground. - APE\_B=0 - 8. Power down outputs. - VOUTxL\_EN=0 - VOUTxR\_EN=0 - 9. Disable remaining bias control bits. - FAST\_EN=0 - POBCTRL=0 - BIAS\_EN=0 Power supplies can now be safely removed from the WM8594 if desired. Table 34 describes the various bias control bits for power up/down control. | REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION | | | |---------------------|-----|-------------------|---------|--------------------------------------------------------------------------------------------------------------------------------|--|--| | R35 | 0 | POBCTRL | 0 | Bias Source for Output Amplifiers | | | | BIAS | | | | 0 = Output amplifiers use master bias | | | | 23h | | | | 1 = Output amplifiers use fast bias | | | | | 1 | VMIDTOG | 0 | VMID Power Down Characteristic | | | | | | | | 0 = Slow ramp | | | | | | | | 1 = Fast ramp | | | | | 2 | FAST_EN | 0 | Fast Bias Enable | | | | | | | | 0 = Fast bias disabled | | | | | | | | 1 = Fast bias enabled | | | | | 3 | BUFIO_ | 0 | VMID Buffer Enable | | | | | | EN | | 0 = VMID Buffer disabled | | | | | | | | 1 = VMID Buffer enabled | | | | | 4 | SOFT_ST | 1 | VMID Soft Ramp Enable | | | | | | | | 0 = Soft ramp disabled | | | | | | | | 1 = Soft ramp enabled | | | | | 5 | BIAS_EN | 0 | Master Bias Enable | | | | | | | | 0 = Master bias disabled | | | | | | | | 1 = Master bias enabled | | | | | | | | Also powers down ADCVMID | | | | | 7:6 | VMID_<br>SEL[1:0] | 00 | VMID Resistor String Value Selection (DACVMID only) | | | | | | 022[1.0] | | 00 = off (no VMID) | | | | | | | | 01 = 100kΩ | | | | | | | | 10 = 500kΩ | | | | | | | | 11 = 10kΩ | | | | | | | | The selection is the total resistance of the string from DACREFP to DACREFN. The ADCVMID resistance is fixed at $200k\Omega$ . | | | **Table 34 Bias Control** # REGISTER MAP | | PGA SAFE SW | | PGA SELIZO | | 0 | 0 | 0 | 0 | 0 | 0 | PGA LIPD | 0 | 0 | 0 | 0 | o | PGA CTRL 3 | 24 | :3<br>36 | |-------------|---------------------------|-------------------|-------------|--------------|-------------------|---------------|-------------|-------------------------------------|--------------------|-------------------|------------------|-----------|-----------|-----------|----|----|--------------|------------------------|----------------| | 0x0010 | POBCTRL | VMIDTOG | FAST_EN | BUFICEN | SOFT_ST | BIAS_EN | SEL[1:0] | VMID | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | BIAS | 23 | 35 | | 0x0040 | VOUT1_TRI | VOUTR_TRI | VOUT2L_TRI | VOUT2R_TRI | VOUT3L_TRI | VOUT3R_TRI | APE_B | VOUT1_EN | VOUT R_EN | VOUT2L_EN | VOUT2R_EN | VOUT3L_EN | VOUT3R_EN | 0 | 0 | 0 | OUTPUT_CTRL3 | 22 | 34 | | 0x0163 | | VOUT2R_SEL[2:0] | | | VOUT3L_SEL[2:0] | | | VOUT3R_SEL[2:0] | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | OUTPUT_CTRL2 | 21 | 33 | | 0x0088 | | VOUT1L_SEU[2:0] | | | VOUTR_SEL[2:0] | | | VOUT2L_SE([2:0] | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | OUTPUT_CTRL1 | 20 | 32 | | 0x0000 | PGA1_EN | PGA1R_EN | PGA2L_EN | PGA2R_EN | PGA3L_EN | PGA3R_EN | ADCL_AMP_EN | ADCR_AMP_EN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | INPUT_CTRL4 | Ŧ | 31 | | 0x0008 | | ADCL_SEL[3:0] | ADCL | | | ADCR_SEL[3:0] | ADCR | | ADC_AMP_VOL[10] | | ADC_SWITCH_EN | 0 | 0 | 0 | 0 | 0 | INPUT_CTRL3 | m) | 30 | | 0x0000 | | PGA2R_IN_SEL[3:0] | PGA2R_I | | | N_SEL[3:0] | PGA3L_IN | | | PGA3R_IN_SEL[3:0] | PGA3R | | 0 | 0 | 0 | 0 | INPUT_CTRL2 | Ð | 29 | | 0x0000 | | PGA 1_IN_SEL[3:0] | PGA1_I | | | N_SEL[3:0] | PGA1R_IN | | | PGA2L_IN_SEL[3:0] | PGA2L_ | | 0 | 0 | 0 | 0 | INPUT_CTRL1 | ð | 28 | | 0x0048 | 0 | 0 | 0 | AUTO_INC | | PGA_SR[20] | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | GEN | в | 27 | | 0x007E | MUTE_ALL | VOUT1_MUTE | VOUT1R_MUTE | VOUT2L_MUTE | VOUT2R_MUTE | VOUT3L_MUTE | VOUT3R_MUTE | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PGA_CTRL2 | 15 | 26 | | 0x00FC | ATTACK_BYPASSDECAY_BYPASS | ATTACK_BYPASS | PGA1_ZC | PGA R_ZC | PGA2L_ZC | PGA2R_ZC | PGA3L_ZC | PGA3R_ZC | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PGA_CTRL1 | e) | 25 | | 0x000C | | | | (0:2)OV | PGA3R_VOU7.0] | | | | PGA3R_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PGA3R_VOL | D) | 24 | | 0x000C | | | | VOL[7:0] | PGA3L_VOL[7:0] | | | | PGA3L_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PG3L_VOL | 77 | 23 | | 0x000C | | | | VOL7:0] | PGA2R_VOL7:0] | | | | PGA2R_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PGA2R_VOL | ď | 22 | | 0x000C | | | | VOL[7:0] | PGA2L_VOL[7:0] | | | | PGA2L_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PGA2L_VOL | ъħ | 21 | | 0x000C | | | | VOL[7:0] | PGA R_VOL[7:0] | | | | PGA R_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PGA1R_VOL | ź | 20 | | 0x000C | | | | VOL[7:0] | PGA1_VOL[7:0] | | | | PGA1_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PGA1L_VOL | 3 | 79 | | 0x00C3 | | | | /OL[7:0] | ADCR_VOL[7:0] | | | | ADCR_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ADCR_VOL | <b>±</b> | 17 | | 0x00C3 | | | | /OL[7:0] | ADCL_VOL[7:0] | | | | ADCL_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ADCL_VOL | ð | ਲੇ | | 0x0000 | ADC_MSTR | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ADC_CTRL3 | 유 | ਲੇ | | 0x0000 | | ADC_SR[20] | | | ADC_BCLKDN[2:0] | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ADC_CTRL2 | OE | 4 | | 0×200A | ADC_FMT[to] | ADC_F | WL[10] | ADC_WL[10] | ADC_BCP | ADC_URP | ADC_EN | ADC_LRSWAP | ADCR_INV | ADCL_INV | ADC_DATA_SEL[10] | ADC_DAT | ADC_HPD | ADC_ZC_EN | 0 | 0 | ADC_CTRL1 | 8 | 13 | | 0x0000 | GLOBAL_EN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ENABLE | 8 | 13 | | 0x00C8 | | | | VOU7:0] | DAC2R_VOU7:0] | | | | DAC2R_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC2R_VOL | 08 | 1 | | 0x00C8 | | | | (0.2)JOV | DAC2L_VOL[7:0] | | | | DACZ_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC2L_VOL | 9A | 10 | | 0x0000 | DAC2_MSTR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC2_CTRL3 | 09 | 9 | | 0x0000 | | DAC2_SR[2:0] | | | DAC2_BCLKDIV[2:0] | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC2_CTRL2 | 08 | 80 | | 0x008A | DAC2_FMT[t0] | DAC2 | WL[1:0] | DA C2_WL[10] | DAC2_BCP | DAC2_LRP | DAC2_DEEMPH | DAC2_ZCEN | DAC2_EN | DAC2_MUTE | DAC2_OP_MUX[1:0] | DAC2_OF | 0 | 0 | 0 | 0 | DAC2_CTRL1 | 07 | 7 | | 0x00C8 | | | | VOL[7:0] | DAC-R_VOL[7:0] | | | | DAC R_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC1R_VOL | 06 | 6 | | 0x00C8 | | | | VOL[7:0] | DAC1_VOL[7:0] | | | | DAC1_VU | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC1L_VOL | 05 | c <sub>1</sub> | | 0x0000 | DAC1_MSTR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC1_CTRL3 | 04 | 4 | | 0x0000 | | DAC1_SR[2:0] | | | DAC1_BCLKDIV[2:0] | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC1_CTRL2 | 03 | s | | 0x008A | DAC1_FMT[10] | DAC1 | WL 10] | DAC1_WL(10] | DAC1_BCP | DAC1_LRP | DAC1_DEEMPH | DAC1_ZCEN | DAC1_EN | DAC1MUTE | DAC1_OP_MUX[1:0] | DAC1_OF | 0 | 0 | 0 | 0 | DAC1_CTRL1 | 02 | 2 | | 0x0000 | | | | M[7:0] | REVNUM[7:0] | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | REVISION | 01 | _ | | 0x8594 | | | | | | | i H | Read:DEVICE_ID[15:0] / Write:SW_RST | Read: DEVICE_ID[16 | 7 | | | | | | | DEVICE_ID | 00 | 0 | | Hex Default | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | ਲੇ | Name | Dec Addr Hex Addr Name | Dec Add | | R0 (0h) - | Software Re | set / Device ID | Register (DEV | ICE_ID) | | | | | | | |-----------|-------------|------------------------------------------------|-------------------|------------------|------------------|---------|---|---|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | | | | DEVICE | _ID[15:8] | | | | | | | Write | | | | SW_ | RST | | | | | | | Default | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | | | | DEVICE | _ID[7:0] | | | | | | | Write | | | | SW_ | RST | | | | | | | Default | 1 | 0 0 1 0 1 0 0 | | | | | | | | | | | | N/A = Not Applicable (no function implemented) | | | | | | | | | | Fu | nction | | | | Description | | | | | | | DEVIC | CEID[15:0] | Device ID | | | | | | | | | | | | A read of this | register will ret | urn the device | ID. In this case | 0x8594. | | | | | | SW | /_RST | Software Res | set | | | | | | | | | | | A write of any | value to this re | gister will gene | rate a software | reset. | | | | | Figure 22 R0 – Software Reset / Device ID | R1 (01h) - | - Device Revi | sion Register ( | REVISION) | | | | | | | |------------|---------------|-----------------|-----------|-------|-----------------|----------------|------------------|---------------|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Write | N/A | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | - | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Read | | | | REVNU | JM[7:0] | | | | | | Write | N/A | N/A | | | | | | | | | Default | - | | | | | | | | | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | | Fui | nction | | | | Description | | | | | | REVI | NUM[7:0] | | | | revision number | r. This number | s sequentially i | ncremented if | | Figure 23 R1 – Device Revision Register | R2 (02h) - | - DAC Contro | I Register 1 (D. | AC1_CTRL1) | | | | | | | |------------------|--------------|----------------------------------------------------------------|-------------------|-------------------|-----------------|----------------------------------------|------------------|--------------|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | Read | 0 | 0 | 0 | 0 | D. C. C. | | 5464= | DAG: -:: | | | Write | N/A | N/A | N/A | N/A | DAC1_OP | _MUX[1:0] | DAC1_MUTE | DAC1_EN | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | 1 | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Read | DAG4 705N | DAC1_ | 5464 155 | 5404 505 | 5464 | \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 5404.5 | | | | Write | DAC1_ZCEN | DEEMPH | DAC1_LRP | DAC1_BCP | DAC1_ | WL[1:0] | DAC1_F | M1[1:0] | | | Default | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | | | | | | | | N/A | A = Not Applica | ble (no function | implemented) | | | Fu | nction | | | | Description | | | | | | DAC1_ | _FMT[1:0] | DAC1 Audio | Interface Forn | nat | | | | | | | | | 00 = Right Jus | stified | | | | | | | | | | 01 = Left Just | ified | | | | | | | | | | $10 = I^2S$ | | | | | | | | | | | 11 = DSP | | | | | | | | | DAC1 | _WL[1:0] | DAC1 Audio | Interface Wor | d Length | | | | | | | | | 00 = 16-bit | | | | | | | | | | | 01 = 20-bit | | | | | | | | | | | 10 = 24-bit | | | | | | | | | | | 11 = 32-bit (no | ot available in F | Right Justified m | node) | | | | | | DAC | 1_BCP | DAC1 BCLK Polarity | | | | | | | | | | | 0 = DACBCLK not inverted - data latched on rising edge of BCLK | | | | | | | | | | | 1 = DACBCLF | Cinverted - dat | a latched on fall | ling edge of BC | CLK | | | | | DAC | C1_LRP | DAC1 LRCL | ( Polarity | | | | | | | | | | | _K not inverted | | | | | | | | | | 1 = DACLRCI | _K inverted | | | | | | | | DAC1_ | _DEEMPH | DAC1 Deemp | ohasis | | | | | | | | | | 0 = No deemp | ohasis | | | | | | | | | | | 1kHz deempha | | | | | | | | DAC <sup>2</sup> | 1_ZCEN | | | rol Zero Cross | Enable | | | | | | | | 0 = Do not us | e zero cross | | | | | | | | | | 1 = Use zero | | | | | | | | | DAG | C1_EN | DAC1 Enable | | | | | | | | | | | 0 = DAC disal | | | | | | | | | | | 1 = DAC enab | | | | | | | | | DAC | 1_MUTE | DAC1 Softmu | | | | | | | | | | | 0 = Normal op | | | | | | | | | | | 1 = Softmute | • • | | | | | | | | DAC1_O | P_MUX[1:0] | DAC1 Digital | | | | | | | | | | | , | Normal Operati | • | | | | | | | | | , | eft data to DAC | • | | | | | | | | | | ight data to DA | | | | | | | | | | 11 = Digital M | lonomix, (L+R) | 2 | | | | | | Figure 24 R2 – DAC1 Control Register 1 | R3 (03h) - | - DAC1 Cont | rol Register 2 (I | DAC1_CTRL2) | | | | | | |------------|-------------------|-------------------|---------------|-----------------|-------------|------------------|------------------|--------------| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Write | N/A | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | <del></del> | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Read | 0 | 0 | DA | C1_BCLKDIV[ | 2.01 | | DAC1 | | | Write | N/A | N/A | DA | C I_BCLKDIV[ | 2.0] | | DAC1_SR[2:0] | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | N// | A = Not Applicat | ole (no function | implemented) | | Fui | nction | | | | Description | | | | | DAC1 | _SR[2:0] | DAC1 MCLK | LRCLK Ratio | | | | | | | | 000 = Auto detect | | | | | | | | | | | 001 = 128fs | | | | | | | | | | 010 = 192fs | | | | | | | | | | 011 = 256fs | | | | | | | | | | 100 = 384fs | | | | | | | | | | 101 = 512fs | | | | | | | | | | 110 = 768fs | | | | | | | | | | 111 = 1152fs | | | | | | | | D. | AC1_ | DAC1 BCLK | Rate | | | | | | | ВС | LKDIV | 000 = MCLK / | 4 | | | | | | | I | [2:0] | 001 = MCLK / | 8 | | | | | | | | | 010 = 32 fs | | | | | | | | | | 011 = 64fs | | | | | | | | | | 100 = 128fs | | | | | | | | | | All other value | es of DAC1_BC | CLKDIV[2:0] are | ereserved | | | | Figure 25 R3 – DAC1 Control Register 2 | R4 (04h) - | - DAC1 Contro | ol Register 3 (I | DAC1_CTRL3) | | | | | | | | | |------------|---------------|------------------|-------------------------|--------------|-----------------|----------------|-----------------|--------------|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Write | N/A | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC1 MSTR | | | | | Write | N/A | N/A | N/A N/A N/A N/A N/A N/A | | | | | | | | | | Default | 0 | 0 | 0 0 0 0 0 0 | | | | | | | | | | | | | | | N/A | = Not Applicab | le (no function | implemented) | | | | | Fui | nction | | | | Description | | | | | | | | DAC. | 1_MSTR | DAC1 Master | Mode Select | | | | | | | | | | | | 0 = Slave mod | de, DACBCLK1 | and DACLRCI | K1 are inputs t | o WM8594 | | | | | | | | | 1 = Master mo | ode, DACBCLK | 1 and DACLRO | CLK1 are output | s from WM859 | 4 | | | | | Figure 26 R4 – DAC1 Control Register 3 | R5 (05h) | - DAC1L Digit | tal Volume Cor | ntrol Register ( | (DAC1L_VOL) | | | | | | | |----------|---------------------|----------------|------------------|-----------------|------------------|------------------|-----------------|----------------|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC4L VIII | | | | Write | N/A DAC1L_VU | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | 1 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | | | | DAC1L_ | VOI [7:0] | | | | | | | Write | | | | DACIL_ | VOL[7.0] | | | | | | | Default | 1 | 1 1 0 0 1 0 0 | | | | | | | | | | | | | | | N/A | \ = Not Applical | ole (no functio | n implemented) | | | | Fu | nction | | | | Description | | | | | | | DAC1L | _VOL[7:0] | DAC1L Digita | al Volume | | | | | | | | | | | 0000 0000 = | -100dB | | | | | | | | | | | 0000 0001 = | -99.5dB | | | | | | | | | | | 0000 0010 = | -99dB | | | | | | | | | | | 0.5dB steps | 3 | | | | | | | | | | | 1100 1000 = | OdB | | | | | | | | | | | 0.5dB steps | 5 | | | | | | | | | | 1101 1111 = +11.5dB | | | | | | | | | | | | | 111X XXXX = | +12dB | | | | | | | | | DAC | C1L_VU | DAC1L Digita | al Volume Upd | late | | | | | | | | | | 0 = Latch DA | C1L_VOL[7:0] i | nto Register Ma | ap but do not up | odate volume | | | | | | | | 1 = Latch DA | C1L_VOL[7:0] i | nto Register Ma | ap and update I | eft and right ch | annels simulta | aneously | | | Figure 27 R5 – DAC1L Digital Volume Control Register | · , | | ital Volume Co | , <u> </u> | <u> </u> | | 10 | | | | | | |--------------------------------------------------------------------|---------------------|---------------------------------------------------------------------------------------------|--------------|----------|-------------|------------------|-----------------|-----------------|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC1R VU | | | | | Write | N/A B/(OII(_VO | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | | | | DAC4B | \/OL[7:0] | | | | | | | | Write | | | | DACTR_ | VOL[7:0] | | | | | | | | Default | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | | | | | | | | | | N/A | A = Not Applicat | ole (no functio | on implemented) | | | | | Fui | nction | | | | Description | | | | | | | | DAC1R | _VOL[7:0] | DAC1R Digit | al Volume | | | | | | | | | | | | 0000 0000 = | -100dB | | | | | | | | | | | | 0000 0001 = | -99.5dB | | | | | | | | | | | | 0000 0010 = | -99dB | | | | | | | | | | | | 0.5dB step | S | | | | | | | | | | | | 1100 1000 = | 0dB | | | | | | | | | | | | 0.5dB step | S | | | | | | | | | | | 1101 1111 = +11.5dB | | | | | | | | | | | | | 111X XXXX = +12dB | | | | | | | | | | | | DAC | 1R_VU | DAC1R Digit | al Volume Up | date | | | | | | | | | 0 = Latch DACR_VOL[7:0] into Register Map but do not update volume | | | | | | | | | | | | | | | 1 = Latch DACR_VOL[7:0] into Register Map and update left and right channels simultaneously | | | | | | | | | | Figure 28 R6 – DAC1R Digital Volume Control Register | R7 (07h) - | - DAC2 Contro | ol Register 1 ([ | DAC2_CTRL1) | | | | | | | | | |-------------------------|---------------|------------------------------------------------|-------------------|-------------------|-----------------|-----------------------------------------|-----------|---------------------------------------|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | | | | | | | | | Write | N/A | N/A | N/A | N/A | DAC2_OF | P_MUX[1:0] | DAC2_MUTE | DAC2_EN | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | 1 | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read<br>Write | DAC2_ZCEN | DAC2_<br>DEEMPH | DAC2_LRP | DAC2_BCP | DAC2_ | _WL[1:0] | DAC2_F | MT[1:0] | | | | | Default | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | | | | | | | N/A = Not Applicable (no function implemented) | | | | | | | | | | | Fui | nction | | | | Description | • • • • • • • • • • • • • • • • • • • • | , | · · · · · · · · · · · · · · · · · · · | | | | | DAC2_ | _FMT[1:0] | DAC2 Audio | Interface Forn | nat | - | | | | | | | | | | 00 = Right Jus | stified | | | | | | | | | | | | 01 = Left Just | | | | | | | | | | | | | $10 = I^2S$ | | | | | | | | | | | | | 11 = DSP | | | | | | | | | | | DAC2 | _WL[1:0] | DAC2 Audio | Interface Word | d Length | | | | | | | | | 00 = 16-bit | | | | | | | | | | | | | 01 = 20-bit | | | | | | | | | | | | | | | 10 = 24-bit | | | | | | | | | | | | | 11 = 32-bit (no | ot available in F | Right Justified n | node) | | | | | | | | DAC | 2_BCP | DAC2 BCLK | Polarity | | | | | | | | | | | | 0 = DACBCLF | Cnot inverted - | data latched or | n rising edge o | f BCLK | | | | | | | | | 1 = DACBCL | Cinverted - dat | a latched on fal | ling edge of Bo | CLK | | | | | | | DAC | 2_LRP | DAC2 LRCL | Polarity | | | | | | | | | | | | 0 = DACLRCLK not inverted | | | | | | | | | | | | | 1 = DACLRCLK inverted | | | | | | | | | | | DAC2_ | _DEEMPH | DAC2 Deemp | hasis | | | | | | | | | | | | 0 = No deemphasis | | | | | | | | | | | | | 1 = Apply 44.1kHz de-emphasis | | | | | | | | | | | DAC | 2_ZCEN | _ | | rol Zero Cross | Enable | | | | | | | | | | 0 = Do not us | e zero cross | | | | | | | | | | | | 1 = Use zero | cross | | | | | | | | | | DAG | C2_EN | DAC2 Enable | | | | | | | | | | | | | 0 = DAC2 disa | | | | | | | | | | | | | 1 = DAC2 ena | | | | | | | | | | | DAC2_MUTE DAC2 Softmute | | | | | | | | | | | | | | | 0 = Normal op | | | | | | | | | | | D | B 1410/2: 51 | 1 = Softmute | | | | | | | | | | | DAC2_O | P_MUX[1:0] | DAC2 Digital | | > | | | | | | | | | | | 00 = Stereo (Normal Operation) | | | | | | | | | | | | | 01 = Mono (Left data to Right DAC2) | | | | | | | | | | | | | | ight data to Let | | | | | | | | | | | | i i = Digital M | onomix, (L+R) | 2 | | | | | | | | Figure 29 R7 – DAC2 Control Register 1 | R8 (08h) - | - DAC2 Cont | rol Register 2 (I | DAC2_CTRL2 | ) | | | | | | | | | |------------|-------------|--------------------------------|----------------|-----------------|-------------|------------------|------------------|--------------|--|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Write | N/A | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit# | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | Read | 0 | 0 | D | VC3 BCI KDI/\(I | 2:01 | | DAC2_SR[2:0] | | | | | | | Write | N/A | DAC2_BCLKDIV[2:0] DAC2_SR[2:0] | | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | N/A | A = Not Applicat | ble (no function | implemented) | | | | | | Fur | nction | | | | Description | | | | | | | | | DAC2 | _SR[2:0] | DAC2 MCLK: | LRCLK Ratio | • | | | | | | | | | | | | 000 = Auto de | etect | | | | | | | | | | | | | 001 = 128fs | | | | | | | | | | | | | | 010 = 192fs | | | | | | | | | | | | | | 011 = 256fs | | | | | | | | | | | | | | 100 = 384fs | | | | | | | | | | | | | | 101 = 512fs | 101 = 512fs | | | | | | | | | | | | | 110 = 768fs | | | | | | | | | | | | | | 111 = 1152fs | | | | | | | | | | | | | | DAC2 BCLK | Rate | | | | | | | | | | | | | 000 = MCLK / | 000 = MCLK / 4 | | | | | | | | | | | | | 001 = MCLK / 8 | | | | | | | | | | | | DAC2_B0 | CLKDIV[2:0] | 010 = 32fs | | | | | | | | | | | | _ | | 011 = 64fs | | | | | | | | | | | | | | 100 = 128fs | | | | | | | | | | | | | | All other value | es of DAC2 B | CLKDIV[2:0] are | e reserved | | | | | | | | Figure 30 R8 – DAC2 Control Register 2 | R9 (09h) - | - DAC2 Contr | ol Register 3 (I | DAC2_CTRL3) | | | | | | | | | | |------------|--------------|-------------------------|---------------------------------------------------------------|-----|-----|----------------|-----------------|--------------|--|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Write | N/A | | | | | Default | 0 | 0 | 0 0 0 0 0 0 0 | | | | | | | | | | | | | _ | | | | | | | | | | | | Bit # | 7 | 6 | 6 5 4 3 2 1 0 | | | | | | | | | | | Read | 0 | 0 | 0 0 0 0 0 0 | | | | | | | | | | | Write | N/A DAC2_MSTR | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | N/A | = Not Applicab | le (no function | implemented) | | | | | | Fui | nction | | Description | | | | | | | | | | | DAC | 2_MSTR | DAC2 Master Mode Select | | | | | | | | | | | | | | 0 = Slave mo | 0 = Slave mode, DACBCLK2 and DACLRCLK2 are inputs to WM8594 | | | | | | | | | | | | | 1 = Master m | = Master mode, DACBCLK2 and DACLRCLK2 are outputs from WM8594 | | | | | | | | | | Figure 31 R9 – DAC2 Control Register 3 | KTU (UAN) | - DACZL DIG | ital Volume Co | ntroi kegistei | r (DACZL_VOL | ) | 1 | 1 | | | |---------------------|-------------|---------------------------------------------------------------------|----------------|-----------------|-----------------|------------------|-----------------|---------------|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC2L_VL | | | Write | N/A DACZL_VC | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit# | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Read | | | | DACSL 3 | /OL [7:0] | | | | | | Write | | | | DAC2L_ | VOL[7.0] | | | | | | Default | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | | | | | | | | N/A | = Not Applical | ble (no functio | n implemented | | | Fur | nction | | | | Description | | | | | | DAC2L | _VOL[7:0] | DAC2 Digital | Volume | | | | | | | | | | 0000 0000 = -100dB | | | | | | | | | | | 0000 0001 = -99.5dB | | | | | | | | | | | 0000 0010 = -99dB | | | | | | | | | | | 0.5dB steps | | | | | | | | | | | 1100 1000 = 0 | dB | | | | | | | | | | 0.5dB steps | | | | | | | | | 1101 1111 = +11.5dB | | | | | | | | | | | | | 111X XXXX = | +12dB | | | | | | | | DAC | 2L_VU | DAC2 Digital | Volume Upda | ite | | | | | | | | | 0 = Latch DAC2L_VOL[7:0] into Register Map but do not update volume | | | | | | | | | | | 1 = Latch DAC | 2L_VOL[7:0] i | nto Register Ma | ap and update l | eft and right ch | annels simulta | ineously | | Figure 32 R10 - DAC2L Digital Volume Control Register | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | | | |---------------------------------------------------------------------|---------------------|--------------|----------------|-----------------|-----------------|----------------------------------------------------------------------------------------------|-----------------|-----------------|--|--|--|--|--|--|--| | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DA 00D 1/11 | | | | | | | | | Write | N/A DAC2R_VU | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | Read | | | | DACSB | VOI [7:0] | | | | | | | | | | | | Write | | | DAC2R_VOL[7:0] | | | | | | | | | | | | | | Default | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | | | | | | | | | | | | | | N/A | A = Not Applicat | ole (no functio | on implemented) | | | | | | | | | Fui | nction | | | | Description | | | | | | | | | | | | DAC2R | _VOL[7:0] | DAC2R Digit | tal Volume | | | | | | | | | | | | | | | | 0000 0000 = | -100dB | | | | | | | | | | | | | | | | 0000 0001 = | -99.5dB | | | | | | | | | | | | | | | | 0000 0010 = | -99dB | | | | | | | | | | | | | | | | 0.5dB step | S | | | | | | | | | | | | | | | | 1100 1000 = | 0dB | | | | | | | | | | | | | | | | 0.5dB step | S | | | | | | | | | | | | | | | 1101 1111 = +11.5dB | | | | | | | | | | | | | | | | | 111X XXXX = +12dB | | | | | | | | | | | | | | | | DAC | 2R_VU | DAC2R Digit | tal Volume Up | date | | | | | | | | | | | | | 0 = Latch DAC2R_VOL[7:0] into Register Map but do not update volume | | | | | | | | | | | | | | | | | | | 0 = Latch DA | .C2R_VOL[7:0] | into Register M | ap but do not t | 1 = Latch DAC2R_VOL[7:0] into Register Map and update left and right channels simultaneously | | | | | | | | | | Figure 33 R11 – DAC2R Digital Volume Control Register | R12 (0Ch | ) – Device En | able Register ( | ENABLE) | | | | | | | | | | |----------|---------------|-----------------|----------------------------------------------------|-----|-----|----------------|-----------------|--------------|--|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Write | N/A | | | | | Default | 0 | 0 | 0 0 0 0 | | | | | | | | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 4 3 2 1 0 | | | | | | | | | | | Read | 0 | 0 | 0 0 0 0 0 | | | | | | | | | | | Write | N/A GLOBAL_EN | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | N/A | = Not Applicat | le (no function | implemented) | | | | | | Fu | nction | | Description | | | | | | | | | | | GLO | BAL_EN | Device Globa | Pevice Global Enable | | | | | | | | | | | | | 0 = ADC, DAG | = ADC, DAC and PGA ramp control circuitry disabled | | | | | | | | | | | | | 1 = ADC, DAG | C, DAC and PGA ramp control circuitry enabled | | | | | | | | | | Figure 34 R12 – Device Enable Register | R13 (0Dh | – ADC Conti | rol Register 1 ( | ADC_CTRL1) | | | | | | | |----------------------------|-------------|------------------|----------------------------|-------------------|----------------|----------------|------------------|--------------|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | Read | 0 | 0 | ADC ZCEN | ADC_HPD | ADC DATA | V CEL[1:0] | ADCL_INV | ADCR_INV | | | Write | N/A | N/A | ADC_ZCEN | ADC_HPD | 0 0 0 | | ADCL_INV | ADCK_INV | | | Default | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Read | ADC_ | ADC EN | ADC LRP | ADC_BCP | ADC_V | VI [1·0] | ADC_F | MT[1·0] | | | Write | LRSWAP | ADC_LIV | ADC_LIN | ADC_BCI | ADC_V | V L[1.0] | ADC_I | wii[i.o] | | | Default | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | | Fui | nction | | Description | | | | | | | | ADC_ | FMT[1:0] | ADC Audio II | ADC Audio Interface Format | | | | | | | | | | 00 = Right Ju | stified | | | | | | | | | | 01 = Left Just | tified | | | | | | | | | | $10 = I^2S$ | | | | | | | | | | | 11 = DSP | | | | | | | | | ADC_ | _WL[1:0] | ADC Audio I | nterface Word | Length | | | | | | | | | 00 = 16-bit | | | | | | | | | | | 01 = 20-bit | | | | | | | | | | | 10 = 24-bit | | | | | | | | | | | 11 = 32-bit (n | ot available in F | Right Justified m | node) | | | | | | ADO | C_BCP | ADC BCLK P | olarity | | | | | | | | | | | | data latched or | | | | | | | | | | | a latched on fall | ing edge of BC | LK | | | | | ADC_LRP ADC LRCLK Polarity | | | | | | | | | | | 0 = ADCLRCLK not inverted | | | | | | | | | | | | | 1 = ADCLRC | LK inverted | | | | | | | | AD | C_EN | ADC Enable | | | | | | | | | | | 0 = ADC disa | bled | | | | | | | | | | 1 = ADC enal | oled | | | | | | | | ADC_LRSWAP | ADC Left/Right Swap | |-------------------|-----------------------------------------------------------------| | | 0 = Normal | | | 1 = Swap left channel data into right channel and vice-versa | | ADCR_INV | ADCL and ADCR Output Signal Inversion | | ADCL_INV | 0 = Output not inverted | | | 1 = Output inverted | | ADC_DATA_SEL[1:0] | ADC Data Output Select | | | 00 = left data from ADCL, right data from ADCR (Normal Stereo) | | | 01 = left data from ADCL, right data from ADCL (Mono Left) | | | 10 = left data from ADCR, right data from ADCR (Mono Right) | | | 11 = left data from ADCR, right data from ADCL (Reverse Stereo) | | ADC_HPD | ADC High Pass Filter Disable | | | 0 = High pass filter enabled | | | 1 = High pass filter disabled | | ADC_ZC_EN | ADC Digital Volume Control Zero Cross Enable | | | 0 = Do not use zero cross, change volume instantly | | | 1 = Use zero cross, change volume when data crosses zero | Figure 35 R13 – ADC Control Register 1 | R14 (0Eh) | - ADC Cont | rol Register 2 ( | ADC_CTRL2) | | | | | | | | | |----------------|------------|------------------|-----------------------------------------------|----------------|----------|-------------|--------------|---|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Write | N/A | N/A | N/A | N/A | N/A | N/A N/A N/A | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | _ | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | 0 | 0 | ΔΙ | DC_BCLKDIV[2 | ∪1 | | ADC_SR[2:0] | | | | | | Write | N/A | N/A | A | DC_BCERDIV[2 | | | ADC_GIV[2.0] | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | N/A = Not Applicable (no function implemented | | | | | | | | | | | nction | Description | | | | | | | | | | | ADC_ | _SR[2:0] | ADC MCLK:L | RCLK Ratio | | | | | | | | | | | | 000 = Auto de | etect | | | | | | | | | | | | 001 = reserve | ed | | | | | | | | | | | | 010 = reserve | ed | | | | | | | | | | | | 011 = 256fs | | | | | | | | | | | | | 100 = 384 fs | | | | | | | | | | | | | 101 = 512fs | | | | | | | | | | | | | 110 = 768fs | | | | | | | | | | | | | 111 = Reserv | ed | | | | | | | | | | ADC_BC | LKDIV[2:0] | ADC BCLK R | ate (when AD | C in Master Mo | ode) | | | | | | | | 000 = MCLK / 4 | | | | | | | | | | | | | | | 001 = MCLK / | <sup>'</sup> 8 | | | | | | | | | | | | 010 = 32fs | | | | | | | | | | | | | 011 = 64fs | | | | | | | | | | | | | 100 = 128fs | | | | | | | | | | | | | All other value | es of ADC_BC | LKDIV[2:0] are | reserved | | | | | | | Figure 36 R14 – ADC Control Register 2 | R15 (0Fh) | – ADC Contr | ol Register 3 (A | ADC_CTRL3) | | | | | | | | | | |-----------|-------------|------------------|-----------------------------------------------------------|-----|-----|----------------|-----------------|--------------|--|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Write | N/A | | | | | Default | 0 | 0 | 0 0 0 0 0 0 | | | | | | | | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 5 4 3 2 1 0 | | | | | | | | | | | Read | 0 | 0 | | | | | | | | | | | | Write | N/A ADC_MSTR | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | N/A | = Not Applicab | le (no function | implemented) | | | | | | Fu | nction | | Description | | | | | | | | | | | ADC | _MSTR | ADC Master | ADC Master Mode Select | | | | | | | | | | | | | 0 = Slave mod | ) = Slave mode, ADCBCLK and ADCLRCLK are inputs to WM8594 | | | | | | | | | | | | | 1 = Master me | Master mode, ADCBCLK and ADCLRCLK are outputs from WM8594 | | | | | | | | | | Figure 37 R15 – ADC Control Register 3 | R16 (10h) – Left ADC Digital Volume Control Register (ADCL_VOL) | | | | | | | | | | | | |---------------------------------------------------------------------------------------------|----------------------------------------|--------------------------|------------------------------------------------------------------|-------------------|-------------|----------------|------------------|--------------|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ADCL VU | | | | | Write | N/A | N/A | N/A | A N/A N/A N/A N/A | | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | | ADCL VOL[7:0] | | | | | | | | | | | Write | | ADOL_VOL[1.0] | | | | | | | | | | | Default | 1 | 1 1 0 0 0 0 1 1 | | | | | | | | | | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | | | | Fui | nction | | | | Description | | | | | | | | ADCL_ | _VOL[7:0] | Left ADC Dig | jital Volume | | | | | | | | | | | | 0000 0000 = Digital mute | | | | | | | | | | | | | 0000 0001 = -97dB | | | | | | | | | | | | | 0000 0010 = | -96.5dB | | | | | | | | | | | | 0.5dB steps | S | | | | | | | | | | | | 1100 0011 = | 0dB | | | | | | | | | | | | 0.5dB steps | S | | | | | | | | | | 1111 1110 = +29.5dB | | | | | | | | | | | | | | | 1111 1111 = | +30dB | | | | | | | | | | ADO | ADCL_VU Left DAC Digital Volume Update | | | | | | | | | | | | | | 0 = Latch AD | = Latch ADCL_VOL[7:0] into Register Map but do not update volume | | | | | | | | | | 1 = Latch ADCL_VOL[7:0] into Register Map and update left and right channels simultaneously | | | | | | eously | | | | | | Figure 38 R10 – Left ADC Digital Volume Control Register | R17 (11h) | - Right ADC | Digital Volum | e Control Regi | ster (ADCR_V | OL) | | | | | | | | |---------------------|-----------------|---------------------------------------------------------------------------------------------|----------------|--------------|-------------|-----------------|-----------------|----------------|--|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ADCR_VU | | | | | | Write | N/A ADCK_VU | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | Read | | ADCR_VOL[7:0] | | | | | | | | | | | | Write | | ADCK_VOL[1.0] | | | | | | | | | | | | Default | 1 1 0 0 0 0 1 1 | | | | | | | | | | | | | | | | | | N/A | A = Not Applica | ble (no functio | n implemented) | | | | | | Fu | nction | | | | Description | | | | | | | | | ADCR_ | _VOL[7:0] | Right ADC D | igital Volume | | | | | | | | | | | | | 0000 0000 = Digital mute | | | | | | | | | | | | | | 0000 0001 = -97dB | | | | | | | | | | | | | | 0000 0010 = -96.5dB | | | | | | | | | | | | | | 0.5dB step | s | | | | | | | | | | | | | 1100 0011 = | 0dB | | | | | | | | | | | | | 0.5dB step | s | | | | | | | | | | | 1111 1110 = +29.5dB | | | | | | | | | | | | | | | | 1111 1111 = | +30dB | | | | | | | | | | | ADO | CR_VU | Right ADC D | igital Volume | Update | | | | | | | | | | | | 0 = Latch ADCR_VOL[7:0] into Register Map but do not update volume | | | | | | | | | | | | | | 1 = Latch ADCR_VOL[7:0] into Register Map and update left and right channels simultaneously | | | | | | | | | | | Figure 39 R17 – Right ADC Digital Volume Control Register WM8594 | R19 (13h) | - PGA1L Vol | lume Control R | egister (PGA1 | L_VOL) | | | | | | | |-----------|-------------------------------------------------------|----------------|-----------------|-----------|--------------|------------------|-----------------|----------------|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Write | N/A PGA1L_VU | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | I | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | | | | DCA4L | VOL [7:0] | | | | | | | Write | | | | PGA1L_ | VOL[7:0] | | | | | | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | | | N/A = Not Applicable (no function implemented) | | | | | | | | | | | R20 (14h) | R20 (14h) - PGA1R Volume Control Register (PGA1R_VOL) | | | | | | | | | | | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Write | N/A PGA1R_VU | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | | | | PGA1R | VOL[7:0] | | | | | | | Write | | | | i o/tiit_ | . V O L[7.0] | | | | | | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | | | | | | | N/A | A = Not Applicab | le (no functio | n implemented) | | | | R21 (15h) | - PGA2L Vol | lume Control R | egister (PGA2 | L_VOL) | 1 | | | 1 | | | | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Write | N/A PGA2L_VU | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | Г | T | 1 | | | 1 | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | | | | PGA2L_ | VOL[7:0] | | | | | | | Write | | | | | | | | | | | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | | D22 (46h) | DC A2D Va | luma Cantral F | Dominton (DC A) | D VOL | N/F | A = Not Applicab | ie (no functioi | n implemented) | | | | Bit # | - PGAZR VO<br>15 | lume Control F | | 12 | 14 | 10 | 0 | | | | | Read | 0 | 0 | 13<br>0 | 0 | 0 | <b>10</b> | 9 | 8 | | | | Write | N/A | N/A | N/A | N/A | N/A | | N/A | PGA2R_VU | | | | Default | 0 | 0 | 0<br>0 | 0<br>0 | 0<br>0 | N/A<br>0 | 0<br>0 | 0 | | | | Deiduit | U | U | l u | l 0 | <u> </u> | U | U | 1 0 | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | ' | | | L | | | 1 | | | | | Write | | | | PGA2R_ | VOL[7:0] | | | | | | | Default | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | | Joidan | <u> </u> | <u> </u> | <u> </u> | <u> </u> | | | | | | | | | N/A = Not Applicable (no function implemented) | | | | | | | | | | ...Continued on next page WM8594 | Bit # | R23 (17h) | - PGA3L Vol | ume Control R | egister (PGA3 | L_VOL) | | | | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------|----------------|----------------|------------------|-----------------|------------------|-----------------|-----------------------------|--|--| | Write N/A N/A N/A N/A N/A N/A N/A PGA3L_VU Default 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Default | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bit # 7 6 5 4 3 2 1 0 | Write | N/A PGA3L_VU | | | | Read PGA3L_VOL[7:0] PGA3L_VOL[7: | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Read PGA3L_VOL[7:0] PGA3L_VOL[7: | | | | | | | | | | | | | Myrite Default 0 | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Default 0 | Read | | | | PGA3I | VOI [7:0] | | | | | | | N/A = Not Applicable (no function implemented) R24 (18h) - PGA3R Volume Control Register (PGA3R_VOL) Bit # | Write | | FGASL_VOL[1.0] | | | | | | | | | | R24 (18h) - PGA3R Volume Control Register (PGA3R_VOL) | Default | | | | | | | | | | | | Bit # 15 | | | | | | N/A | A = Not Applical | ole (no functio | n implemented) | | | | Read | R24 (18h) | - PGA3R Vol | lume Control F | Register (PGA3 | R_VOL) | _ | _ | | | | | | Write N/A N/A N/A N/A N/A N/A PGA3R_VU Default 7 6 5 4 3 2 1 0 Read PGA3R_VOL[7:0] Write PGA3R_VOL[7:0] Default 0 0 0 1 1 0 0 N/A = Not Applicable (no function implemented) PGA1L_VOL[7:0] PGA2L_VOL[7:0] Input PGA Volume 0000 0000 = +6dB 0000 0001 = +5.5dB 0.5dB steps 00001100 = 0dB <td>Bit #</td> <td>15</td> <td>14</td> <td>13</td> <td>12</td> <td>11</td> <td>10</td> <td>9</td> <td>8</td> | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Bit # 7 6 5 4 3 2 1 0 | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Bit # 7 6 5 4 3 2 1 0 | Write | N/A PGA3R_VU | | | | PGA3R_VOL[7:0] | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | PGA3R_VOL[7:0] | | | | | | | | | | | | | Default O | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Default O | Read | | | | PGA3R | VOI [7:0] | | | | | | | PGA1L_VOL[7:0] Input PGA Volume PGA1R_VOL[7:0] 0000 0000 = +6dB PGA2L_VOL[7:0] 0000 0001 = +5.5dB PGA2R_VOL[7:0] 0000 1100 = 0dB PGA3R_VOL[7:0] 0000 1100 = 0dB PGA3R_VOL[7:0] 011111 = PGA Mute PGA1L_VU PGA1R_VU PGA1R_VU PGA2L_VU PGA2L_VU PGA2L_VU PGA2R_VU PGA3L_VU | | | | | . 67.611 | | | | | | | | PGA1L_VOL[7:0] Input PGA Volume 9GA1R_VOL[7:0] 0000 0000 = +6dB 9GA2L_VOL[7:0] 0000 0001 = +5.5dB 0.5dB steps 9GA3L_VOL[7:0] 00001100 = 0dB PGA3R_VOL[7:0] 1001 1110 = -73.5dB 1001 1111 = PGA Mute PGA1L_VU PGA1R_VU PGA2L_VU PGA2L_VU PGA2L_VU PGA3L_VU | Default | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | | PGA1R_VOL[7:0] 0000 0000 = +6dB PGA2L_VOL[7:0] 0000 0001 = +5.5dB PGA2R_VOL[7:0] 0.5dB steps PGA3L_VOL[7:0] 00001100 = 0dB PGA3R_VOL[7:0] 1001 1110 = -73.5dB 1001 1111 = PGA Mute PGA1L_VU Input PGA Volume Update PGA1R_VU 0 = Latch corresponding volume setting into Register Map but do not update volume PGA2L_VU 1 = Latch corresponding volume setting into Register Map and update all channels simultaneously PGA3L_VU PGA3L_VU | | | 1 | | | N/A | A = Not Applical | ole (no functio | n implemented) | | | | PGA2L_VOL[7:0] 0000 0001 = +5.5dB0.5dB steps 00001100 = 0dB 0.5dB steps 1001 1110 = -73.5dB 1001 1111 = PGA Mute PGA1L_VU PGA1R_VU PGA2L_VU PGA3L_VU | | | • | | | | | | | | | | PGA2R_VOL[7:0]0.5dB steps 00001100 = 0dB PGA3R_VOL[7:0] 1001 1110 = -73.5dB 1001 1111 = PGA Mute PGA1L_VU Input PGA Volume Update PGA1R_VU 0 = Latch corresponding volume setting into Register Map but do not update volume PGA2L_VU 1 = Latch corresponding volume setting into Register Map and update all channels simultaneously PGA3L_VU PGA3L_VU | | | | | | | | | | | | | PGA3L_VOL[7:0] 00001100 = 0dB 1001 1110 = -73.5dB 1001 1111 = PGA Mute PGA1L_VU | | | | | | | | | | | | | PGA3R_VOL[7:0] 1001 1110 = -73.5dB 1001 1111 = PGA Mute PGA1L_VU PGA1R_VU PGA2L_VU PGA2R_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU | | | | | | | | | | | | | 1001 1110 = -73.5dB 1001 1111 = PGA Mute PGA1L_VU PGA1R_VU PGA2L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU | | | | )dB | | | | | | | | | PGA1L_VU PGA1R_VU PGA2L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU | PGA3R | _VOL[7:0] | | 72 EdD | | | | | | | | | PGA1L_VU PGA1R_VU PGA2L_VU PGA2R_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA1L_VU Input PGA Volume Update 0 = Latch corresponding volume setting into Register Map and update all channels simultaneously | | | | | | | | | | | | | PGA1R_VU PGA2L_VU PGA2R_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU PGA3L_VU | DC 4 | 41 1/11 | | | | | | | | | | | PGA2L_VU 1 = Latch corresponding volume setting into Register Map and update all channels simultaneously PGA2R_VU PGA3L_VU | | _ | | • | ıma sattina inte | Pegister Man | hut do not unda | ate volume | | | | | PGA2R_VU<br>PGA3L_VU | | | | | | | | | ultaneously | | | | PGA3L_VU | | _ | I - Later Col | responding voi | unic scillig III | to register Mar | and update an | GIAIIIICIS SIII | idital i <del>c</del> ously | | | | | | | | | | | | | | | | | PGA3R_VU | | | | | | | | | | | | Figure 40 R19-24 - PGA Volume Control Registers | R25 (19h) - PGA Control Register 1 (PGA_CTRL1) | | | | | | | | | | | |------------------------------------------------|----------|----------------------------------------------|----------------|----------|-------------|----------------|------------------|--------------|--|--| | Bit# | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Write | N/A | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit# | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | DCA2D 70 | DCASL 7C | PGA2R ZC | DCAOL 70 | PGA1R ZC | DC 441 7C | ATTACK_ | DECAY_ | | | | Write | PGA3R_ZC | PGA3L_ZC | PGAZR_ZC | PGA2L_ZC | PGATR_ZC | PGA1L_ZC | BYPASS | BYPASS | | | | Default | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | | | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | | | Fu | nction | | | | Description | | | | | | | DECAY | _BYPASS | PGA Gain Decay Mode | | | | | | | | | | | | 0 = PGA gain will ramp down | | | | | | | | | | | | 1 = PGA gain will step down | | | | | | | | | | ATTACI | K_BYPASS | PGA Gain At | tack Mode | | | | | | | | | | | 0 = PGA gain will ramp up | | | | | | | | | | | | 1 = PGA gain will step up | | | | | | | | | | PG/ | A1L_ZC | PGA Gain Ze | ero Cross Enak | ole | | | | | | | | PG/ | A1R_ZC | 0 = PGA gain updates occur immediately | | | | | | | | | | PG/ | A2L_ZC | 1 = PGA gain updates occur on zero cross | | | | | | | | | | PG <i>A</i> | A2R_ZC | Zero cross must be disabled to use gain ramp | | | | | | | | | | PGA | A3L_ZC | | | | | | | | | | | PG/ | A3R ZC | | | | | | | | | | Figure 41 R25 – PGA Control Register 1 | R26 (1Ah | ) – PGA Conti | rol Register 2 ( | PGA CTRL2) | | | | | | | | |-------------|---------------|-----------------------------|------------|---------|-------------|----------------|------------------|--------------|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Write | N/A | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | 0 | VOUT3R_ | VOUT3L_ | VOUT2R_ | VOUT2L_ | VOUT1R_ | VOUT1L_ | MUTE ALL | | | | Write | N/A | MUTE | MUTE | MUTE | MUTE | MUTE | MUTE | MUTE_ALL | | | | Default | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | | | Fu | nction | | | | Description | | | | | | | MU | ΓE_ALL | Master PGA Mute Control | | | | | | | | | | | | 0 = Unmute all PGAs | | | | | | | | | | | | 1 = Mute all PGAs | | | | | | | | | | VOUT | 1L_MUTE | Individual PGA Mute Control | | | | | | | | | | VOUT | 1R_MUTE | 0 = Unmute PGA | | | | | | | | | | VOUT | 2L_MUTE | 1 = Mute PGA | A | | | | | | | | | VOUT2R_MUTE | | | | | | | | | | | | VOUT | 3L_MUTE | | | | | | | | | | | VOUT: | 3R_MUTE | | | | | | | | | | Figure 42 R26 – PGA Control Register 2 | R27 (1Bh) | - Additiona | al Control Regis | ter 1 (ADD_CT | RL1) | | | | | | | | | |-----------|-------------|------------------|--------------------------------------------|--------------|------------------|---------------|------------------|--------------|--|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Write | N/A | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit# | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | Read | 0 | | DCA CDIO.OI | | AUTO_INC | 0 | 0 | 0 | | | | | | Write | N/A | | PGA_SR[2:0] | | AUTO_INC | N/A | N/A | N/A | | | | | | Default | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | | | | | | | | | | | N/A | = Not Applica | ble (no function | implemented) | | | | | | Fur | nction | | | | Description | | | | | | | | | AUT | O_INC | 2-wire Softw | 2-wire Software Mode Auto Increment Enable | | | | | | | | | | | | | 0 = Auto incr | 0 = Auto increment disabled | | | | | | | | | | | | | 1 = Auto incre | ement enabled | | | | | | | | | | | PGA_ | SR[2:0] | Sample Rate | for PGA | | | | | | | | | | | | | 000 = 32kHz | | | | | | | | | | | | | | 001 = 44.1kH | lz | | | | | | | | | | | | | 010 = 48kHz | 010 = 48kHz | | | | | | | | | | | | | 011 = 88.2kHz | | | | | | | | | | | | | | 100 = 96kHz | | | | | | | | | | | | | | 101 = 176.4kHz | | | | | | | | | | | | | | 11X = 192kH | 11X = 192kHz | | | | | | | | | | | | | See Table 28 | for further infor | mation on PG | A sample rate ve | rsus volume r | amp rate. | | | | | | Figure 43 R27 – Additional Control Register 1 | R28 (1Ch) | - Input Cont | rol Register 1 | (INPUT_CTRL | 1) | | | | | | | | |-----------|--------------|------------------------------|------------------------------------|----------|-------------------|------------------|------------------|--------------|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | | 5040 | N. 051 (0.0) | | | | | | Write | N/A | N/A | N/A | N/A | | PGA2L_I | N_SEL[3:0] | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | | DCA1B IN | L CEL [3:0] | | | DCA4L II | N 6E1 [3:0] | | | | | | Write | | PGA1R_IN | I_SEL[3:0] | | PGA1L_IN_SEL[3:0] | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | N | /A = Not Applica | ble (no function | implemented) | | | | | R29 (1Dh) | - Input Cont | rol Register 2 | (INPUT_CTRL | 2) | | | | | | | | | Bit# | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | | DCA2D I | N CELISIO | | | | | | Write | N/A | N/A | N/A | N/A | | PGA3R_I | N_SEL[3:0] | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit# | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | | PGA3L_IN | CE [3·0] | | | DCV3D I | N CELIS:01 | | | | | | Write | | PGA3L_IIV | _3⊑L[3.0] | | PGA2R_IN_SEL[3:0] | | | | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | N | /A = Not Applica | ble (no function | implemented) | | | | | Fur | nction | | | | Description | ı | | | | | | | | N_SEL[3:0] | Left Input PG | A Source Sele | ection | | | | | | | | | PGA2L_I | N_SEL[3:0] | 0000 = No inp | out selected | | | | | | | | | | PGA3L_I | N_SEL[3:0] | 0001 = VIN1L | . selected | | | | | | | | | | | | 0010 = VIN2L selected | | | | | | | | | | | | | 0011 = VIN3L selected | | | | | | | | | | | | | 0100 = VIN4L | | | | | | | | | | | | | 0101 = VIN5L | | | | | | | | | | | | | 0110 to 1000 | | | | | | | | | | | | | | L output select | | | | | | | | | | | | | R output select<br>L output select | | | | | | | | | | | | | R output select | | | | | | | | | | | | 1100 = B/(02<br>1101 to 1111 | | icu | | | | | | | | | PGA1R | IN_SEL[3:0] | - | GA Source Se | election | | | | | | | | | _ | IN_SEL[3:0] | 0000 = No inp | | | | | | | | | | | | IN_SEL[3:0] | 0001 = VIN1F | | | | | | | | | | | _ | | 0010 = VINVIN Selected | | | | | | | | | | | | | 0011 = VIN3R selected | | | | | | | | | | | | | 0100 = VIN4R selected | | | | | | | | | | | | | 0101 = VIN5R selected | | | | | | | | | | | | | 0110 to 1000 = reserved | | | | | | | | | | | | | 1001 = DAC1L output selected | | | | | | | | | | | | | 1010 = DAC1R output selected | | | | | | | | | | | | | 1011 = DAC2L output selected | | | | | | | | | | | | | | R output select | ted | | | | | | | | | | | 1101 to 1111 = reserved | | | | | | | | | | Figure 44 R28-29 – Input Control Registers 1-2 | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | |----------------------|--------------|-------------------------------|--------------------------------------------|-----|-----|-----------|----------|------------|--|--|--| | Read | 0 | 0 | 0 | 0 | 0 | ADC | | | | | | | Write | N/A | N/A | N/A | N/A | N/A | SWITCH_EN | ADC_AMF | P_VOL[1:0] | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | | | | | | | | | | | <u> </u> | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | | 4000 | ADOD SEL[3:0] | | | | | | | | | | Write | | ADCR_ | ADCR_SEL[3:0] ADCL_SEL[3:0] | | | | | | | | | | Default | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | N/A = Not Applicable (no function implemen | | | | | | | | | | Function Description | | | | | | | | | | | | | ADCL | _SEL[3:0] | ADC Input S | elect | | | | | | | | | | ADCR | _SEL[3:0] | 0000 = VIN1L | | | | | | | | | | | | | 0001 = VIN2I | _ | | | | | | | | | | | | 0010 = VIN3I | _ | | | | | | | | | | | | 0011 = VIN4I | _ | | | | | | | | | | | | 0100 = VIN5I | _ | | | | | | | | | | | | 0101 to 1000 = reserved | | | | | | | | | | | | | 1000 = VIN1R | | | | | | | | | | | | | 1001 = VIN2R | | | | | | | | | | | | | 1010 = VIN3I | 3 | | | | | | | | | | | | 1011 = VIN4I | 3 | | | | | | | | | | | | 1100 = VIN5I | ₹ | | | | | | | | | | | | 1101 to 1111 = reserved | | | | | | | | | | | ADC_AN | /IP_VOL[1:0] | ADC Amplifier Gain Control | | | | | | | | | | | | | 00 = 0 dB | | | | | | | | | | | | | 01 = +3dB | | | | | | | | | | | | | 10 = +6dB | | | | | | | | | | | | | 11 = +12dB | | | | | | | | | | | ADC_S | WITCH_EN | ADC Input S | witch Control | | | | | | | | | | _ | | _ | it switches open | ı | | | | | | | | | | | 1 = ADC input switches closed | | | | | | | | | | Figure 45 R30 – Input Control Register 3 | R31 (1Fh) | R31 (1Fh) - Input Control Register 4 (INPUT_CTRL4) | | | | | | | | | | |-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|----------|----------|-------------|----------------|------------------|--------------|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Write | N/A | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | Read ADCR_AMP_ ADCL_AMP_ BOAGE EN | | | | | | | | | | | Write | EN | EN | PGA3R_EN | PGA3L_EN | PGA2R_EN | PGA2L_EN | PGA1R_EN | PGA1L_EN | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | | | Fu | nction | | | | Description | | | | | | | PG <i>A</i> | \1L_EN | Input PGA Enable Controls | | | | | | | | | | PGA | 1R_EN | 0 = PGA disabled | | | | | | | | | | PG/ | \2L_EN | 1 = PGA enabled | | | | | | | | | | PGA | A2R_EN | | | | | | | | | | | PG/ | A3L_EN | | | | | | | | | | | PGA | A3R_EN | | | | | | | | | | | ADCL_ | _AMP_EN | ADC Input Amplifier Enable Controls | | | | | | | | | | ADCR. | _AMP_EN | 0 = Amplifier disabled | | | | | | | | | | 1 = Amplifier enabled | | | | | | | | | | | Figure 46 R31 – Input Control Register 4 | R32 (20h) | - Output Co | ntrol Register 1 | (OUTPUT_CT | RL1) | | | | | | | | |-----------|-------------|----------------------------|----------------|---------------|-------------|------------------|------------------|----------------|--|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | VOUT2L_ | | | | | Write | N/A SEL[2] | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | VOUT2L | SEL[1:0] | VC | OUT1R _SEL[2 | ·01 | V | OUT1L_SEL[2 | 2:01 | | | | | Write | VOOTZE | _0LL[1.0] | • | 701 IN _0LL[2 | | V | 00111_01112 | 0] | | | | | Default | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | | | | | | | | | N/A | A = Not Applicat | ole (no function | n implemented) | | | | | R33 (21h) | - Output Co | ntrol Register 2 | (OUTPUT_CT | RL2) | | 1 | | | | | | | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | VOUT3R_ | | | | | Write | N/A SEL[2] | | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Read | VOUT3R_ | SEL [1:0] | V | OUT3L_SEL [2 | ·01 | V | OUT2R_SEL[2 | 2.01 | | | | | Write | 700101 | _022[1.0] | | JO 102_022 [2 | .0] | | 001211_022[ | 01 | | | | | Default | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | | | | | | | 1 | | | | A = Not Applicat | ole (no function | n implemented) | | | | | | nction | | | | Description | | | | | | | | | L_SEL[3:0] | Output Mux | | | | | | | | | | | | R_SEL [3:0] | | 000 = PGA1L | | | | | | | | | | | _SEL [3:0] | | 001 = PGA1R | | | | | | | | | | | R_SEL [3:0] | 010 = PGA2L | | | | | | | | | | | | _SEL [3:0] | 011 = PGA2R | | | | | | | | | | | VOU13F | R_SEL [3:0] | 100 = PGA3L<br>101 = PGA3R | | | | | | | | | | | | | | 11X = Reserved | | | | | | | | | | | | IIA = Keserv | eu | | | | | | | | | Figure 47 R32-33 – Output Control Registers 1-2 | R34 (22h) | R34 (22h) - Output Control Register 3 (OUTPUT_CTRL3) | | | | | | | | | | |---------------------------------------|------------------------------------------------------|---------------------------------------------|------------------|-------------|--------------|----------------|------------------|--------------|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | VOUT3R EN | VOLITAL EN | VOUT2R EN | VOUT2L EN | VOUT1R EN | | | | Write | N/A | N/A | N/A | VOOTSK_EIV | VOUTSL_EN | VOOTZK_EN | VOOTZL_EN | VOOT IK_EIN | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | VOUT1L_EN | APE B | VOLITAR TRI | VOLIT3L TRI | VOUT2R_TRI | VOLITZI TRI | VOLIT1R TRI | VOLIT1L TRI | | | | Write | VOOTTE_EIN | /\\ L_B | VOOTOIL_III | VOOTOL_TIKE | VOOTZIN_TINI | VOOTZE_TIKI | VOOT III_IIII | V00112_11(1 | | | | Default | 0 | 1 0 0 0 0 0 0 | | | | | | 0 | | | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | | | Fui | nction | | | | Description | | | | | | | VOU | T1L_TRI | Output Ampl | ifier Tristate C | ontrol | | | | | | | | VOU | T1R_TRI | 0 = Normal operation | | | | | | | | | | | T2L_TRI | 1 = Output amplifier tristate enable (Hi-Z) | | | | | | | | | | | T2R_TRI | | | | | | | | | | | | T3L_TRI | | | | | | | | | | | | T3R_TRI | | | | | | | | | | | AF | PE_B | | ıts to Ground | | | | | | | | | | | 0 = clamp act | | | | | | | | | | | | 1 = clamp not | | | | | | | | | | | T1L_EN | | ifier Enables | | | | | | | | | | VOUT1R_EN 0 = Output amplifier d | | | | | | | | | | | VOUT2L_EN 1 = Output amplifier enable | | | nplifier enabled | | | | | | | | | | VOUT2R_EN | | | | | | | | | | | VOUT3L_EN | | | | | | | | | | | | VOU' | T3R_EN | | | | | | | | | | Figure 48 R34 – Output Control Register 3 | R35 (23h) | R35 (23h) - Bias Control Register (BIAS) | | | | | | | | | | |-----------|-------------------------------------------------------------------|-----------------------------------------------|------------------------------|-----------------|----------------|----------------|------------------|--------------|--|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Write | N/A | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | \/MID ( | SEL[1:0] | BIAS_EN | SOFT_ST | BUFIO_EN | FAST_EN | VMIDTOG | POBCTRL | | | | Write | VIVIID_C | 5EL[1.0] | BIAS_EN | 30F1_31 | BOFIO_EN | FAST_EN | VIVIIDTOG | POBCIKE | | | | Default | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | | | Fur | nction | | | | Description | | | | | | | POE | BCTRL | Bias Source | for Output Am | plifiers | | | | | | | | | | - | nplifiers use ma | | | | | | | | | | | | nplifiers use fas | | | | | | | | | VMI | DTOG | | Down Charact | eristic | | | | | | | | | | 0 = Slow ramp | | | | | | | | | | | | 1 = Fast ramp | | | | | | | | | | FAS | ST_EN | Fast Bias En | | | | | | | | | | | | 0 = Fast bias disabled | | | | | | | | | | | | 1 = Fast bias | | | | | | | | | | BUF | IO_EN | VMID Buffer | | | | | | | | | | | | 0 = VMID Buf | | | | | | | | | | 001 | | 1 = VMID Buf | | | | | | | | | | 501 | FT_ST | VMID Soft Ramp Enable 0 = Soft ramp disabled | | | | | | | | | | | | 1 = Soft ramp enabled | | | | | | | | | | RIA | S_EN | Master Bias | | | | | | | | | | | .O_LIV | 0 = Master bias disabled | | | | | | | | | | | | 1 = Master bia | | | | | | | | | | | Also powers down ADCVMID | | | | | | | | | | | VMID_ | VMID_SEL[1:0] VMID Resistor String Value Selection (DACVMID only) | | | | | | | | | | | | 00 = off (no VMID) | | | | | | | | | | | | $01 = 100k\Omega$ | | | | | | | | | | | | $10 = 500$ k $\Omega$ | | | | | | | | | | | | | $11 = 10k\Omega$ | | | | | | | | | | | | | is the total rixed at 200kΩ. | esistance of th | ne string from | DACREFP to | DACREFN. T | he ADCVMID | | | Figure 49 R35 - Bias Control Register | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | |---------|----------------------------------------------------------|------------------------------------------------------------------|-------------------|----------------|-------------|--------------------|----------------|--------------|--|--| | Read | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | | | Write | N/A | N/A | N/A | N/A | N/A | PGA_UPD | N/A | N/A | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | • | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Read | 0 | 0 | 0 | 0 | | DCA SELIZIO | | PGA_ | | | | Write | N/A | N/A | N/A | N/A | | PGA_SEL[2:0] | | SAFE_SW | | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | N | /A = Not Applicabl | e (no function | implemented) | | | | Fur | nction | | | | Description | 1 | | | | | | PGA_S | AFE_SW | PGA Ramp Control Clock Source Mux Force Update | | | | | | | | | | | | 0 = Wait until clocks are safe before switching PGA clock source | | | | | | | | | | | | 1 = Force PGA clock source to change immediately | | | | | | | | | | | | See page 37 | for details of us | se. | | | | | | | | PGA_ | SEL[2:0] | PGA Ramp Control Clock Source | | | | | | | | | | | | 000 = ADCLRCLK | | | | | | | | | | | | 001 = DACLRCLK1 | | | | | | | | | | | | 010 = DACLRCLK2 | | | | | | | | | | | | 011 = reserved | | | | | | | | | | | | 100 = reserved | | | | | | | | | | | | 101 = DACLRCLK1 (when DAC1 is being used in master mode) | | | | | | | | | | | 110 = DACLRCLK2 (when DAC2 is being used in master mode) | | | | | | | | | | | | | | , | C is being use | | ode) | | | | | | PGA | \_UPD | | | Source Mux U | pdate | | | | | | | | | 0 = Do not update PGA clock source | | | | | | | | | | | | 1 = Update clock source | | | | | | | | | Figure 50 R36 – PGA Control Register 3 | R37 (25h) - ADC Input Clock Control Register (ADC_CLK) | | | | | | | | | |--------------------------------------------------------|--------------------------------------------|-----|-----|-----|-------------|----------------|------------------|--------------| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Write | N/A | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ADC_ | | Write | N/A SAFE_SW | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | N/A | = Not Applicat | ole (no function | implemented) | | Fui | nction | | | | Description | | | | | ADC_S | ADC_SAFE_SW ADC Clock Input Safe Switching | | | | | | | | | | 0 = Ignore ADC Clock Inputs | | | | | | | | | | 1 = Use ADC Clock Inputs | | | | | | | | | | See page 33 for details of use | | | | | | | | Figure 51 R37 – ADC Input Clock Control Register | R38 (26h) | R38 (26h) - DAC1 Input Clock Control Register (DAC1_CLK) | | | | | | | | | |---------------------------|----------------------------------------------------------|-----|-----|-----|-----|------------------|------------------|--------------|--| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Write | N/A | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC1_ | | | Write | N/A SAFE_SW | | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | N/A | A = Not Applicat | ole (no function | implemented) | | | Fui | Function Description | | | | | | | | | | DAC1_ | DAC1_SAFE_SW DAC1 Clock Input Safe Switching | | | | | | | | | | | 0 = Ignore DAC1 Clock Inputs | | | | | | | | | | 1 = Use DAC1 Clock Inputs | | | | | | | | | | | | See page 31 for details of use. | | | | | | | | | Figure 52 R38 – DAC1 Input Clock Control Register | R39 (27h) - DAC2 Input Clock Control Register (DAC2_CLK) | | | | | | | | | |----------------------------------------------------------|----------------------------------------------|-----|-----|-----|-----|------------------|------------------|--------------| | Bit # | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Write | N/A | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit # | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | DAC2_ | | Write | N/A SAFE_SW | | Default | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | N/A | A = Not Applicab | ole (no function | implemented) | | Fui | Function Description | | | | | | | | | DAC2_ | DAC2_SAFE_SW DAC2 Clock Input Safe Switching | | | | | | | | | | 0 = Ignore DAC2 Clock Inputs | | | | | | | | | | 1 = Use DAC2 Clock Inputs | | | | | | | | | | See page 31 for details of use. | | | | | | | | Figure 53 R39 - DAC2 Input Clock Control Register # **DIGITAL FILTER CHARACTERISTICS** | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------|-----------------|-----------------------------------------------|-----|---------|------| | ADC Filter | | <u>, </u> | | | • | | Passband | ± 0.05dB | | | 0.454fs | | | Passband Ripple | | | | 0.05 | dB | | Stopband | | 0.546fs | | | | | Stopband Attenuation | | -60 | | | dB | | Group Delay | | | 16 | | fs | | DAC Filter - 32kHz to 9 | 6kHz | | | | | | Passband | ± 0.1dB | | | 0.454fs | | | Passband Ripple | | | | 0.1 | dB | | Stopband | | 0.546fs | | | | | Stopband attenuation | f > 0.546fs | -50 | | | dB | | Group Delay | | | 10 | | Fs | | DAC Filter - 176.4kHz t | o 192kHz | | | | | | Passband | ± 0.1dB | | | 0.247fs | | | Passband Ripple | | | | 0.1 | dB | | Stopband | | 0.753fs | | | | | Stopband attenuation | f > 0.546fs | -50 | | | dB | | Group Delay | | | 10 | | Fs | # **DAC FILTER RESPONSES** Figure 54 DAC Digital Filter Frequency Response - 32kHz to 96kHz Figure 55 DAC Digital Filter Ripple -32kHz to 96kHz Figure 56 DAC Digital Filter Frequency Response - 176.4kHz to 192kHz Figure 57 DAC Digital Filter Ripple – 176.4kHz to 192kHz # **DIGITAL DE-EMPHASIS CHARACTERISTICS** Figure 58 De-Emphasis Frequency Response (44.1KHz) Figure 59 De-Emphasis Error (44.1KHz) ### **ADC FILTER RESPONSES** Figure 60 ADC Digital Filter Frequency Response Figure 61 ADC Digital Filter Ripple ## **ADC HIGH PASS FILTER** The WM8594 has a selectable digital high pass filter to remove DC offsets. The filter response is characterised by the following polynomial. $$H(z) = \frac{1 - z^{-1}}{1 - 0.9995z^{-1}}$$ Figure 62 ADC Highpass Filter Response ### **APPLICATIONS INFORMATION** #### RECOMMENDED EXTERNAL COMPONENTS #### Notes: - AGND and DGND should ideally share a continuous ground plane. Where this is not possible, it is recommended that AGND and DGND are connected as close to the WM8594 as possible. - Decoupling capacitors shown are very low-ESR, multilayer ceramic capacitors and should be placed as near to the WM8594 as possible. Equally good results may be obtained using 0.1μF ceramic capacitors near to the WM8594, with a 10μF electrolytic capacitor nearby. #### RECOMMENDED ANALOGUE LOW PASS FILTER Figure 63 Recommended Analogue Low Pass Filter (shown for VOUT1L/R) Note: See WAN0176 for AC coupling capacitor selection information. An external single pole RC filter is recommended (see Figure 63) if the device is driving a wideband amplifier. Other filter architectures may provide equally good results. #### **EXTENDED INPUT IMPEDANCE CONFIGURATION** Figure 64 Extended Input Impedance Configuration Note: See WAN0176 for AC coupling capacitor selection information. The input impedance to the WM8594 is specified in the Electrical Characteristics section beginning on p7, and is fixed across gain setting and signal routing options. If this input impedance is not enough for the intended application, an alternative input configuration (Figure 64) is possible. This configuration increases the input impedance to the WM8594 by $10k\Omega$ , but reduces the overall gain in the ADC and Bypass paths by -6dB. In order to compensate for this reduction in gain, +6dB of gain should be set in the ADC Input PGA (by using ADC\_AMP\_VOL[1:0]) and in the bypass PGA (by using PGAxx\_VOL[7:0]). #### **Examples:** - If a 2V<sub>RMS</sub> signal is applied to VIN1L and VIN1R and routed to VOUT1L and VOUT1R using PGA1L and PGA1R, then setting PGA1L\_VOL[7:0] and PGA1R\_VOL[7:0] =0x00 is necessary to see 2V<sub>RMS</sub> at VOUT1L and VOUT1R. - If a 2V<sub>RMS</sub> signal is applied to VIN1L and VIN1R and routed to ADCL and ADCR, then setting ADC\_AMP\_VOL[1:0]=10 is necessary to see 0dBFS at the ADC outputs. ### **RELEVANT APPLICATION NOTES** The following application notes, available from <a href="www.wolfsonmicro.com">www.wolfsonmicro.com</a>, may provide additional guidance for the use of the WM8594. ### **DEVICE PERFORMANCE:** WAN0129 - Decoupling and Layout Methodology for Wolfson DACs, ADCs and CODECs WAN0144 - Using Wolfson Audio DACs and CODECs with Noisy Supplies WAN0176 - AC Coupling Capacitor Selection ### **GENERAL**: WAN0108 - Moisture Sensitivity Classification and Plastic IC Packaging WAN0109 - ESD Damage in Integrated Circuits: Causes and Prevention WAN0158 - Lead-Free Solder Profiles for Lead-Free Components # **PACKAGE DIMENSIONS** | Symbols | Dimensions (mm) | | | | | | | |-----------------------|---------------------------------|----------|------|--|--|--|--| | | MIN | NOM | MAX | | | | | | Α | 1.20 | | | | | | | | <b>A</b> <sub>1</sub> | 0.05 | | 0.15 | | | | | | A <sub>2</sub> | 0.95 | 1.00 | 1.05 | | | | | | b | 0.17 | 0.22 | 0.27 | | | | | | С | 0.09 | | 0.20 | | | | | | D | | 9.00 BSC | | | | | | | D <sub>1</sub> | | 7.00 BSC | | | | | | | E | | 9.00 BSC | | | | | | | E <sub>1</sub> | | 7.00 BSC | | | | | | | е | | 0.50 BSC | | | | | | | L | 0.45 | 0.60 | 0.75 | | | | | | Θ | 0° | 3.5° | 7° | | | | | | | Tolerances of Form and Position | | | | | | | | ccc | 0.08 | | | | | | | | | | | | | | | | | REF: | JEDEC.95. MS-026 | | | | | | | - NOTES: A. ALL LINEAR DIMENSIONS ARE IN MILLIMETERS. B. THIS DRAWING IS SUBJECT TO CHANGE WITHOUT NOTICE. C. BODY DIMENSIONS DO NOT INCLUDE MOLD FLASH OR PROTRUSION, NOT TO EXCEED 0.25MM. D. MEETS JEDEC.95 MS-026, VARIATION = ABC. REFER TO THIS SPECIFICATION FOR FURTHER DETAILS. #### IMPORTANT NOTICE Wolfson Microelectronics plc ("Wolfson") products and services are sold subject to Wolfson's terms and conditions of sale, delivery and payment supplied at the time of order acknowledgement. Wolfson warrants performance of its products to the specifications in effect at the date of shipment. Wolfson 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 Wolfson to verify that the information is current. Testing and other quality control techniques are utilised to the extent Wolfson deems necessary to support its warranty. Specific testing of all parameters of each device is not necessarily performed unless required by law or regulation. In order to minimise risks associated with customer applications, the customer must use adequate design and operating safeguards to minimise inherent or procedural hazards. Wolfson is not liable for applications assistance or customer product design. The customer is solely responsible for its selection and use of Wolfson products. Wolfson is not liable for such selection or use nor for use of any circuitry other than circuitry entirely embodied in a Wolfson product. Wolfson's products are not intended for use in life support systems, appliances, nuclear systems or systems where malfunction can reasonably be expected to result in personal injury, death or severe property or environmental damage. Any use of products by the customer for such purposes is at the customer's own risk. Wolfson does not grant any licence (express or implied) under any patent right, copyright, mask work right or other intellectual property right of Wolfson covering or relating to any combination, machine, or process in which its products or services might be or are used. Any provision or publication of any third party's products or services does not constitute Wolfson's approval, licence, warranty or endorsement thereof. Any third party trade marks contained in this document belong to the respective third party owner. Reproduction of information from Wolfson datasheets is permissible only if reproduction is without alteration and is accompanied by all associated copyright, proprietary and other notices (including this notice) and conditions. Wolfson is not liable for any unauthorised alteration of such information or for any reliance placed thereon. Any representations made, warranties given, and/or liabilities accepted by any person which differ from those contained in this datasheet or in Wolfson's standard terms and conditions of sale, delivery and payment are made, given and/or accepted at that person's own risk. Wolfson is not liable for any such representations, warranties or liabilities or for any reliance placed thereon by any person. #### ADDRESS: Wolfson Microelectronics plo Westfield House 26 Westfield Road Edinburgh EH11 2QB Tel :: +44 (0)131 272 7000 Fax :: +44 (0)131 272 7001 Email:: sales@wolfsonmicro.com