

# Low Power Stereo ADC with PLL and TDM Interface

## **DESCRIPTION**

The WM8953 is a low power high performance stereo ADC designed for mobile handsets and other portable devices.

Four single-ended or differential input connections are provided, with up to 60dB of analogue gain in each input path. Stereo 24-bit sigma-delta ADCs provide hi-fi quality audio recording of microphones or line input. A programmable high pass filter is available in the ADC path for removing DC offsets and suppressing wind and other low frequency noise.

A low noise microphone bias with programmable current detect and short-circuit detect is provided.

A flexible digital audio interface supports most commonly-used clocking schemes. The audio interface supports TDM and tristate outputs allow multiple devices to share the same interface.

An integrated low power PLL provides support for most commonly-used audio sample rates.

The WM8953 is supplied in very small and thin 42-ball WCSP package, ideal for portable systems.

### **FEATURES**

- SNR 94dB ('A' weighted)
- THD -82dB at 48kHz, 3.3V
- Full stereo microphone / line input interface
- Low noise MICBIAS
- Low power consumption
- Full analogue and digital volume control
- PLL provides flexible clocking scheme
- 2-wire, 3-wire or 4-wire control
- Sample rates: 8, 11.025, 12, 16, 22.05, 24, 32, 44.1, 48kHz
- · GPIO functions available
- Digital supply: 1.71V 3.6V
- Analogue supply: 2.7V 3.6V
- W-CSP package (3.226 x 3.44 x 0.7mm, 0.5mm pitch)

### **APPLICATIONS**

- · Multimedia phones
- General purpose low power audio ADC



# **TABLE OF CONTENTS**

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| FEATURES                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                              |
| APPLICATIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                |
| TABLE OF CONTENTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                |
| BLOCK DIAGRAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                |
| PIN CONFIGURATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                |
| ORDERING INFORMATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                |
| PIN DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                |
| ABSOLUTE MAXIMUM RATINGS                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                |
| RECOMMENDED OPERATING CONDITIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                |
| THERMAL PERFORMANCE                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                |
| ELECTRICAL CHARACTERISTICS                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                |
| TERMINOLOGY                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                |
| TYPICAL POWER CONSUMPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 12<br>19                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                |
| PSRR PERFORMANCE                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                |
| AUDIO SIGNAL PATHS                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                |
| SIGNAL TIMING REQUIREMENTS                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                |
| SYSTEM CLOCK TIMING                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                |
| AUDIO INTERFACE TIMING – MASTER MODE                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                |
| AUDIO INTERFACE TIMING – SLAVE MODEAUDIO INTERFACE TIMING – TDM MODE                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                |
| CONTROL INTERFACE TIMING – 1DW MODE                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                |
| CONTROL INTERFACE TIMING – 2-WIRE MODE                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                |
| CONTROL INTERFACE TIMING – 4-WIRE MODE                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                |
| INTERNAL POWER ON RESET CIRCUIT                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                |
| DEVICE DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 25                                                             |
| INTRODUCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 25                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 25<br>25                                                       |
| INTRODUCTIONINPUT SIGNAL PATH                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 25<br>26<br>26                                                 |
| INTRODUCTIONINPUT SIGNAL PATHANALOGUE TO DIGITAL CONVERTER (ADC)                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                |
| INTRODUCTIONINPUT SIGNAL PATHANALOGUE TO DIGITAL CONVERTER (ADC)DIGITAL AUDIO PATHS                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                |
| INPUT SIGNAL PATH                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                |
| INTRODUCTION INPUT SIGNAL PATH ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE DIGITAL AUDIO INTERFACE CONTROL                                                                                                                                                                                                                                                                                           |                                                                |
| INTRODUCTION INPUT SIGNAL PATH ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES                                                                                                                                                                                                                                                                 | 25<br>25<br>26<br>36<br>39<br>40<br>41<br>56                   |
| INTRODUCTION. INPUT SIGNAL PATH. ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE. DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES. CONTROL INTERFACE                                                                                                                                                                                                                                           | 25<br>25<br>26<br>36<br>39<br>40<br>41<br>56<br>63             |
| INTRODUCTION INPUT SIGNAL PATH ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES CONTROL INTERFACE POWER MANAGEMENT                                                                                                                                                                                                                              | 25<br>25<br>26<br>36<br>39<br>40<br>41<br>56<br>63<br>75       |
| INTRODUCTION INPUT SIGNAL PATH ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING. GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES CONTROL INTERFACE POWER MANAGEMENT POWER DOMAINS.                                                                                                                                                                                                              | 25<br>25<br>26<br>36<br>39<br>40<br>41<br>56<br>63<br>75<br>75 |
| INTRODUCTION INPUT SIGNAL PATH ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES CONTROL INTERFACE POWER MANAGEMENT POWER DOMAINS REGISTER MAP                                                                                                                                                                                                   | 25<br>26<br>36<br>39<br>40<br>41<br>56<br>63<br>75<br>79       |
| INTRODUCTION. INPUT SIGNAL PATH. ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE. DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES. CONTROL INTERFACE. POWER MANAGEMENT POWER DOMAINS. REGISTER MAP REGISTER BITS BY ADDRESS.                                                                                                                                                                   | 25 26 26 36 36 40 41 56 67 75 81                               |
| INTRODUCTION INPUT SIGNAL PATH ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING. GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE DIGITAL AUDIO INTERFACE CONTROL. CLOCKING AND SAMPLE RATES. CONTROL INTERFACE POWER MANAGEMENT POWER DOMAINS REGISTER MAP REGISTER BITS BY ADDRESS DIGITAL FILTER CHARACTERISTICS                                                                                                                                        | 25 26 26 36 36 39 40 41 56 63 67 75 81 82                      |
| INTRODUCTION INPUT SIGNAL PATH ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING. GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE DIGITAL AUDIO INTERFACE CONTROL. CLOCKING AND SAMPLE RATES. CONTROL INTERFACE POWER MANAGEMENT POWER DOMAINS REGISTER MAP REGISTER BITS BY ADDRESS DIGITAL FILTER CHARACTERISTICS ADC FILTER RESPONSES                                                                                                                   | 25 26 26 36 36 39 40 41 56 63 75 79 81 82                      |
| INTRODUCTION. INPUT SIGNAL PATH. ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS. THERMAL SENSING. GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE. DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES. CONTROL INTERFACE POWER MANAGEMENT. POWER DOMAINS. REGISTER MAP REGISTER BITS BY ADDRESS. DIGITAL FILTER CHARACTERISTICS. ADC FILTER RESPONSES.                                                                                                           | 25 26 26 36 36 39 40 41 56 67 75 81 82 82 97                   |
| INTRODUCTION. INPUT SIGNAL PATH. ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE. DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES CONTROL INTERFACE. POWER MANAGEMENT POWER DOMAINS. REGISTER MAP REGISTER BITS BY ADDRESS. DIGITAL FILTER CHARACTERISTICS ADC FILTER RESPONSES APPLICATIONS INFORMATION                                                                                       | 25 26 26 36 36 39 40 41 56 67 75 79 81 82 84 97                |
| INTRODUCTION. INPUT SIGNAL PATH                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 25 26 26 36 36 39 40 41 56 63 67 75 79 81 82 84 97             |
| INTRODUCTION. INPUT SIGNAL PATH. ANALOGUE TO DIGITAL CONVERTER (ADC) DIGITAL AUDIO PATHS THERMAL SENSING. GENERAL PURPOSE INPUT/OUTPUT DIGITAL AUDIO INTERFACE DIGITAL AUDIO INTERFACE CONTROL CLOCKING AND SAMPLE RATES. CONTROL INTERFACE POWER MANAGEMENT POWER DOMAINS. REGISTER MAP REGISTER BITS BY ADDRESS. DIGITAL FILTER CHARACTERISTICS ADC FILTER RESPONSES. ADC HIGH PASS FILTER RESPONSES. APPLICATIONS INFORMATION RECOMMENDED EXTERNAL COMPONENTS. PACKAGE DIMENSIONS. | 25 26 26 36 36 39 40 41 56 63 67 75 81 82 82 82 97             |
| INTRODUCTION. INPUT SIGNAL PATH                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 25 26 26 36 36 39 40 41 56 67 75 79 81 81 82 82 97             |



# **BLOCK DIAGRAM**



# **PIN CONFIGURATION**



**TOP VIEW** 

# **ORDERING INFORMATION**

| ORDER CODE   | TEMPERATURE RANGE | PACKAGE                                   | MOISTURE<br>SENSITIVITY LEVEL | PEAK SOLDERING<br>TEMPERATURE |
|--------------|-------------------|-------------------------------------------|-------------------------------|-------------------------------|
| WM8953ECS/RV | -40°C to +85°C    | 42-ball W-CSP<br>(Pb-free, Tape and reel) | MSL3                          | 260°C                         |

Note:

Reel quantity = 3500

# **PIN DESCRIPTION**

| PIN NO             | NAME        | TYPE                   | DESCRIPTION                                              |
|--------------------|-------------|------------------------|----------------------------------------------------------|
| A2                 | MICBIAS     | Analogue Output        | Microphone bias                                          |
| D3                 | LIN1        | Analogue Input         | Left channel single-ended MIC input /                    |
|                    |             |                        | Left channel negative differential MIC input             |
| C5                 | LIN2        | Analogue Input         | Left channel line input /                                |
|                    |             |                        | Left channel positive differential MIC input             |
| C6                 | LIN3 / GPI7 | Analogue Input /       | Left channel line input /                                |
|                    |             | Digital Input          | Left channel negative differential MIC input /           |
|                    |             |                        | Accessory or button detect input pin                     |
| B6                 | LIN4        | Analogue Input         | Left channel line input /                                |
|                    |             |                        | Left channel positive differential MIC input /           |
| D4                 | RIN1        | Analogue Input         | Right channel single-ended MIC input /                   |
|                    |             |                        | Right channel negative differential MIC input            |
| D6                 | RIN2        | Analogue Input         | Right channel line input /                               |
|                    |             |                        | Right channel positive differential MIC input            |
| D5                 | RIN3 / GPI8 | Analogue Input /       | Right channel line input /                               |
|                    |             | Digital Input          | Right channel negative differential MIC input /          |
|                    |             |                        | Accessory or button detect input pin                     |
| E5                 | RIN4        | Analogue Input         | Left channel line input /                                |
|                    |             |                        | Left channel positive differential MIC input /           |
| F6                 | DCVDD       | Supply                 | Digital core supply                                      |
| E6                 | DGND        | Supply                 | Digital ground (Return path for both DCVDD and DBVDD)    |
| G6                 | DBVDD       | Supply                 | Digital buffer (I/O) supply                              |
| A6                 | AVDD        | Supply                 | Analogue supply                                          |
| A3, B1,<br>B3      | AGND        | Supply                 | Analogue ground (Return path for AVDD)                   |
| F5                 | MCLK        | Digital Input          | Master clock                                             |
| G5                 | BCLK        | Digital Input / Output | Audio interface bit clock                                |
| E4                 | ADCLRC      | Digital Input / Output | Audio interface ADC left / right clock                   |
| F4                 | ADCDAT      | Digital Output         | ADC digital audio data                                   |
| E2                 | MODE        | Digital Input          | Selects 2-wire or 3/4 -wire control                      |
| F2                 | CSB / ADDR  | Digital Input          | 3/4 -wire chip select or 2-wire address select           |
| F1                 | SCLK        | Digital Input          | Control interface clock input                            |
| E3                 | SDIN        | Digital Input / Output | Control interface data input / 2-wire acknowledge output |
| C3                 | VMID        | Analogue Output        | Midrail voltage decoupling capacitor                     |
| G2                 | GPIO3       | Digital Input / Output | GPIO pin                                                 |
| G3                 | GPIO4       | Digital Input / Output | GPIO pin                                                 |
| G1                 | GPIO5       | Digital Input / Output | GPIO pin                                                 |
| A1, A4,            | DNC         | Do Not Connect         |                                                          |
| A5, B2,            |             |                        |                                                          |
| B4, B5,<br>C1, C2, |             |                        |                                                          |
| C1, C2,<br>C4, D1, |             |                        |                                                          |
| D2, E1,            |             |                        |                                                          |
| F3, G4             |             |                        |                                                          |



## **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 ^{\circ}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         |
|---------------------------------------------|------------|-------------|
| Supply voltages                             | -0.3V      | +4.5V       |
| Voltage range digital inputs                | DGND -0.3V | DBVDD +0.3V |
| Voltage range analogue inputs               | AGND -0.3V | AVDD +0.3V  |
| Operating temperature range, T <sub>A</sub> | -40°C      | +85°C       |
| Junction temperature, T <sub>JMAX</sub>     | -40°C      | +150°C      |
| Storage temperature after soldering         | -65°C      | +150°C      |

### RECOMMENDED OPERATING CONDITIONS

| PARAMETER                     | SYMBOL     | MIN  | TYP | MAX | UNIT |
|-------------------------------|------------|------|-----|-----|------|
| Digital supply range (Core)   | DCVDD      | 1.71 |     | 3.6 | V    |
| Digital supply range (Buffer) | DBVDD      | 1.71 |     | 3.6 | V    |
| Analogue supply range         | AVDD       | 2.7  |     | 3.6 | V    |
| Ground                        | DGND, AGND |      | 0   |     | V    |

## Notes

- 1. Analogue and digital grounds must always be within 0.3V of each other.
- 2. All digital and analogue supplies are completely independent from each other (i.e. not internally connected).
- 3. DCVDD must be less than or equal to AVDD.
- 4. DCVDD must be less than or equal to DBVDD.



## THERMAL PERFORMANCE

Thermal analysis should be performed in the intended application to prevent the WM8953 from exceeding maximum junction temperature. Several contributing factors affect thermal performance most notably the physical properties of the mechanical enclosure, location of the device on the PCB in relation to surrounding components and the number of PCB layers. Connecting the GND balls through thermal vias and into a large ground plane will aid heat extraction.

Three main heat transfer paths exist to surrounding air as illustrated below in Figure 1:

- Package top to air (radiation).
- Package bottom to PCB (radiation).
- Package balls to PCB (conduction).



Figure 1 Heat Transfer Paths

The temperature rise  $T_R$  is given by  $T_R = P_D * \Theta_{JA}$ 

- P<sub>D</sub> is the power dissipated in the device.
- $\Theta_{JA}$  is the thermal resistance from the junction of the die to the ambient temperature and is therefore a measure of heat transfer from the die to surrounding air.  $\Theta_{JA}$  is determined with reference to JEDEC standard JESD51-9.

The junction temperature  $T_J$  is given by  $T_J$  =  $T_A$  + $T_R$ , where  $T_A$  is the ambient temperature.

| PARAMETER                      | SYMBOL        | MIN | TYP | MAX | UNIT |
|--------------------------------|---------------|-----|-----|-----|------|
| Operating temperature range    | TA            | -40 |     | 85  | °C   |
| Operating junction temperature | TJ            | -40 |     | 100 | °C   |
| Thermal Resistance             | $\Theta_{JA}$ |     | 43  |     | °C/W |

# **ELECTRICAL CHARACTERISTICS**

## **Test Conditions**

DCVDD = 1.8V, DBVDD = 3.3V, AVDD = 3.3V,  $T_A$  = +25°C, 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                                                                 | TEST                                                                                                           | CONDITIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | MIN | TYP      | MAX | UNIT        |  |
|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|-----|-------------|--|
| Analogue Input Pin Maximum Signal Levels (LIN1, LIN2, LIN3, LIN4, RIN1, RIN2, RIN3, RIN4) |                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |          |     |             |  |
| Maximum Full-Scale PGA<br>Input Signal Level<br>Note 1; Note 2; Note 3                    | Single-ended PGA<br>input on LIN1, LIN3,<br>RIN1 or RIN3, output<br>to INMIXL or INMIXR                        | LINI LINE ON THE ONE OF THE ONE O |     | 1.0<br>0 |     | Vrms<br>dBV |  |
| 1,166 2,166 2                                                                             | Differential PGA input<br>on LIN1/LIN2,<br>LIN3/LIN4, RIN1/RIN2<br>or RIN3/RIN4, output<br>to INMIXL or INMIXR | RRH OF RRD CHB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     | 1.0<br>0 |     | Vrms<br>dBV |  |
| Maximum Full-Scale Line<br>Input Signal Level<br>Note 1; Note 2; Note 3                   | Line input on LIN2,<br>LIN4, RIN2 or RIN4 to<br>INMIXL or INMIXR                                               | LIN2, LIN4,<br>RIN2 or<br>RIN4 INMIXL or INMIXR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     | 1.0      |     | Vrms<br>dBV |  |

#### Notes

- 1. Maximum full scale signal changes in proportion to AVDD (AVDD/3.3).
- 2. When mixing input PGA outputs and line inputs, the total signal must not exceed 1Vrms (0dBV).
- 3. A 1.0Vrms differential signal equates to 0.5Vrms/-6dBV per input.



## **Test Conditions**

DCVDD = 1.8V, DBVDD = 3.3V, AVDD = 3.3V,  $T_A$  = +25°C, 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                             | TEST C                                   | ONDITIONS                       | MIN | TYP | MAX | UNIT |
|---------------------------------------|------------------------------------------|---------------------------------|-----|-----|-----|------|
| Analogue Input Pin Impe               | edances (LIN1, LIN2, LIN3, L             | IN4, RIN1, RIN2, RIN3, RIN4)    |     |     |     |      |
| PGA Input Resistance                  | LIN1, LIN3, RIN1 or RIN3                 |                                 |     | 57  |     | kΩ   |
|                                       | (PGA Gain = -16.5dB)                     | Rin                             |     |     |     |      |
| Note: this will be seen in            | LIN1, LIN3, RIN1 or RIN3                 | LIN1, LIN3,<br>RIN1 or RIN3     |     | 33  |     | kΩ   |
| parallel with the resistance of other | (PGA Gain = 0dB)                         | LIN12, LIN13,<br>RIN12 or RIN34 |     |     |     |      |
| enabled input paths                   | LIN1, LIN3, RIN1 or RIN3                 |                                 |     | 2   |     | kΩ   |
| from the same pin                     | (PGA Gain = +30dB)                       |                                 |     |     |     |      |
| ·                                     | LIN2, LIN4, RIN2 or RIN4                 | LIN2, LIN4,                     |     | 65  |     | kΩ   |
|                                       | (Constant for all gains)                 | RIN2 or RIN4  + LIN12, LIN13,   |     |     |     |      |
|                                       |                                          | RIN12 or RIN34                  |     |     |     |      |
| Line Input Resistance                 | LIN2 or RIN2 to INMIXL or INMIXR (-12dB) | LIN2 or<br>RIN2 RIN             |     | 60  |     | kΩ   |
| Note: this will be seen in            | LIN2 or RIN2 to INMIXL or                |                                 |     | 15  |     | kΩ   |
| parallel with the                     | INMIXR (0dB)                             | INMIXR (0dB)                    |     |     |     | Kab  |
| resistance of other                   | LIN2 or RIN2 to INMIXL or                |                                 |     | 7.5 |     | kΩ   |
| enabled input paths from the same pin | INMIXR (+6dB)                            |                                 |     |     |     |      |
| Input Capacitance                     | All analogue input pins                  |                                 |     | 10  |     | pF   |

## **Test Conditions**

DCVDD = 1.8V, DBVDD = 3.3V, AVDD = 3.3V,  $T_A$  = +25°C, 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                                               | TEST CONDITIONS                                 | MIN | TYP   | MAX | UNIT |  |  |
|-------------------------------------------------------------------------|-------------------------------------------------|-----|-------|-----|------|--|--|
| Input Programmable Gain Amplifiers (PGAs) LIN12, LIN34, RIN12 and RIN34 |                                                 |     |       |     |      |  |  |
| Minimum Programmable Gain                                               |                                                 |     | -16.5 |     | dB   |  |  |
| Maximum Programmable Gain                                               |                                                 |     | 30    |     | dB   |  |  |
| Programmable Gain Step Size                                             | Guaranteed monotonic                            |     | 1.5   |     | dB   |  |  |
| Mute Attenuation                                                        | Inputs disconnected                             |     | 90    |     | dB   |  |  |
| Common Mode Rejection Ratio                                             | Single PGA in differential mode, gain = +30dB   |     | 60    |     | dB   |  |  |
| (1kHz input)                                                            | Single PGA in differential mode, gain = 0dB     |     | 50    |     |      |  |  |
|                                                                         | Single PGA in differential mode, gain = -16.5dB |     | 50    |     |      |  |  |
| Input Mixers INMIXL and INMIXR                                          |                                                 |     |       |     |      |  |  |
| Minimum Programmable Gain                                               | PGA Outputs to INMIXL and INMIXR                |     | 0     |     | dB   |  |  |
| Maximum Programmable Gain                                               | PGA Outputs to INMIXL and INMIXR                |     | +30   |     | dB   |  |  |
| Programmable Gain Step Size                                             | PGA Outputs to INMIXL and INMIXR                |     | 30    |     | dB   |  |  |
| Minimum Programmable Gain                                               | Line Inputs to INMIXL and INMIXR                |     | -12   |     | dB   |  |  |
| Maximum Programmable Gain                                               | Line Inputs to INMIXL and INMIXR                |     | +6    |     | dB   |  |  |
| Programmable Gain Step Size                                             | Line Inputs to INMIXL and INMIXR                |     | 3     |     | dB   |  |  |
| Mute attenuation                                                        |                                                 |     | 95    |     | dB   |  |  |



## **Test Conditions**

DCVDD = 1.8V, DBVDD = 3.3V, AVDD = 3.3V,  $T_A$  = +25°C, 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER              |                            | TEST CONDITIONS                                         | MIN | TYP  | MAX | UNIT |
|------------------------|----------------------------|---------------------------------------------------------|-----|------|-----|------|
| ADC Input Path Perform | ance                       |                                                         |     |      |     |      |
| SNR (A-weighted)       | Line inputs to             |                                                         | 84  | 94   |     | dB   |
| THD (-1dBFS input)     | ADC via INMIXL             | 4                                                       |     | -84  | -75 | dB   |
| THD+N (-1dBFS input)   | and INMIXR,<br>AVDD = 3.3V | Ligor                                                   |     | -82  | -73 | dB   |
| Crosstalk (L/R)        | 7.755 0.07                 | RI2 ADC I                                               |     | -100 |     | dB   |
| AVDD PSRR (217Hz)      |                            | or ADCR                                                 |     | 45   |     | dB   |
| DCVDD PSRR (217Hz)     |                            | INMIXL or INMIXR                                        |     | 80   |     | dB   |
| SNR (A-weighted)       | Line inputs to             |                                                         |     | 93   |     | dB   |
| THD (-1dBFS input)     | ADC via INMIXL             |                                                         |     | -78  |     | dB   |
| THD+N (-1dBFS input)   | and INMIXR,<br>AVDD = 2.7V |                                                         |     | -76  |     | dB   |
| SNR (A-weighted)       | Input PGAs to              |                                                         | 84  | 94   |     | dB   |
| THD (-1dBFS input)     | ADC via INMIXL             | LIN1, LIN3, OdB INMIXL or                               |     | -84  | -75 | dB   |
| THD+N (-1dBFS input)   | or INMIXR,<br>AVDD = 3.3V  | INMIXR ADCL or                                          |     | -82  | -73 | dB   |
| Crosstalk (L/R)        |                            | + ADCR                                                  |     | -100 |     | dB   |
| AVDD PSRR (217Hz)      |                            | LIN2, LIN4, / LIN12, LIN34, RIN2 or RIN4 RIN12 or RIN34 |     | 45   |     | dB   |
| SNR (A-weighted)       | Input PGAs to              | (Single-ended or<br>differential mode)                  |     | 92   |     | dB   |
| THD (-1dBFS input)     | ADC via INMIXL             |                                                         |     | -78  |     | dB   |
| THD+N (-1dBFS input)   | or INMIXR,<br>AVDD = 2.7V  |                                                         |     | -76  |     | dB   |



## **Test Conditions**

DCVDD = 1.8V, DBVDD = 3.3V, AVDD = 3.3V,  $T_A$  = +25°C, 1kHz signal, fs = 48kHz, PGA gain = 0dB, 24-bit audio data unless otherwise stated.

| PARAMETER                                                                             | TEST CONDITIONS                     | MIN                                   | TYP       | MAX                                   | UNIT   |
|---------------------------------------------------------------------------------------|-------------------------------------|---------------------------------------|-----------|---------------------------------------|--------|
| Analogue Reference Levels                                                             |                                     |                                       |           |                                       |        |
| VMID Midrail Reference Voltage                                                        |                                     | -3%                                   | AVDD/2    | +3%                                   | V      |
| Microphone Bias                                                                       |                                     |                                       |           |                                       |        |
| Bias Voltage                                                                          | 3mA load current<br>MBSEL=0         | -5%                                   | 0.9×AVDD  | +5%                                   | V      |
|                                                                                       | 3mA load current<br>MBSEL=1         | -5%                                   | 0.65×AVDD | +5%                                   | V      |
| Bias Current Source                                                                   |                                     |                                       |           | 3                                     | mA     |
| Output Noise Density                                                                  | 1kHz to 20kHz                       |                                       | 100       |                                       | nV/√Hz |
| AVDD PSRR (217Hz)                                                                     | 100mV pk-pk @217Hz<br>on AVDD       |                                       | 45        |                                       | dB     |
| Digital Input / Output                                                                |                                     |                                       |           |                                       |        |
| Input HIGH Level                                                                      |                                     | 0.7×DBVDD                             |           |                                       | V      |
| Input LOW Level                                                                       |                                     |                                       |           | 0.3×DBVDD                             | V      |
| Note that digital input pins should not be Internal pull-up/pull-down resistors may b |                                     | GPIO5 if require                      | d.        |                                       |        |
| Output HIGH Level                                                                     | I <sub>OL</sub> =1mA                | 0.9×DBVDD                             |           |                                       | V      |
| Output LOW Level                                                                      | I <sub>OH</sub> =-1mA               |                                       |           | 0.1×DBVDD                             | V      |
| Input capacitance                                                                     |                                     |                                       | 10        |                                       | pF     |
| Input leakage                                                                         |                                     | -0.9                                  |           | 0.9                                   | uA     |
| PLL                                                                                   | -                                   |                                       | 1         | 1                                     | I      |
| Input Frequency                                                                       | PRESCALE = 0b                       | 7.7                                   |           | 18                                    | MHz    |
|                                                                                       | PRESCALE = 1b                       | 14.4                                  |           | 36                                    | MHz    |
| Lock time                                                                             |                                     |                                       | 200       |                                       | us     |
| GPIO                                                                                  |                                     | •                                     | •         | •                                     |        |
| Clock output duty cycle                                                               | SYSCLK=MCLK;                        | 35                                    |           | 65                                    | %      |
| (Integer OPCLKDIV)                                                                    | OPCLKDIV=0000                       |                                       |           |                                       |        |
|                                                                                       | SYSCLK=MCLK;<br>OPCLKDIV=1000       | 45                                    |           | 55                                    | %      |
|                                                                                       | SYSCLK=PLL output;<br>OPCLKDIV=0000 | 45                                    |           | 55                                    | %      |
|                                                                                       | SYSCLK=PLL output;<br>OPCLKDIV=1000 | 45                                    |           | 55                                    | %      |
| Clock output duty cycle (Non-integer OPCLKDIV)                                        | SYSCLK=MCLK;<br>OPCLKDIV=0100       | 33                                    |           | 66                                    | %      |
| (i.e., i.i.e.go) or our corre                                                         | SYSCLK=PLL output; OPCLKDIV=0100    | 33                                    |           | 66                                    | %      |
| Interrupt response time for accessory /                                               | Input de-bounced                    | 2 <sup>21</sup> / f <sub>SYSCLK</sub> |           | 2 <sup>22</sup> / f <sub>SYSCLK</sub> | s      |
| button detect                                                                         | Input de-bounced TOCLKSEL=1         | 2 <sup>19</sup> / f <sub>SYSCLK</sub> |           | 2 <sup>20</sup> / f <sub>SYSCLK</sub> | S      |
|                                                                                       | Input not de-bounced                |                                       | 0         |                                       | s      |



#### **TERMINOLOGY**

 Signal-to-Noise Ratio (dB) – SNR is a measure of the difference in level between the maximum theoretical full scale output signal and the output with no input signal applied.

- 2. Total Harmonic Distortion (dB) THD is the level of the rms value of the sum of harmonic distortion products relative to the amplitude of the measured output signal.
- 3. Total Harmonic Distortion plus Noise (dB) THD+N is the level of the rms value of the sum of harmonic distortion products plus noise in the specified bandwidth relative to the amplitude of the measured output signal.
- 4. Crosstalk (L/R) (dB) left-to-right and right-to-left channel crosstalk is the measured signal level in the idle channel at the test signal frequency relative to the signal level at the output of the active channel. The active channel is configured and supplied with an appropriate input signal to drive a full scale output, with signal measured at the output of the associated idle channel. For example, measured signal level on the output of the idle right channel (RIN2 to ADCR) with a full scale signal level at the output of the active left channel (LIN1 to ADCL).
- 5. Multi-Path Channel Separation (dB) is the measured signal level in the idle path at the test signal frequency relative to the signal level at the output of the active path. The active path is configured and supplied with an appropriate input signal to drive a full scale output, with signal measured at the output of the specified idle path.
- 6. 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 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.
- 7. Mute Attenuation This is a measure of the difference in level between the full scale output signal and the output with mute applied.



# **TYPICAL POWER CONSUMPTION**

| Mode                                              | Other settings |     |     |     | IAVDD | IDBVDD | IDCVDD | Total Power |
|---------------------------------------------------|----------------|-----|-----|-----|-------|--------|--------|-------------|
|                                                   | Other settings | (V) | (V) | (V) | (mA)  | (mA)   | (mA)   | (mW)        |
| Standby/Sleep                                     |                |     |     |     |       |        |        |             |
|                                                   |                | 2.7 | 1.8 | 1.8 | 0.028 | 0.000  | 0.000  | 0.075       |
| OFF (default state at power-up)                   | No Clocks      | 3.0 | 2.5 | 2.5 | 0.029 | 0.000  | 0.000  | 0.087       |
| Of T (default state at power-up)                  | NO CIOCKS      | 3.3 | 3.3 | 3.3 | 0.030 | 0.000  | 0.000  | 0.099       |
|                                                   |                | 3.6 | 3.6 | 3.6 | 0.031 | 0.000  | 0.000  | 0.114       |
|                                                   |                | 2.7 | 1.8 | 1.8 | 0.008 | 0.000  | 0.000  | 0.020       |
| OFF (thermal sensor disabled)                     | No Clocks      | 3.0 | 2.5 | 2.5 | 0.008 | 0.000  | 0.000  | 0.024       |
| OTT (ITETHIAL SELISOL UISABIEU)                   | NO CIOCKS      | 3.3 | 3.3 | 3.3 | 0.009 | 0.000  | 0.000  | 0.029       |
|                                                   |                | 3.6 | 3.6 | 3.6 | 0.009 | 0.000  | 0.000  | 0.035       |
|                                                   | With Clocks    | 2.7 | 1.8 | 1.8 | 0.087 | 0.004  | 0.459  | 1.068       |
| SLEEP (VMID enabled, thermal sensor anabled)      |                | 3.0 | 2.5 | 2.5 | 0.096 | 0.008  | 0.694  | 2.044       |
| OLLET (VIIII) CHABICO, ITICITIAI SCIISOI ATABICO) |                | 3.3 | 3.3 | 3.3 | 0.106 | 0.014  | 1.025  | 3.780       |
|                                                   |                | 3.6 | 3.6 | 3.6 | 0.117 | 0.017  | 1.162  | 4.667       |
| ADC Record                                        |                |     |     |     |       |        |        |             |
|                                                   |                | 2.7 | 1.8 | 1.8 | 5.272 | 0.023  | 2.285  | 18.389      |
| Stereo Line Record                                | fs=44.1kHz     | 3.0 | 2.5 | 2.5 | 5.603 | 0.039  | 3.317  | 25.199      |
| (L/RIN2 to INMIXL/R bypassing PGA)                | 15-44. IKHZ    | 3.3 | 3.3 | 3.3 | 5.927 | 0.060  | 4.728  | 35.358      |
|                                                   |                | 3.6 | 3.6 | 3.6 | 6.261 | 0.063  | 5.295  | 41.830      |
|                                                   |                | 2.7 | 1.8 | 1.8 | 5.125 | 0.017  | 0.758  | 15.233      |
| Stereo Line Record                                | fs=8kHz        | 3.0 | 2.5 | 2.5 | 5.434 | 0.027  | 1.123  | 19.177      |
| (L/RIN2 to INMIXL/R bypassing PGA)                | 13-0KI IZ      | 3.3 | 3.3 | 3.3 | 5.738 | 0.061  | 1.634  | 24.528      |
|                                                   |                | 3.6 | 3.6 | 3.6 | 6.053 | 0.062  | 1.841  | 28.642      |

## Notes:

- 1. All figures are quoted at  $T_A = +25$ °C
- 2. All figures are quoted as quiescent current unless otherwise stated.

# **PSRR PERFORMANCE**

DCVDD - Line-In to ADC



AVDD - Line-In to ADC



AVDD - MICBIAS



Note: All figures based on 100mVp-p injected on the supply at the relevant test frequency.



# **AUDIO SIGNAL PATHS**



# **SIGNAL TIMING REQUIREMENTS**

# **SYSTEM CLOCK TIMING**



Figure 2 System Clock Timing Requirements

## **Test Conditions**

DCVDD=1.8V, DBVDD=AVDD=3.3V, DGND=AGND=0V, T<sub>A</sub> = +25°C

| PARAMETER                       | SYMBOL             | CONDITIONS                               | MIN   | TYP | MAX   | UNIT |
|---------------------------------|--------------------|------------------------------------------|-------|-----|-------|------|
| System Clock Timing Information |                    |                                          |       |     |       |      |
| MCLK cycle time                 | T <sub>MCLKY</sub> |                                          | 33.33 |     |       | ns   |
| MCLK duty cycle                 |                    | = T <sub>MCLKH</sub> /T <sub>MCLKL</sub> | 60:40 |     | 40:60 |      |



# **AUDIO INTERFACE TIMING - MASTER MODE**



Figure 3 Digital Audio Data Timing - Master Mode (see Control Interface)

## **Test Conditions**

DCVDD=1.8V, DBVDD=AVDD=3.3V, DGND=AGND=0V,  $T_A$ =+25°C, Master Mode, fs=48kHz, MCLK=256fs, 24-bit data, unless otherwise stated.

| PARAMETER                                       | SYMBOL           | MIN | TYP | MAX | UNIT |
|-------------------------------------------------|------------------|-----|-----|-----|------|
| Audio Data Timing Information                   |                  |     |     |     |      |
| ADCLRC propagation delay from BCLK falling edge | t <sub>DL</sub>  |     |     | 20  | ns   |
| ADCDAT propagation delay from BCLK falling edge | t <sub>DDA</sub> |     |     | 20  | ns   |

# **AUDIO INTERFACE TIMING - SLAVE MODE**



Figure 4 Digital Audio Data Timing - Slave Mode

## **Test Conditions**

DCVDD=1.8V, DBVDD=AVDD=3.3V, DGND=AGND=0V,  $T_A$ =+25°C, Slave Mode, fs=48kHz, MCLK=256fs, 24-bit data, unless otherwise stated.

| PARAMETER                                       | SYMBOL            | MIN | TYP | MAX | UNIT |
|-------------------------------------------------|-------------------|-----|-----|-----|------|
| Audio Data Input Timing Information             |                   |     |     |     |      |
| BCLK cycle time                                 | t <sub>BCY</sub>  | 50  |     |     | ns   |
| BCLK pulse width high                           | t <sub>BCH</sub>  | 20  |     |     | ns   |
| BCLK pulse width low                            | t <sub>BCL</sub>  | 20  |     |     | ns   |
| ADCLRC set-up time to BCLK rising edge          | t <sub>LRSU</sub> | 20  |     |     | ns   |
| ADCLRC hold time from rising edge               | t <sub>LRH</sub>  | 10  |     |     | ns   |
| ADCDAT propagation delay from BCLK falling edge | t <sub>DD</sub>   |     |     | 20  | ns   |

# Note:

BCLK period should always be greater than or equal to MCLK period.



## **AUDIO INTERFACE TIMING - TDM MODE**

In TDM mode, it is important that two ADC devices to not attempt to drive the ADCDAT pin simultaneously. The timing of the WM8953 ADCDAT tri-stating at the start and end of the data transmission is described in Figure 5 and the table below.



Figure 5 Digital Audio Data Timing - TDM Mode

### **Test Conditions**

AVDD=3.3V, DGND=AGND=0V,  $T_A$ =+25°C, Master Mode, fs=48kHz, MCLK=256fs, 24-bit data, unless otherwise stated.

| PARAMETER                                  | CONDITIONS               | MIN | TYP | MAX | UNIT |
|--------------------------------------------|--------------------------|-----|-----|-----|------|
| Audio Data Timing Information              |                          |     |     |     |      |
| ADCDAT setup time from BCLK falling edge   | DCVDD =<br>DBVDD = 3.6V  |     | 5   |     | ns   |
|                                            | DCVDD =<br>DBVDD = 1.71V |     | 15  |     | ns   |
| ADCDAT release time from BCLK falling edge | DCVDD =<br>DBVDD = 3.6V  |     | 5   |     | ns   |
|                                            | DCVDD =<br>DBVDD = 1.71V |     | 15  |     | ns   |

## **CONTROL INTERFACE TIMING – 2-WIRE MODE**

2-wire mode is selected by connecting the MODE pin low.



Figure 6 Control Interface Timing – 2-Wire Serial Control Mode

### **Test Conditions**

DCVDD=1.8V, DBVDD=AVDD=3.3V, DGND=AGND=0V,  $T_A$ =+25°C, Slave Mode, fs=48kHz, MCLK = 256fs, 24-bit data, unless otherwise stated.

| PARAMETER                                     | SYMBOL          | MIN | TYP | MAX | UNIT |  |  |
|-----------------------------------------------|-----------------|-----|-----|-----|------|--|--|
| Program Register Input Information            |                 |     |     |     |      |  |  |
| SCLK Frequency                                |                 |     |     | 526 | kHz  |  |  |
| SCLK Low Pulse-Width                          | t <sub>1</sub>  | 1.3 |     |     | us   |  |  |
| SCLK High Pulse-Width                         | t <sub>2</sub>  | 600 |     |     | ns   |  |  |
| Hold Time (Start Condition)                   | t <sub>3</sub>  | 600 |     |     | ns   |  |  |
| Setup Time (Start Condition)                  | t <sub>4</sub>  | 600 |     |     | ns   |  |  |
| Data Setup Time                               | t <sub>5</sub>  | 100 |     |     | ns   |  |  |
| SDIN, SCLK Rise Time                          | t <sub>6</sub>  |     |     | 300 | ns   |  |  |
| SDIN, SCLK Fall Time                          | t <sub>7</sub>  |     |     | 300 | ns   |  |  |
| Setup Time (Stop Condition)                   | t <sub>8</sub>  | 600 |     |     | ns   |  |  |
| Data Hold Time                                | t <sub>9</sub>  |     |     | 900 | ns   |  |  |
| Pulse width of spikes that will be suppressed | t <sub>ps</sub> | 0   |     | 5   | ns   |  |  |



## **CONTROL INTERFACE TIMING – 3-WIRE MODE**

3-wire mode is selected by connecting the MODE pin high.



Figure 7 Control Interface Timing – 3-Wire Serial Control Mode (Write Cycle)



Figure 8 Control Interface Timing – 3-Wire Serial Control Mode (Read Cycle)

### **Test Conditions**

DCVDD=1.8V, DBVDD=AVDD=3.3V, DGND=AGND=0V,  $T_A$ =+25°C, Slave Mode, fs=48kHz, MCLK=256fs, 24-bit data, unless otherwise stated.

| PARAMETER                                     | SYMBOL           | MIN | TYP | MAX | UNIT |
|-----------------------------------------------|------------------|-----|-----|-----|------|
| Program Register Input Information            |                  |     |     |     |      |
| CSB falling edge to SCLK rising edge          | t <sub>CSU</sub> | 40  |     |     | ns   |
| SCLK falling edge to CSB rising edge          | t <sub>сно</sub> | 40  |     |     | ns   |
| SCLK pulse cycle time                         | t <sub>SCY</sub> | 200 |     |     | ns   |
| SCLK pulse width low                          | t <sub>SCL</sub> | 80  |     |     | ns   |
| SCLK pulse width high                         | t <sub>scн</sub> | 80  |     |     | ns   |
| SDIN to SCLK set-up time                      | t <sub>DSU</sub> | 40  |     |     | ns   |
| SDIN to SCLK hold time                        | t <sub>DHO</sub> | 10  |     |     | ns   |
| Pulse width of spikes that will be suppressed | t <sub>ps</sub>  | 0   |     | 5   | ns   |
| SCLK falling edge to SDOUT transition         | t <sub>DL</sub>  |     |     | 40  | ns   |



## **CONTROL INTERFACE TIMING – 4-WIRE MODE**

4-wire mode supports readback via SDOUT which is available as a GPIO pin function.



Figure 9 Control Interface Timing – 4-Wire Serial Control Mode (Write Cycle)



Figure 10 Control Interface Timing – 4-Wire Serial Control Mode (Read Cycle)

### **Test Conditions**

DCVDD=1.8V, DBVDD=AVDD=3.3V, DGND=AGND=0V,  $T_A$  =+25 $^{\circ}$ C, Slave Mode, fs=48kHz, MCLK=256fs, 24-bit data, unless otherwise stated.

| PARAMETER                                     | SYMBOL           | MIN | TYP | MAX | UNIT |  |  |  |
|-----------------------------------------------|------------------|-----|-----|-----|------|--|--|--|
| Program Register Input Information            |                  |     |     |     |      |  |  |  |
| SCLK rising edge to CSB falling edge          | t <sub>CSU</sub> | 40  |     |     | ns   |  |  |  |
| SCLK falling edge to CSB rising edge          | t <sub>CHO</sub> | 40  |     |     | ns   |  |  |  |
| SCLK pulse cycle time                         | t <sub>SCY</sub> | 200 |     |     | ns   |  |  |  |
| SCLK pulse width low                          | t <sub>SCL</sub> | 80  |     |     | ns   |  |  |  |
| SCLK pulse width high                         | t <sub>sch</sub> | 80  |     |     | ns   |  |  |  |
| SDIN to SCLK set-up time                      | t <sub>DSU</sub> | 40  |     |     | ns   |  |  |  |
| SDIN to SCLK hold time                        | t <sub>DHO</sub> | 10  |     |     | ns   |  |  |  |
| SDOUT propagation delay from SCLK rising edge | t <sub>DL</sub>  |     |     | 10  | ns   |  |  |  |
| Pulse width of spikes that will be suppressed | t <sub>ps</sub>  | 0   |     | 5   | ns   |  |  |  |
| SCLK falling edge to SDOUT transition         | t <sub>DL</sub>  |     |     | 40  | ns   |  |  |  |



## INTERNAL POWER ON RESET CIRCUIT



Figure 11 Internal Power on Reset Circuit Schematic

The WM8953 includes an internal Power-On-Reset Circuit, as shown in Figure 11, which is used to reset the digital logic into a default state after power up. The POR circuit is powered from AVDD and monitors DCVDD. It asserts PORB low if AVDD or DCVDD is below a minimum threshold.



Figure 12 Typical Power up Sequence where AVDD is Powered before DCVDD

Figure 12 shows a typical power-up sequence where AVDD comes up first. When AVDD goes above the minimum threshold,  $V_{pora}$ , there is enough voltage for the circuit to guarantee PORB is asserted low and the chip is held in reset. In this condition, all writes to the control interface are ignored. Now AVDD is at full supply level. Next DCVDD rises to  $V_{pord\_on}$  and PORB is released high and all registers are in their default state and writes to the control interface may take place.

On power down, where AVDD falls first, PORB is asserted low whenever AVDD drops below the minimum threshold  $V_{\text{pora off}}$ .



Figure 13 Typical Power up Sequence where DCVDD is Powered before AVDD

Figure 13 shows a typical power-up sequence where DCVDD comes up first. First it is assumed that DCVDD is already up to specified operating voltage. When AVDD goes above the minimum threshold,  $V_{pora}$ , there is enough voltage for the circuit to guarantee PORB is asserted low and the chip is held in reset. In this condition, all writes to the control interface are ignored. When AVDD rises to  $V_{pora\_on}$ , PORB is released high and all registers are in their default state and writes to the control interface may take place.

On power down, where DCVDD falls first, PORB is asserted low whenever DCVDD drops below the minimum threshold  $V_{\text{pord off}}$ .

| SYMBOL    | MIN | TYP  | MAX | UNIT |
|-----------|-----|------|-----|------|
| Vpora     |     | 0.6  |     | V    |
| Vpora_on  |     | 1.52 |     | V    |
| Vpora_off |     | 1.5  |     | V    |
| Vpord_on  |     | 0.92 |     | V    |
| Vpord off |     | 0.9  |     | V    |

Table 1 Typical POR Operation (typical values, not tested)

## Notes:

- If AVDD and DCVDD suffer a brown-out (i.e. drop below the minimum recommended operating level but do not go below V<sub>pora\_off</sub> or V<sub>pord\_off</sub>) then the chip will not reset and will resume normal operation when the voltage is back to the recommended level again.
- The chip will enter reset at power down when AVDD or DCVDD falls below V<sub>pora\_off</sub> or V<sub>pord\_off</sub>.
   This may be important if the supply is turned on and off frequently by a power management system.
- 3. The minimum  $t_{por}$  period is maintained even if DCVDD and AVDD have zero rise time. This specification is guaranteed by design rather than test.

### **DEVICE DESCRIPTION**

## INTRODUCTION

The WM8953 is a low power, high quality audio ADC designed to interface with a wide range of processors and analogue components. A high level of mixed-signal integration in a very small 3.226x3.44mm footprint makes it ideal for portable applications such as mobile phones.

Eight highly flexible analogue inputs allow interfacing to up to four microphone inputs plus multiple stereo or mono line inputs (single-ended or differential).

The stereo ADCs are of hi-fi quality using a 24-bit, low-order oversampling architecture to deliver optimum performance. A flexible clocking arrangement supports a wide variety of clock inputs and sample rates; the integrated ultra-low power PLL provides additional flexibility. A high pass filter is available in the ADC path for removing DC offsets and suppressing low frequency noise such as mechanical vibration and wind noise.

The WM8953 has a highly flexible digital audio interface, supporting a number of protocols, including  $I^2S$ , DSP, MSB-first left/right justified, and can operate in master or slave modes. PCM operation is supported in the DSP mode. A-law and  $\mu$ -law companding are also supported. Time division multiplexing (TDM) is available to allow multiple devices to stream data simultaneously on the same bus, saving space and power.

The SYSCLK (system clock) provides clocking for the ADCs, DSP core and the digital audio interface. SYSCLK can be derived directly from the MCLK pin or via an integrated PLL, providing flexibility to support a wide range of clocking schemes. All MCLK frequencies typically used in portable systems are supported for sample rates between 8kHz and 48kHz.

To allow full software control over all its features, the WM8953 uses a standard 2-wire or 3/4-wire control interface with readback of key registers supported. It is fully compatible and an ideal partner for a wide range of industry standard microprocessors, controllers and DSPs. Unused circuitry can be disabled via software to save power, while low leakage currents extend standby and off time in portable battery-powered applications. The device address can be selected using the CSB/ADDR pin.

Versatile GPIO functionality is provided, with support for up to five button/accessory detect inputs with interrupt and status readback and flexible de-bouncing options, clock output, and logic '1' / logic '0' for control of additional external circuitry.



#### **INPUT SIGNAL PATH**

The WM8953 has eight highly flexible analogue input channels, configurable in many combinations of the following:

- 1. Up to four pseudo-differential or single-ended microphone inputs
- 2. Up to eight mono line inputs or 4 stereo line inputs

The input paths are mixed together as illustrated in Figure 14.



Figure 14 Control Registers for Input Signal Path

#### MICROPHONE INPUTS

Up to four microphones can be connected to the WM8953, either in single-ended or pseudodifferential mode. A low noise microphone bias is fully integrated to reduce the need for external components.

In single-ended microphone input configuration, the microphone signal is connected to the inverting input of the PGA (LIN1, LIN3, RIN1 or RIN3). The non-inverting input of the PGAs should be internally connected to VMID in this configuration. This is enabled via the Input PGA configuration register settings. In this configuration, LIN2, LIN4, RIN2 or RIN4 may be free to be used as line inputs.

In pseudo-differential microphone input configuration, the non-inverted microphone signal is connected to the non-inverting input of the PGA (LIN2, LIN4, RIN2 or RIN4) and the inverted (or noisy ground) signal is connected to the inverting input (LIN1, LIN3, RIN1 or RIN3).

Any PGA input pin that is used in either microphone configuration should not be enabled as a line input path at the same time.



The gain of the input PGAs is controlled via register settings. Note that the input impedance of LIN1, LIN3, RIN1 and RIN3 changes with the input PGA gain setting, as described under "Electrical Characteristics". (Note this does not apply to input paths which bypass the input PGA.) The input impedance of LIN2, LIN4, RIN2 and RIN4 does not change with input PGA gain. The inverting and non-inverting inputs are therefore not matched and the differential configuration is not fully differential.



#### **LINE INPUTS**

All eight analogue input pins may be configured as line inputs with up to six single-ended inputs available, and up to four pseudo differential inputs.

LIN1, LIN3, RIN1 and RIN3 can operate as single-ended line inputs to the Input PGAs to provide high gain if required for small input signals. In this configuration the non-inverting input of the PGAs should be internally connected to Vmid.

LIN2 and RIN2 can operate as line inputs to the Input PGAs LIN12 and RIN12 or directly to the input mixers. Direct routing to the mixers minimises power consumption by reducing the number of active amplifiers in the signal path.

LIN4 and RIN4 should only be used as part of a differential line input with LIN3 and LIN4. Up to four differential line inputs can be connected to LIN1+LIN2, LIN3+LIN4, RIN1+RIN2 and RIN3+RIN4.



### **INPUT PGA ENABLE**

The Input PGAs are enabled using register bits LIN12\_ENA, LIN34\_ENA, RIN12\_ENA and RIN34\_ENA as described in Table 2.

| REGISTER<br>ADDRESS | BIT | LABEL     | DEFAULT | DESCRIPTION            |
|---------------------|-----|-----------|---------|------------------------|
| R2 (02h)            | 7   | LIN34_ENA | 0b      | LIN34 Input PGA Enable |
|                     |     | (rw)      |         | 0 = disabled           |
|                     |     |           |         | 1 = enabled            |
|                     | 6   | LIN12_ENA | 0b      | LIN12 Input PGA Enable |
|                     |     | (rw)      |         | 0 = disabled           |
|                     |     |           |         | 1 = enabled            |
|                     | 5   | RIN34_ENA | 0b      | RIN34 Input PGA Enable |
|                     |     | (rw)      |         | 0 = disabled           |
|                     |     |           |         | 1 = enabled            |
|                     | 4   | RIN12_ENA | 0b      | RIN12 Input PGA Enable |
|                     |     | (rw)      |         | 0 = disabled           |
|                     |     |           |         | 1 = enabled            |

Table 2 Input PGA Enable

### **REFERENCE VOLTAGES**

The analogue circuits in the WM8953 are referenced to VMID (AVDD/2). This voltage is generated from AVDD via a programmable resistor chain as shown in the audio signal paths diagram on page 15. Together with the external decoupling capacitor on VMID, the programmable resistor chain results in a slow, normal or fast charging characteristic on VMID. The VMID reference is controlled by VMID\_MODE[1:0].

The analogue circuits in the WM8953 require a bias current. The bias current is enabled by setting VREF\_ENA. Note that the bias current source requires VMID to be enabled also.

| REGISTER<br>ADDRESS | BIT | LABEL                      | DEFAULT | DESCRIPTION                                                                                                                                                                                                                         |
|---------------------|-----|----------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R1 (01h)            | 2:1 | VMID_MODE<br>[1:0]<br>(rw) | 00b     | VMID Divider Enable and Select<br>00 = VMID disabled (for OFF mode)<br>$01 = 2 \times 50k\Omega$ divider (Normal mode)<br>$10 = 2 \times 250k\Omega$ divider (Standby mode)<br>$11 = 2 \times 5k\Omega$ divider (for fast start-up) |
|                     | 0   | VREF_ENA<br>(rw)           | 0b      | VREF Enable (Bias for all analogue functions)  0 = VREF bias disabled  1 = VREF bias enabled                                                                                                                                        |

Table 3 Reference Voltages



#### MICROPHONE BIAS CONTROL

The MICBIAS output provides a low noise reference voltage suitable for biasing electret type microphones via an external resistor. Refer to the Applications Information section for recommended external components. The MICBIAS voltage can be enabled or disabled using the MICBIAS\_ENA control bit and the voltage can be selected using the MBSEL register bit as detailed in Table 4.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                     |
|---------------------|-----|-------------|---------|---------------------------------|
| R1 (01h)            | 4   | MICBIAS_ENA | 0b      | Microphone Bias                 |
|                     |     | (rw)        |         | 0 = OFF (high impedance output) |
|                     |     |             |         | 1 = ON                          |
| R58 (3Ah)           | 0   | MBSEL       | 0b      | Microphone Bias Voltage Control |
|                     |     |             |         | 0 = 0.9 * AVDD                  |
|                     |     |             |         | 1 = 0.65 * AVDD                 |

**Table 4 Microphone Bias Control** 

Note that the maximum source current capability for MICBIAS is 3mA. The external biasing resistance must be large enough to limit the MICBIAS current to 3mA.

#### **MICROPHONE CURRENT DETECT**

A MICBIAS current detect function allows detection of accessories such as headset microphones. When the MICBIAS load current exceeds one of two programmable thresholds, (e.g. short circuit current or normal operating current), an interrupt or GPIO output can be generated. The current detection circuit is enabled by the MCD bit; the current thresholds are selected by the MCDTHR and MCDSCTH register fields as described in Table 24- see "General Purpose Input/Output" for a full description of these fields.

#### **DISABLED INPUT CONTROL**

After start-up, it may be desirable to disable an input stage, in order to reduce power consumption on an unused PGA or Input Mixer.

In order to avoid audible pops caused by a disabling any part of the input circuits, the WM8953 can maintain the input at VMID even when the PGA or Input Mixer is disabled. This is achieved by connecting a buffered VMID reference to the input. The buffered VMID is enabled by setting RUFIOFN

When BUFIOEN is enabled, the WM8953 maintains the charge on the input capacitors connected to any disabled input amplifier. This suppresses the audible artefacts that would otherwise arise when an input amplifier is disabled or enabled. In some applications, a pop generated at an input stage can be entirely suppressed by correctly managing the output stages (eg. using the ADC mute). However, it may be desirable to use the buffered VMID feature in order to eliminate the input PGA start-up delay (the input capacitor charging time) in addition to suppressing any mute/un-mute pops. In applications where frequent enabling and configuration of signal paths is used, it is recommended to enable BUFIOEN at all times

| REGISTER<br>ADDRESS   | BIT | LABEL   | DEFAULT | DESCRIPTION                                            |
|-----------------------|-----|---------|---------|--------------------------------------------------------|
| R57 (39h)<br>Anti-Pop | 3   | BUFIOEN | 0b      | Enables the Buffered VMID reference at disabled inputs |
| ·                     |     |         |         | 0 = Disabled                                           |
|                       |     |         |         | 1 = Enabled                                            |

Table 5 Disabled Input/Output Control



### **INPUT PGA CONFIGURATION**

Each of the four Input PGAs can be configured in single-ended or pseudo-differential mode.

Single-ended microphone operation of an Input PGA is selected by connecting the input source to the inverting PGA input. The non-inverting PGA input must be connected to VMID by setting the appropriate register bits.

For pseudo-differential microphone operation, the inverting and non-inverting PGA inputs are both connected to the input source and not to VMID.

For any line input or other connection not using the Input PGA, the appropriate PGA input should be disconnected from the external pin and connected to VMID.

Register bits LMN1, LMP2, LMN3, LMP4, RMN1, RMP2, RMN3 and RMP4 control connection of the PGA inputs to the device pins as shown in Table 6. The maximum available attenuation on any of these input paths is achieved using these bits to disable the input path to the applicable PGA.

| REGISTER<br>ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION                          |
|---------------------|-----|-------|---------|--------------------------------------|
| R40 (28h)           | 7   | LMP4  | 0b      | LIN34 PGA Non-Inverting Input Select |
|                     |     |       |         | 0 = LIN4 not connected to PGA        |
|                     |     |       |         | 1 = LIN4 connected to PGA            |
|                     | 6   | LMN3  | 0b      | LIN34 PGA Inverting Input Select     |
|                     |     |       |         | 0 = LIN3 not connected to PGA        |
|                     |     |       |         | 1 = LIN3 connected to PGA            |
|                     | 5   | LMP2  | 0b      | LIN12 PGA Non-Inverting Input Select |
|                     |     |       |         | 0 = LIN2 not connected to PGA        |
|                     |     |       |         | 1 = LIN2 connected to PGA            |
|                     | 4   | LMN1  | 0b      | LIN12 PGA Inverting Input Select     |
|                     |     |       |         | 0 = LIN1 not connected to PGA        |
|                     |     |       |         | 1 = LIN1 connected to PGA            |
|                     | 3   | RMP4  | 0b      | RIN34 PGA Non-Inverting Input Select |
|                     |     |       |         | 0 = RIN4 not connected to PGA        |
|                     |     |       |         | 1 = RIN4 connected to PGA            |
|                     | 2   | RMN3  | 0b      | RIN34 PGA Inverting Input Select     |
|                     |     |       |         | 0 = RIN3 not connected to PGA        |
|                     |     |       |         | 1 = RIN3 connected to PGA            |
|                     | 1   | RMP2  | 0b      | RIN12 PGA Non-Inverting Input Select |
|                     |     |       |         | 0 = RIN2 not connected to PGA        |
|                     |     |       |         | 1 = RIN2 connected to PGA            |
|                     | 0   | RMN1  | 0b      | RIN12 PGA Inverting Input Select     |
|                     |     |       |         | 0 = RIN1 not connected to PGA        |
|                     |     |       |         | 1 = RIN1 connected to PGA            |

Table 6 Input PGA Configuration



### **INPUT PGA VOLUME CONTROL**

Each of the four Input PGAs has an independently controlled gain range of -16.5dB to +30dB in 1.5dB steps. The gains on the inverting and non-inverting inputs to the PGAs are always equal. Each Input PGA can be independently muted using the PGA mute bits as described in Table 7, with specified mute attenuation achieved by simultaneously disconnecting the corresponding inputs described in Table 6.

To prevent "zipper noise", a zero-cross function is provided, so that when enabled, volume updates will not take place until a zero-crossing is detected. In the event of a long period without zero-crossings, a timeout function is available. When this function is enabled (using the TOCLK\_ENA register bit), the volume will update after the timeout period if no earlier zero-cross has occurred. The timeout period is set by TOCLK\_RATE. See "Clocking and Sample Rates" for more information on these fields.

The IPVU bit controls the loading of the input PGA volume data. When IPVU is set to 0, the PGA volume data will be loaded into the respective control register, but will not actually change the gain setting. The LIN12, RIN12, LIN34, RIN34 volume settings are all updated when a 1 is written to IPVU. This makes it possible to update the gain of all input paths simultaneously.

The Input PGA Volume Control register fields are described in Table 7 and Table 8.

| REGISTER<br>ADDRESS | BIT | LABEL             | DEFAULT         | DESCRIPTION                                                                                                                                   |
|---------------------|-----|-------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| R24 (18h)           | 8   | IPVU[0]           | N/A             | Input PGA Volume Update Writing a 1 to this bit will cause all input PGA volumes to be updated simultaneously (LIN12, LIN34, RIN12 and RIN34) |
|                     | 7   | LI12MUTE          | 1b              | LIN12 PGA Mute 0 = Disable Mute 1 = Enable Mute                                                                                               |
|                     | 6   | LI12ZC            | 0b              | LIN12 PGA Zero Cross Detector  0 = Change gain immediately  1 = Change gain on zero cross only                                                |
|                     | 4:0 | LIN12VOL<br>[4:0] | 01011b<br>(0dB) | LIN12 Volume (See Table 8 for volume range)                                                                                                   |
| R25 (19h)           | 8   | IPVU[1]           | N/A             | Input PGA Volume Update Writing a 1 to this bit will cause all input PGA volumes to be updated simultaneously (LIN12, LIN34, RIN12 and RIN34) |
|                     | 7   | LI34MUTE          | 1b              | LIN34 PGA Mute 0 = Disable Mute 1 = Enable Mute                                                                                               |
|                     | 6   | LI34ZC            | Ob              | LIN34 PGA Zero Cross Detector 0 = Change gain immediately 1 = Change gain on zero cross only                                                  |
|                     | 4:0 | LIN34VOL<br>[4:0] | 01011b<br>(0dB) | LIN34 Volume<br>(See Table 8 for volume range)                                                                                                |
| R26 (1Ah)           | 8   | IPVU[2]           | N/A             | Input PGA Volume Update Writing a 1 to this bit will cause all input PGA volumes to be updated simultaneously (LIN12, LIN34, RIN12 and RIN34) |
|                     | 7   | RI12MUTE          | 1b              | RIN12 PGA Mute 0 = Disable Mute 1 = Enable Mute                                                                                               |
|                     | 6   | RI12ZC            | 0b              | RIN12 PGA Zero Cross Detector 0 = Change gain immediately 1 = Change gain on zero cross only                                                  |



**WM8953** 

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                                                                                                           |
|---------------------|-----|----------|---------|-----------------------------------------------------------------------------------------------------------------------|
|                     | 4:0 | RIN12VOL | 01011b  | RIN12 Volume                                                                                                          |
|                     |     | [4:0]    | (0dB)   | (See Table 8 for volume range)                                                                                        |
| R27 (1Bh)           | 8   | IPVU[3]  | N/A     | Input PGA Volume Update                                                                                               |
|                     |     |          |         | Writing a 1 to this bit will cause all input PGA volumes to be updated simultaneously (LIN12, LIN34, RIN12 and RIN34) |
|                     | 7   | RI34MUTE | 1b      | RIN34 PGA Mute                                                                                                        |
|                     |     |          |         | 0 = Disable Mute                                                                                                      |
|                     |     |          |         | 1 = Enable Mute                                                                                                       |
|                     | 6   | RI34ZC   | 0b      | RIN34 PGA Zero Cross Detector                                                                                         |
|                     |     |          |         | 0 = Change gain immediately                                                                                           |
|                     |     |          |         | 1 = Change gain on zero cross only                                                                                    |
|                     | 4:0 | RIN34VOL | 01011b  | RIN34 Volume                                                                                                          |
|                     |     | [4:0]    | (0dB)   | (See Table 8 for volume range)                                                                                        |

Table 7 Input PGA Volume Control



WM8953

| LIN12VOL[4:0], LIN34VOL[4:0],<br>RIN12VOL[4:0], RIN34VOL[4:0] | VOLUME<br>(DB) |
|---------------------------------------------------------------|----------------|
| 00000                                                         | -16.5          |
| 00001                                                         | -15.0          |
| 00010                                                         | -13.5          |
| 00011                                                         | -12.0          |
| 00100                                                         | -10.5          |
| 00101                                                         | -9.0           |
| 00110                                                         | -7.5           |
| 00111                                                         | -6.0           |
| 01000                                                         | -4.5           |
| 01001                                                         | -3.0           |
| 01010                                                         | -1.5           |
| 01011                                                         | 0              |
| 01100                                                         | +1.5           |
| 01101                                                         | +3.0           |
| 01110                                                         | +4.5           |
| 01111                                                         | +6.0           |
| 10000                                                         | +7.5           |
| 10001                                                         | +9.0           |
| 10010                                                         | +10.5          |
| 10011                                                         | +12.0          |
| 10100                                                         | +13.5          |
| 10101                                                         | +15.0          |
| 10110                                                         | +16.5          |
| 10111                                                         | +18.0          |
| 11000                                                         | +19.5          |
| 11001                                                         | +21.0          |
| 11010                                                         | +22.5          |
| 11011                                                         | +24.0          |
| 11100                                                         | +25.5          |
| 11101                                                         | +27.0          |
| 11110                                                         | +28.5          |
| 11111                                                         | +30.0          |

Table 8 Input PGA Volume Range

#### **INPUT MIXER ENABLE**

The WM8953 has two analogue input mixers which allow the Input PGAs and Line Inputs to be combined in a number of ways and output to the ADCs.

The input mixers INMIXL and INMIXR are enabled by the AINL\_ENA and AINR\_ENA register bits, as described in Table 9.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION             |
|---------------------|-----|----------|---------|-------------------------|
| R2 (02h)            | 9   | AINL_ENA | 0b      | Left Input Path Enable  |
|                     |     | (rw)     |         | 0 = Input Path disabled |
|                     |     |          |         | 1 = Input Path enabled  |
|                     | 8   | AINR_ENA | 0b      | Right Input Path Enable |
|                     |     | (rw)     |         | 0 = Input Path disabled |
|                     |     |          |         | 1 = Input Path enabled  |

**Table 9 Input Mixer Enable** 

#### INPUT MIXER VOLUME CONTROL

The Input Mixer volume controls are described in Table 10 for the Left Channel and Table 11 for the Right Channel. The Input PGA levels may be set to Mute, 0dB or 30dB boost. The other gain controls provide adjustment from -12dB to +6dB in 3dB steps.

To prevent pop noise it is recommended that gain and mute controls for the input mixers are not modified while the signal paths are active. If volume control is required on the input signal path it is recommended that the input PGA volume controls or the ADC volume controls are used instead of the input mixer gain registers.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                      |
|---------------------|-----|----------|---------|----------------------------------|
| R41 (29h)           | 8   | L34MNB   | 0b      | LIN34 PGA Output to INMIXL Mute  |
|                     |     |          |         | 0 = Mute                         |
|                     |     |          |         | 1 = Un-Mute                      |
|                     | 7   | L34MNBST | 0b      | LIN34 PGA Output to INMIXL Gain  |
|                     |     |          |         | 0 = 0dB                          |
|                     |     |          |         | 1 = +30dB                        |
|                     | 5   | L12MNB   | 0b      | LIN12 PGA Output to INMIXL Mute  |
|                     |     |          |         | 0 = Mute                         |
|                     |     |          |         | 1 = Un-Mute                      |
|                     | 4   | L12MNBST | 0b      | LIN12 PGA Output to INMIXL Gain  |
|                     |     |          |         | 0 = 0dB                          |
|                     |     |          |         | 1 = +30dB                        |
| R43 (2Bh)           | 8:6 | LI2BVOL  | 000b    | LIN2 Pin to INMIXL Gain and Mute |
|                     |     | [2:0]    | (Mute)  | 000 = Mute                       |
|                     |     |          |         | 001 = -12dB                      |
|                     |     |          |         | 010 = -9dB                       |
|                     |     |          |         | 011 = -6dB                       |
|                     |     |          |         | 100 = -3dB                       |
|                     |     |          |         | 101 = 0dB                        |
|                     |     |          |         | 110 = +3dB                       |
|                     |     |          |         | 111 = +6dB                       |

Table 10 Left Input Mixer Volume Control



| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                      |
|---------------------|-----|----------|---------|----------------------------------|
| R42 (2A)            | 8   | R34MNB   | 0b      | RIN34 PGA Output to INMIXR Mute  |
|                     |     |          |         | 0 = Mute                         |
|                     |     |          |         | 1 = Un-Mute                      |
|                     | 7   | R34MNBST | 0b      | RIN34 PGA Output to INMIXR Gain  |
|                     |     |          |         | 0 = 0dB                          |
|                     |     |          |         | 1 = +30dB                        |
|                     | 5   | R12MNB   | 0b      | RIN12 PGA Output to INMIXR Mute  |
|                     |     |          |         | 0 = Mute                         |
|                     |     |          |         | 1 = Un-Mute                      |
|                     | 4   | R12MNBST | 0b      | RIN12 PGA Output to INMIXR Gain  |
|                     |     |          |         | 0 = 0dB                          |
|                     |     |          |         | 1 = +30dB                        |
| R44 (2Ch)           | 8:6 | RI2BVOL  | 000b    | RIN2 Pin to INMIXR Gain and Mute |
|                     |     | [2:0]    | (Mute)  | 000 = Mute                       |
|                     |     |          |         | 001 = -12dB                      |
|                     |     |          |         | 010 = -9dB                       |
|                     |     |          |         | 011 = -6dB                       |
|                     |     |          |         | 100 = -3dB                       |
|                     |     |          |         | 101 = 0dB                        |
|                     |     |          |         | 110 = +3dB                       |
|                     |     |          |         | 111 = +6dB                       |

Table 11 Right Input Mixer Volume Control



## **ANALOGUE TO DIGITAL CONVERTER (ADC)**

The WM8953 uses stereo 24-bit, 64x oversampled sigma-delta ADCs. The use of multi-bit feedback and high oversampling rates reduces the effects of jitter and high frequency noise. The ADC full scale input level is proportional to AVDD. See "Electrical Characteristics" for further details. Any input signal greater than full scale may overload the ADC and cause distortion.

The ADCs are enabled by the ADCL\_ENA and ADCR\_ENA register bits. If both ADCs are to be enabled, they should be enabled simultaneously, i.e. with the same register write. If there is a requirement to enable the ADCs independently of one another and use them simultaneously, the ADCL\_ADCR\_LINK bit should be set. The EXT\_ACCESS\_ENA bit must be set before writing to the ADCL\_ADCR\_LINK bit.

| REGISTER<br>ADDRESS | BIT | LABEL          | DEFAULT | DESCRIPTION                  |
|---------------------|-----|----------------|---------|------------------------------|
| R2 (02h)            | 1   | ADCL_ENA       | 0b      | Left ADC Enable              |
|                     |     | (rw)           |         | 0 = ADC disabled             |
|                     |     |                |         | 1 = ADC enabled              |
|                     | 0   | ADCR_ENA       | 0b      | Right ADC Enable             |
|                     |     | (rw)           |         | 0 = ADC disabled             |
|                     |     |                |         | 1 = ADC enabled              |
| R117 (75h)          | 1   | EXT_ACCESS_ENA | 0b      | Extended Register Map Access |
|                     |     |                |         | 0 = disabled                 |
|                     |     |                |         | 1 = enabled                  |
| R122 (7Ah)          | 15  | ADCL_ADCR_LINK | 0b      | 0 = ADC Sync disabled        |
|                     |     |                |         | 1 = ADC Sync enabled         |

Table 12 ADC Enable Control

#### **ADC DIGITAL VOLUME CONTROL**

The output of the ADCs can be digitally amplified or attenuated over a range from -71.625dB to +17.625dB in 0.375dB steps. The volume of each channel can be controlled separately. The gain for a given eight-bit code X is given by:

 $0.375 \times (X-192) \text{ dB for } 1 \le X \le 239;$  MUTE for X = 0 +17.625dB for  $239 \le X \le 255$ 

The ADC\_VU bit controls the loading of digital volume control data. When ADC\_VU is set to 0, the ADCL\_VOL or ADCR\_VOL control data will be loaded into the respective control register, but will not actually change the digital gain setting. Both left and right gain settings are updated when a 1 is written to ADC\_VU. This makes it possible to update the gain of both channels simultaneously.

| REGISTER<br>ADDRESS | BIT | LABEL             | DEFAULT             | DESCRIPTION                                                                                                 |
|---------------------|-----|-------------------|---------------------|-------------------------------------------------------------------------------------------------------------|
| R15 (0Fh)           | 8   | ADC_VU            | N/A                 | ADC Volume Update Writing a 1 to this bit will cause left and right ADC volume to be updated simultaneously |
|                     | 7:0 | ADCL_VOL<br>[7:0] | 1100_0000b<br>(0dB) | Left ADC Digital Volume (See Table 14 for volume range)                                                     |
| R16 (10h)           | 8   | ADC_VU            | N/A                 | ADC Volume Update Writing a 1 to this bit will cause left and right ADC volume to be updated simultaneously |
|                     | 7:0 | ADCR_VOL<br>[7:0] | 1100_0000b<br>(0dB) | Right ADC Digital Volume (See Table 14 for volume range)                                                    |

**Table 13 ADC Digital Volume Control** 



| ADCL_VOL or |                    | ADCL_VOL or |                    | ADCL_VOL or |                    | ADCL_VOL or |                  |
|-------------|--------------------|-------------|--------------------|-------------|--------------------|-------------|------------------|
| ADCR_VOL    | Volume (dB)        | ADCR_VOL    | Volume (dB)        | ADCR_VOL    | Volume (dB)        | ADCR_VOL    | Volume (dB)      |
| 0h          | MUTE               | 40h         | -48.000            | 80h         | -24.000            | C0h         | 0.000            |
| 1h<br>2h    | -71.625<br>-71.250 | 41h<br>42h  | -47.625<br>-47.250 | 81h<br>82h  | -23.625<br>-23.250 | C1h<br>C2h  | 0.375<br>0.750   |
| 3h          | -70.875            | 43h         | -46.875            | 83h         | -22.875            | C3h         | 1.125            |
| 4h          | -70.500            | 44h         | -46.500            | 84h         | -22.500            | C4h         | 1.500            |
| 5h          | -70.125            | 45h         | -46.125            | 85h         | -22.125            | C5h         | 1.875            |
| 6h          | -69.750            | 46h         | -45.750            | 86h         | -21.750            | C6h         | 2.250            |
| 7h          | -69.375            | 47h         | -45.375            | 87h         | -21.375            | C7h         | 2.625            |
| 8h          | -69.000            | 48h         | -45.000            | 88h         | -21.000            | C8h         | 3.000            |
| 9h          | -68.625            | 49h         | -44.625            | 89h         | -20.625            | C9h         | 3.375            |
| Ah          | -68.250            | 4Ah         | -44.250            | 8Ah         | -20.250            | CAh         | 3.750            |
| Bh<br>Ch    | -67.875            | 4Bh<br>4Ch  | -43.875            | 8Bh<br>8Ch  | -19.875            | CBh<br>CCh  | 4.125<br>4.500   |
| Dh          | -67.500<br>-67.125 | 4Dh         | -43.500<br>-43.125 | 8Dh         | -19.500<br>-19.125 | CDh         | 4.875            |
| Eh          | -66.750            | 4Eh         | -42.750            | 8Eh         | -18.750            | CEh         | 5.250            |
| Fh          | -66.375            | 4Fh         | -42.375            | 8Fh         | -18.375            | CFh         | 5.625            |
| 10h         | -66.000            | 50h         | -42.000            | 90h         | -18.000            | D0h         | 6.000            |
| 11h         | -65.625            | 51h         | -41.625            | 91h         | -17.625            | D1h         | 6.375            |
| 12h         | -65.250            | 52h         | -41.250            | 92h         | -17.250            | D2h         | 6.750            |
| 13h         | -64.875            | 53h         | -40.875            | 93h         | -16.875            | D3h         | 7.125            |
| 14h         | -64.500            | 54h         | -40.500            | 94h         | -16.500            | D4h         | 7.500            |
| 15h         | -64.125            | 55h         | -40.125            | 95h         | -16.125            | D5h         | 7.875            |
| 16h         | -63.750            | 56h         | -39.750            | 96h         | -15.750            | D6h         | 8.250            |
| 17h<br>18h  | -63.375<br>-63.000 | 57h<br>58h  | -39.375<br>-39.000 | 97h<br>98h  | -15.375<br>-15.000 | D7h<br>D8h  | 8.625<br>9.000   |
| 19h         | -62.625            | 59h         | -38.625            | 99h         | -14.625            | D9h         | 9.375            |
| 1Ah         | -62.250            | 5Ah         | -38.250            | 9Ah         | -14.250            | DAh         | 9.750            |
| 1Bh         | -61.875            | 5Bh         | -37.875            | 9Bh         | -13.875            | DBh         | 10.125           |
| 1Ch         | -61.500            | 5Ch         | -37.500            | 9Ch         | -13.500            | DCh         | 10.500           |
| 1Dh         | -61.125            | 5Dh         | -37.125            | 9Dh         | -13.125            | DDh         | 10.875           |
| 1Eh         | -60.750            | 5Eh         | -36.750            | 9Eh         | -12.750            | DEh         | 11.250           |
| 1Fh         | -60.375            | 5Fh         | -36.375            | 9Fh         | -12.375            | DFh         | 11.625           |
| 20h         | -60.000            | 60h         | -36.000            | A0h         | -12.000            | E0h         | 12.000           |
| 21h         | -59.625            | 61h         | -35.625<br>-35.250 | A1h         | -11.625            | E1h<br>E2h  | 12.375           |
| 22h<br>23h  | -59.250<br>-58.875 | 62h<br>63h  | -35.250<br>-34.875 | A2h<br>A3h  | -11.250<br>-10.875 | E3h         | 12.750<br>13.125 |
| 24h         | -58.500            | 64h         | -34.500            | A4h         | -10.500            | E4h         | 13.500           |
| 25h         | -58.125            | 65h         | -34.125            | A5h         | -10.125            | E5h         | 13.875           |
| 26h         | -57.750            | 66h         | -33.750            | A6h         | -9.750             | E6h         | 14.250           |
| 27h         | -57.375            | 67h         | -33.375            | A7h         | -9.375             | E7h         | 14.625           |
| 28h         | -57.000            | 68h         | -33.000            | A8h         | -9.000             | E8h         | 15.000           |
| 29h         | -56.625            | 69h         | -32.625            | A9h         | -8.625             | E9h         | 15.375           |
| 2Ah         | -56.250            | 6Ah         | -32.250            | AAh         | -8.250             | EAh         | 15.750           |
| 2Bh         | -55.875<br>55.500  | 6Bh         | -31.875            | ABh         | -7.875<br>7.500    | EBh         | 16.125           |
| 2Ch<br>2Dh  | -55.500<br>-55.125 | 6Ch<br>6Dh  | -31.500<br>-31.125 | ACh<br>ADh  | -7.500<br>-7.125   | ECh<br>EDh  | 16.500<br>16.875 |
| 2Eh         | -55.125<br>-54.750 | 6Eh         | -30.750            | AEh         | -7.125<br>-6.750   | EEh         | 17.250           |
| 2Fh         | -54.375            | 6Fh         | -30.375            | AFh         | -6.375             | EFh         | 17.625           |
| 30h         | -54.000            | 70h         | -30.000            | B0h         | -6.000             | F0h         | 17.625           |
| 31h         | -53.625            | 71h         | -29.625            | B1h         | -5.625             | F1h         | 17.625           |
| 32h         | -53.250            | 72h         | -29.250            | B2h         | -5.250             | F2h         | 17.625           |
| 33h         | -52.875            | 73h         | -28.875            | B3h         | -4.875             | F3h         | 17.625           |
| 34h         | -52.500            | 74h         | -28.500            | B4h         | -4.500             | F4h         | 17.625           |
| 35h         | -52.125<br>-51.750 | 75h<br>76h  | -28.125<br>-27.750 | B5h<br>B6h  | -4.125<br>-3.750   | F5h         | 17.625<br>17.625 |
| 36h<br>37h  | -51.750<br>-51.375 | 76h<br>77h  | -27.750<br>-27.375 | B6h<br>B7h  | -3.750<br>-3.375   | F6h<br>F7h  | 17.625<br>17.625 |
| 38h         | -51.375<br>-51.000 | 7711<br>78h | -27.000            | B8h         | -3.375<br>-3.000   | F8h         | 17.625           |
| 39h         | -50.625            | 79h         | -26.625            | B9h         | -2.625             | F9h         | 17.625           |
| 3Ah         | -50.250            | 7Ah         | -26.250            | BAh         | -2.250             | FAh         | 17.625           |
| 3Bh         | -49.875            | 7Bh         | -25.875            | BBh         | -1.875             | FBh         | 17.625           |
| 3Ch         | -49.500            | 7Ch         | -25.500            | BCh         | -1.500             | FCh         | 17.625           |
| 3Dh         | -49.125            | 7Dh         | -25.125            | BDh         | -1.125             | FDh         | 17.625           |
| 3Eh         | -48.750            | 7Eh         | -24.750            | BEh         | -0.750             | FEh         | 17.625           |
| 3Fh         | -48.375            | 7Fh         | -24.375            | BFh         | -0.375             | FFh         | 17.625           |

Table 14 ADC Digital Volume Range



## **HIGH PASS FILTER**

A digital high pass filter is applied by default to the ADC path to remove DC offsets. This filter can also be programmed to remove low frequency noise in voice applications (e.g. wind noise or mechanical vibration). This filter is controlled using the ADC\_HPF\_ENA and ADC\_HPF\_CUT register bits.

In hi-fi mode the high pass filter is optimised for removing DC offsets without degrading the bass response and has a cut-off frequency of 3.7Hz at fs=44.1kHz.

In voice mode the high pass filter is optimised for voice communication and it is recommended to program the cut-off frequency below 300Hz (e.g. ADC\_HPF\_CUT=11 at fs=8kHz or ADC\_HPF\_CUT=10 at fs=16kHz).

| REGISTER<br>ADDRESS | BIT | LABEL                | DEFAULT | DESCRIPTION                                                                                                                                                                                                                                                                                                              |
|---------------------|-----|----------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R14 (0Eh)           | 8   | ADC_HPF_ENA          | 1b      | ADC Digital High Pass Filter Enable  0 = disabled  1 = enabled                                                                                                                                                                                                                                                           |
|                     | 6:5 | ADC_HPF_CUT<br>[1:0] | 00b     | ADC Digital High Pass Filter Cut-Off Frequency (fc) 00 = Hi-fi mode (fc=4Hz at fs=48kHz) 01 = Voice mode 1 (fc=127Hz at fs=16kHz) 10 = Voice mode 2 (fc=130Hz at fs=8kHz) 11 = Voice mode 3 (fc=267Hz at fs=8kHz) (Note: fc scales with sample rate. See Table 16 for cut-off frequencies at all supported sample rates) |

Table 15 ADC High Pass Filter Control Registers

| Sample             |                    |                    |                    |                    |
|--------------------|--------------------|--------------------|--------------------|--------------------|
| Frequency<br>(kHz) | ADC_HPF_CUT<br>=00 | ADC_HPF_CUT<br>=01 | ADC_HPF_CUT<br>=10 | ADC_HPF_CUT<br>=11 |
| 8.000              | 0.7                | 64                 | 130                | 267                |
| 11.025             | 0.9                | 88                 | 178                | 367                |
| 16.000             | 1.3                | 127                | 258                | 532                |
| 22.050             | 1.9                | 175                | 354                | 733                |
| 24.000             | 2.0                | 190                | 386                | 798                |
| 32.000             | 2.7                | 253                | 514                | 1063               |
| 44.100             | 3.7                | 348                | 707                | 1464               |
| 48.000             | 4.0                | 379                | 770                | 1594               |

Table 16 ADC High Pass Filter Cut-Off Frequencies

The high pass filter characteristics are shown in the "Digital Filter Characteristics" section.

# **DIGITAL AUDIO PATHS**

The ADC data can be routed in different ways to the digital audio interface. Data from either of the two ADCs can be routed to either the left or the right channel of the digital audio interface. Independent functions enable either of the audio channels to be digitally inverted if required. See "Digital Audio Interface" for more information on the audio interface.

Figure 20 shows the digital audio paths available in the WM8953 digital core.



Figure 20 Digital Audio Paths

The polarity of each ADC output signal can be changed under software control using the ADCL\_DATINV and ADCR\_DATINV register bits. The AIFADCL\_SRC and AIFADCR\_SRC register bits may be used to select which ADC is used for the left and right digital audio interface data. These register bits are described in Table 17.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                   |
|---------------------|-----|-------------|---------|-----------------------------------------------|
| R4 (04h)            | 15  | AIFADCL_SRC | 0b      | Left Digital Audio channel source             |
|                     |     |             |         | 0 = Left ADC data is output on left channel   |
|                     |     |             |         | 1 = Right ADC data is output on left channel  |
|                     | 14  | AIFADCR_SRC | 1b      | Right Digital Audio channel source            |
|                     |     |             |         | 0 = Left ADC data is output on right channel  |
|                     |     |             |         | 1 = Right ADC data is output on right channel |
| R14 (0Eh)           | 1   | ADCL_DATINV | 0b      | Left ADC Invert                               |
|                     |     |             |         | 0 = Left ADC output not inverted              |
|                     |     |             |         | 1 = Left ADC output inverted                  |
|                     | 0   | ADCR_DATINV | 0b      | Right ADC Invert                              |
|                     |     |             |         | 0 = Right ADC output not inverted             |
|                     |     |             |         | 1 = Right ADC output inverted                 |

Table 17 ADC Routing and Control

# THERMAL SENSING

The WM8953 incorporates a thermal sensor in order to provide protection from overheating. The sensor is enabled by setting TSHUT\_ENA. The status of the thermal sensor can be output on a GPIO pin and/or read from the GPIO registers. Alternatively, the temperature sensor can be configured to cause an Interrupt event. See "General Purpose Input/Output" for further details.

Note that, if thermal shutdown is required, this must be implemented by the host processor, in response to the thermal status indication generated by the WM8953.

| REGISTER<br>ADDRESS | BIT | LABEL     | DEFAULT | DESCRIPTION                 |
|---------------------|-----|-----------|---------|-----------------------------|
| R2 (02h)            | 14  | TSHUT_ENA | 1b      | Thermal Sensor Enable       |
|                     |     | (rw)      |         | 0 = Thermal sensor disabled |
|                     |     |           |         | 1 = Thermal sensor enabled  |

Table 18 Thermal Shutdown

# **GENERAL PURPOSE INPUT/OUTPUT**

The WM8953 provides a number of versatile GPIO functions to enable features such as button and accessory detection and clock output.

The WM8953 has five multi-purpose pins for these functions.

- GPIO3, GPIO4 and GPIO5: Dedicated GPIO pins.
- LIN3/GPI7 and RIN3/GPI8: Analogue inputs or button/accessory detect inputs.

The following functions are available on some or all of the GPIO pins.

- Button detect (latched with programmable de-bounce)
- MICBIAS / Accessory current or short circuit detect
- Clock output
- Temperature sensor output
- PLL lock output
- Logic '1' and logic '0' output
- · Interrupt event output
- · Serial data output (register readback)

The functions available on each of the GPIO pins are identified in Table 19.

|                                 | GPIO PINS |       |       |      |      |  |
|---------------------------------|-----------|-------|-------|------|------|--|
| GPIO Pin Function               | GPIO3     | GPIO4 | GPIO5 | GPI7 | GPI8 |  |
| Button/Accessory Detect Input   | Y         | Υ     | Y     | Υ    | Y    |  |
| Clock Output                    | Y         | Y     | Y     |      |      |  |
| Temperature OK                  | Y         | Y     | Y     |      |      |  |
| PLL Lock                        | Y         | Υ     | Y     |      |      |  |
| Logic 1 and Logic 0             | Y         | Υ     | Y     |      |      |  |
| Interrupt                       | Y         | Υ     | Y     |      |      |  |
| SDOUT (Readback Data)           | Y         | Y     | Υ     |      |      |  |
| Pull-up and Pull-down Available | Y         | Y     | Y     |      |      |  |

Table 19 Functions Available on GPIO Pins

The GPIO pins are configured by a combination of register settings described in Table 20 to Table 23 in the following section. The order of precedence for the control of the GPIO pins is as listed below.

- 1. Pin pull-up or pull-down (GPIOn\_PU, GPIOn\_PD)
- 2. Audio Interface and GPIO Tristate (AIF\_TRIS)
- 3. GPIO functionality (GPIOn\_SEL)

## **GPIO CONTROL REGISTERS**

Register bit AIF\_TRIS, when set, tri-states all audio interface and GPIO pins.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                                                                                                                           |
|---------------------|-----|----------|---------|---------------------------------------------------------------------------------------------------------------------------------------|
| R9 (09h)            | 13  | AIF_TRIS | 0b      | Audio Interface and GPIO Tristate  0 = Audio interface and GPIO pins operate normally  1 = Tristate all audio interface and GPIO pins |

Table 20 GPIO and GPI Pin Function Select

The GPIO pins are also controlled by the register fields described in Table 21. Note the order of precedence described earlier applies.

Pull-up and pull-down resistors may be enabled on any of GPIO3, GPIO4 or GPIO5. If enabled, these settings take precedence over all other GPIO selections for that pin. Note that, by default, the pull-down resistors on GPIO3, GPIO4 and GPIO5 are enabled.

When the GPIO pins are used as inputs, de-bounce and interrupt masking may be controlled on all GPIO pins (including GPI7 and GPI8) using GPIOn\_DEB\_ENA and GPIOn\_IRQ\_ENA bits as shown in Table 22.

For each of GPIO3, GPIO4 and GPIO5, the register field GPIOn\_SEL is used to select the pin functions of the individual GPIO pins as shown in Table 22. Note that this control has the lowest precedence and is only effective when GPIOn\_PU, GPIOn\_PD and AIF\_TRIS are set to allow GPIO functionality on that GPIO pin.

| REGISTER<br>ADDRESS | BIT  | LABEL          | DEFAULT | DESCRIPTION                        |
|---------------------|------|----------------|---------|------------------------------------|
| R20 (14h)           | 15   | GPIO4_DEB_ENA  | 0b      | See Table 22 for GPIO4 control bit |
|                     | 14   | GPIO4_IRQ_ENA  | 0b      | description                        |
|                     | 13   | GPIO4_PU       | 0b      |                                    |
|                     | 12   | GPIO4_PD       | 1b      |                                    |
|                     | 11:8 | GPIO4_SEL[3:0] | 0000b   |                                    |
|                     | 7    | GPIO3_DEB_ENA  | 0b      | See Table 22 for GPIO3 control bit |
|                     | 6    | GPIO3_IRQ_ENA  | 0b      | description                        |
|                     | 5    | GPIO3_PU       | 0b      |                                    |
|                     | 4    | GPIO3_PD       | 1b      |                                    |
|                     | 3:0  | GPIO3_SEL[3:0] | 0000b   |                                    |
| R21 (15h)           | 7    | GPIO5_DEB_ENA  | 0b      | See Table 22 for GPIO5 control bit |
|                     | 6    | GPIO5_IRQ_ENA  | 0b      | description                        |
|                     | 5    | GPIO5_PU       | 0b      |                                    |
|                     | 4    | GPIO5_PD       | 1b      |                                    |
|                     | 3:0  | GPIO5_SEL[3:0] | 0000b   |                                    |
| R22 (16h)           | 7    | GPI8_DEB_ENA   | 0b      | See Table 22 for GPIn control bit  |
|                     | 6    | GPI8_IRQ_ENA   | 0b      | description                        |
|                     | 4    | GPI8_ENA       | 0b      |                                    |
|                     | 3    | GPI7_DEB_ENA   | 0b      | See Table 22 for GPIn control bit  |
|                     | 2    | GPI7_IRQ_ENA   | 0b      | description                        |
|                     | 0    | GPI7_ENA       | 0b      |                                    |

Table 21 GPIO and GPI Control



The following table describes the coding of the fields listed in Table 21.

| REGISTER<br>ADDRESS | LABEL               | DEFAULT  | DESCRIPTION                                         |
|---------------------|---------------------|----------|-----------------------------------------------------|
| Registers           | GPIOn_DEB_ENA       | 0b       | De-Bounce                                           |
| R20 (14h)           | (n = 3, 4, 5, 7, 8) |          | 0 = disabled (Not de-bounced)                       |
| to<br>R21 (15h)     |                     |          | 1 = enabled (Requires MCLK input and TOCLK_ENA = 1) |
| (See Table          | GPIOn_IRQ_ENA       | 0b       | IRQ Enable                                          |
| 21)                 | (n = 3, 4, 5, 7, 8) |          | 0 = disabled                                        |
|                     |                     |          | 1 = enabled                                         |
|                     | GPIOn_PU            | 0b       | GPIO Pull-Up Resistor Enable                        |
|                     | (n = 3, 4, 5)       |          | 0 = Pull-up disabled                                |
|                     |                     |          | 1 = Pull-up enabled (Approx 150k $\Omega$ )         |
|                     | GPIOn_PD            | See      | GPIO Pull-Down Resistor Enable                      |
|                     | (n = 3, 4, 5)       | Table 21 | 0 = Pull-down disabled                              |
|                     |                     |          | 1 = Pull-down enabled (Approx 150k $\Omega$ )       |
|                     | GPIOn_SEL[3:0]      | 0000b    | GPIOn Pin Function Select                           |
|                     | (n = 3, 4, 5)       |          | 0000 = Input pin                                    |
|                     |                     |          | 0001 = Clock output (SYSCLK/OPCLKDIV)               |
|                     |                     |          | 0010 = Logic '0'                                    |
|                     |                     |          | 0011 = Logic '1'                                    |
|                     |                     |          | 0100 = PLL Lock output                              |
|                     |                     |          | 0101 = Temperature OK output                        |
|                     |                     |          | 0110 = SDOUT data output                            |
|                     |                     |          | 0111 = IRQ output                                   |
|                     |                     |          | 1000 = MIC Detect                                   |
|                     |                     |          | 1001 = MIC Short Circuit Detect                     |
|                     |                     |          | 1010 to 1111 = Reserved                             |
|                     | GPIn_ENA            | 0b       | GPIn Input Pin Enable                               |
|                     | (n = 7, 8)          |          | 0 = pin disabled as GPIn input                      |
|                     |                     |          | 1 = pin enabled as GPIn input                       |

**Table 22 GPIO Function Control Bits** 

The polarity of GPIO/GPI inputs may be configured using the GPIO\_POL register bits. This is described in Table 23.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                  |
|---------------------|-----|----------|---------|------------------------------|
| R23 (17h)           | 7:0 | GPIO_POL | 00h     | GPIOn Input Polarity         |
|                     |     | [7:0]    |         | 0 = Non-inverted             |
|                     |     | (rw)     |         | 1 = Inverted                 |
|                     |     |          |         | GPIO_POL[7] = GPI8 polarity  |
|                     |     |          |         | GPIO_POL[6] = GPI7 polarity  |
|                     |     |          |         | GPIO_POL[5] = Reserved       |
|                     |     |          |         | GPIO_POL[4] = GPIO5 polarity |
|                     |     |          |         | GPIO_POL[3] = GPIO4 polarity |
|                     |     |          |         | GPIO_POL[2] = GPIO3 polarity |
|                     |     |          |         | GPIO_POL[1] = Reserved       |
|                     |     |          |         | GPIO_POL[0] = Reserved       |

Table 23 GPIO Polarity

Each of the available GPIO functions is described in turn in the following sections.



## **BUTTON CONTROL**

The WM8953 GPIO supports button control detection with full status readback for up to four inputs (and one IRQ output). All inputs are latched at the IRQ Register, with de-bounce available for normal operation. De-bouncing may be disabled in order to allow the device to respond to wake-up events while the processor is disabled and is unable to provide a clock for de-bouncing.

To enable button control and accessory detection, the following register settings are required:

- LMN3 = 0 (only required if using GPI7)
- RMN3 = 0 (only required if using GPI8)
- AIF\_TRIS = 0
- GPIOn\_SEL = 0000 for each required GPIO button input

Programmable pull-up and pull-down resistors are available on GPIO3, GPIO4 and GPIO5. These should be set according to the external circuit configuration. Note that pull-up and pull-down resistors are not available on the GPI7 and GPI8 input pins. Note that the analogue input paths to GPI7 and GPI8 must be disabled as described above when using these as digital inputs.

In this application, one or more of the GPIO pins may be configured as an Interrupt event if desired. This is controlled by the GPIOn\_IRQ\_ENA bits described in Table 21. The GPIO Pin status fields contained in the IRQ Register (R18) may be read at any time or else in response to an Interrupt event. See Table 30 for more details of the Interrupt function.

An example configuration of the button control GPIO function is illustrated in Figure 21.



Figure 21 Example of Button Control Using GPIO Pins

# Note:

- The GPIOs 3, 4, and 5 are referenced to DBVDD
- The GPIs 7 and 8 are referenced to AVDD

## MICBIAS CURRENT AND ACCESSORY DETECT

A MICBIAS current detect function is provided for accessory detection. When a microphone current is detected (e.g. when a headset is inserted), an interrupt event can be generated and the microphone status read back via the control interface.

The MICBIAS current detect threshold is programmable. A short-circuit current detection is also available, with a programmable threshold. These functions are enabled by register bit MCD; the thresholds are programmable via register fields MCDTHR and MCDSCTR as shown in Table 24. Current detect and short circuit detect thresholds are subject to a +/- 30% temperature, supply and part-to-part variation. This should be factored into any application design.

The polarity of the current detect GPIO signals may be controlled by register bits MICDET\_POL and MICSHRT\_POL. Note that these polarity inversion bits apply to the Interrupt register behaviour only; they do not affect the direct GPIO output of the Current Detect functions. The respective interrupt events may be masked or enabled by register bits MICDET\_IRQ\_ENA and MICSHRT\_IRQ\_ENA. The MICBIAS current threshold status bits contained in the IRQ Register (R18) may be read at any time or else in response to an Interrupt event. See Table 30 for more details of the Interrupt function.

If direct output of the MICBIAS current detect function is required to the external pins of the WM8953, the following register settings are required:

- AIF\_TRIS = 0
- GPIOn\_SEL = 1000 for the selected GPIO MICBIAS Current Detect output pin
- GPIOn\_SEL = 1001 for the selected GPIO MICBIAS Short Circuit Detect output pin
- GPIOn\_PU = 0 for the selected GPIO MICBIAS output pin or pins
- GPIOn\_PD = 0 for the selected GPIO MICBIAS output pin or pins

The register fields used to configure the MICBIAS Current Detect function are described in Table 24.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                                        |
|---------------------|-----|-------------|---------|--------------------------------------------------------------------|
| R58 (3Ah)           | 7:6 | MCDSCTH     | 00b     | MICBIAS Short Circuit Detect Threshold                             |
|                     |     | [1:0]       |         | 00 = 600uA                                                         |
|                     |     |             |         | 01 = 1200uA                                                        |
|                     |     |             |         | 10 = 1800uA                                                        |
|                     |     |             |         | 11 = 2400uA                                                        |
|                     |     |             |         | These values are for AVDD=3.3V and scale proportionally with AVDD. |
|                     | 5:3 | MCDTHR      | 000b    | MICBIAS Current Detect Threshold                                   |
|                     |     | [2:0]       |         | 000 = 200uA                                                        |
|                     |     |             |         | 001 = 350uA                                                        |
|                     |     |             |         | 010 = 500uA                                                        |
|                     |     |             |         | 011 = 650uA                                                        |
|                     |     |             |         | 100 = 800uA                                                        |
|                     |     |             |         | 101 = 950uA                                                        |
|                     |     |             |         | 110 = 1100uA                                                       |
|                     |     |             |         | 111 = 1250uA                                                       |
|                     |     |             |         | These values are for AVDD=3.3V and scale proportionally with AVDD. |
|                     | 2   | MCD         | 0b      | MICBIAS Current and Short Circuit Detect Enable                    |
|                     |     |             |         | 0 = disabled                                                       |
|                     |     |             |         | 1 = enabled                                                        |
| R23 (17h)           | 10  | MICSHRT_POL | 0b      | MICBIAS short circuit detect polarity                              |
|                     |     | (rw)        |         | 0 = Non-inverted                                                   |
|                     |     |             |         | 1 = Inverted                                                       |
|                     | 9   | MICDET_POL  | 0b      | MICBIAS current detect polarity                                    |
|                     |     | (rw)        |         | 0 = Non-inverted                                                   |
|                     |     |             |         | 1 = Inverted                                                       |



| REGISTER<br>ADDRESS | BIT | LABEL           | DEFAULT | DESCRIPTION                             |
|---------------------|-----|-----------------|---------|-----------------------------------------|
| R22 (16h)           | 10  | MICSHRT_IRQ_ENA | 0b      | MICBIAS short circuit detect IRQ Enable |
|                     |     |                 |         | 0 = disabled                            |
|                     |     |                 |         | 1 = enabled                             |
|                     | 9   | MICDET_IRQ_ENA  | 0b      | MICBIAS current detect IRQ Enable       |
|                     |     |                 |         | 0 = disabled                            |
|                     |     |                 |         | 1 = enabled                             |

**Table 24 MICBIAS Current Detect Control** 

The current detect function operates according to the following the truth table:

| LABEL                    | VALUE | DESCRIPTION                            |
|--------------------------|-------|----------------------------------------|
| Mic Short Circuit Detect | 0     | MCDSCTH current threshold not exceeded |
| Mic Short Circuit Detect | 1     | MCDSCTH current threshold exceeded     |
| Mic Current Detect       | 0     | MCDTHR current threshold not exceeded  |
| Mic Current Detect       | 1     | MCDTHR current threshold exceeded      |

Table 25 Truth Table for GPIO Output of MICBIAS Current Detect Function

## **CLOCK OUTPUT**

A clock output (OPCLK) derived from SYSCLK may be output via GPIO3, GPIO4 or GPIO5. SYSCLK is derived from MCLK (either directly, or in conjunction with the PLL), and is used to provide all internal clocking for the WM8953 (see "Clocking and Sample Rates" section for more information).

A programmable clock divider OPCLKDIV controls the frequency of the OPCLK output. This clock is enabled by register bit OPCLK\_ENA. See "Clocking and Sample Rates" for a definition of this register field.

To enable clock output via one or more GPIO pins, the following register settings are required:

- AIF\_TRIS = 0
- GPIOn\_SEL = 0001 for the selected GPIO clock output pin
- GPIOn\_PU = 0 for the selected GPIO clock output pin
- GPIOn\_PD = 0 for the selected GPIO clock output pin



## **TEMPERATURE SENSOR OUTPUT**

To protect the device from overheating a thermal shutdown function is provided (see "Thermal Shutdown" section for more information).

The polarity of the Thermal Shutdown sensor may be controlled by register bit TEMPOK\_POL. Note that this polarity inversion bit applies to the Interrupt register behaviour only; it does not affect the direct GPIO output of the Temperature Sensor function. The associated interrupt event may be masked or enabled by register bit TEMPOK\_IRQ\_ENA. The Temperature status bit contained in the IRQ Register (R18) may be read at any time or else in response to an Interrupt event. See Table 30 for more details of the Interrupt function.

If direct output of the Temperature status bit is required to the external pins of the WM8953, the following register settings are required:

- AIF\_TRIS = 0
- GPIOn\_SEL = 0101 for the selected GPIO Temperature status output pin
- GPIOn\_PU = 0 for the selected GPIO Temperature status output pin
- GPIOn\_PD = 0 for the selected GPIO Temperature status output pin

The register fields used to configure the Temperature Sensor GPIO function are described in Table 26

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                   |
|---------------------|-----|-------------|---------|-------------------------------|
| R23 (17h)           | 11  | TEMPOK_POL  | 1b      | Temperature Sensor polarity   |
|                     |     | (rw)        |         | 0 = Non-inverted              |
|                     |     |             |         | 1 = Inverted                  |
| R22 (16h)           | 11  | TEMPOK_IRQ_ | 0b      | Temperature Sensor IRQ Enable |
|                     |     | ENA         |         | 0 = disabled                  |
|                     |     |             |         | 1 = enabled                   |

Table 26 Temperature Sensor GPIO Control

The temperature sensor function operates according to the following truth table:

| LABEL                     | VALUE | DESCRIPTION                       |
|---------------------------|-------|-----------------------------------|
| Temperature Sensor output | 0     | Overheat temperature exceeded     |
| Temperature Sensor output | 1     | Overheat temperature not exceeded |

Table 27 Truth Table for GPIO Output of Temperature Sensor Function

## **PLL LOCK OUTPUT**

An internal signal used to indicate the lock status of the PLL can be output to a GPIO pin or used to trigger an Interrupt event. The polarity of the PLL Lock indication may be controlled by register bit PLL\_LCK\_POL. Note that this polarity inversion bit applies to the Interrupt register behaviour only; it does not affect the direct GPIO output of the PLL Lock function. The associated interrupt event may be masked or enabled by register bit PLL\_LCK\_IRQ\_ENA. The PLL Lock status bit in the IRQ Register (R18) may be read at any time or else in response to an Interrupt event. See Table 30 for more details of the Interrupt function.

If direct output of the PLL Lock status bit is required to the external pins of the WM8953, the following register settings are required:

- AIF\_TRIS = 0
- GPIOn\_SEL = 0100 for the selected PLL Lock status output pin
- GPIOn\_PU = 0 for the selected PLL Lock status output pin
- GPIOn\_PD = 0 for the selected PLL Lock status output pin

The register fields used to configure the PLL Lock GPIO function are described in Table 28.

| REGISTER<br>ADDRESS | BIT | LABEL               | DEFAULT | DESCRIPTION                                     |
|---------------------|-----|---------------------|---------|-------------------------------------------------|
| R23 (17h)           | 8   | PLL_LCK_POL (rw)    | 0b      | PLL Lock polarity 0 = Non-inverted 1 = Inverted |
| R22 (16h)           | 8   | PLL_LCK_IRQ_<br>ENA | 0b      | PLL Lock IRQ Enable 0 = disabled 1 = enabled    |

Table 28 PLL Lock GPIO Control

The PLL Lock function operates according to the following truth table:

| LABEL           | VALUE | DESCRIPTION    |
|-----------------|-------|----------------|
| PLL Lock output | 0     | PLL not Locked |
| PLL Lock output | 1     | PLL Locked     |

Table 29 Truth Table for GPIO Output of PLL Lock Function

# LOGIC '1' AND LOGIC '0' OUTPUT

The GPIO pins can be programmed to drive a logic high or logic low signal. The following register settings are required:

- AIF TRIS = 0
- GPIOn\_SEL = 0010 for each Logic '0' output pin
- GPIOn\_SEL = 0011 for each Logic '1' output pin
- GPIOn\_PU = 0 for each Logic '0' or Logic '1' GPIO pin
- GPIOn\_PD = 0 for each Logic '0' or Logic '1' GPIO pin



## INTERRUPT EVENT OUTPUT

An interrupt can be generated by any of the following events described earlier:

- Button Control input (on GPIO3, GPIO4, GPIO5, GPI7 or GPI8)
- MICBIAS current / short circuit / accessory detect
- PLL Lock
- Temperature Sensor

The interrupt status flag IRQ is asserted when any un-masked Interrupt input is asserted. It is the OR'd combination of all the un-masked Interrupt inputs. If required, this flag may be inverted using the IRQ\_INV register bit. The GPIO pins can be configured to output the IRQ signal.

The interrupt behaviour is driven by level detection (not edge detection) of the un-masked inputs. Therefore, if an input remains asserted after the interrupt register has been reset, then the interrupt status flag IRQ will be triggered again even though no transition has occurred. If edge detection is required (eg. confirming that the input has been de-asserted), then the polarity inversion may be used after each event in order to detect each rising and falling edge separately. This is described further in the "GPIO Summary" section.

The status of the IRQ flag may be read back via the control interface. The status of each GPIO pin and the internal signals PLL\_LCK, TEMPOK, MICSHRT and MICDET may also be read back in the same way.

The IRQ register (R18) is described in Table 30. The status of the GPIO pins or other Interrupt inputs can be read back via the read/write bits R18[11:0]. The Interrupt inputs are latched once set. Each input may be reset by writing a 1 to the appropriate bit. The IRQ bit cannot be reset; it is the OR'd combination of all other registers and will reset only if R18[11:0] are all 0.

If direct output of the Interrupt signal is required to external pins of the WM8953, the following register settings are required:

- AIF\_TRIS = 0
- GPIOn\_SEL = 0111 for the selected Interrupt (IRQ) output pin
- GPIOn\_PU = 0 for the selected Interrupt (IRQ) output pin
- GPIOn PD = 0 for the selected Interrupt (IRQ) output pin



The IRQ register (R18) is described in Table 30.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT   | DESCRIPTION                        |
|---------------------|-----|-------------|-----------|------------------------------------|
| R18 (12h)           | 12  | IRQ         | Read Only | IRQ Readback                       |
|                     |     | (ro)        |           | (Allows polling of IRQ status)     |
|                     | 11  | TEMPOK      | Read or   | Temperature OK status              |
|                     |     | (rr)        | Reset     | Read-                              |
|                     |     |             |           | 0 = Device temperature NOT ok      |
|                     |     |             |           | 1 = Device temperature ok          |
|                     |     |             |           | Write -                            |
|                     |     |             |           | 1 = Reset TEMPOK latch             |
|                     | 10  | MICSHRT     | Read or   | MICBIAS short status               |
|                     |     | (rr)        | Reset     | Read-                              |
|                     |     |             |           | 0 = MICBIAS ok                     |
|                     |     |             |           | 1 = MICBIAS shorted                |
|                     |     |             |           | Write-                             |
|                     |     |             |           | 1 = Reset MICSHRT latch            |
|                     | 9   | MICDET      | Read or   | MICBIAS detect status              |
|                     |     | (rr)        | Reset     | MICBIAS microphone detect Readback |
|                     |     |             |           | Read-                              |
|                     |     |             |           | 0 = No Microphone detected         |
|                     |     |             |           | 1 = Microphone detected            |
|                     |     |             |           | Write-                             |
|                     |     |             |           | 1 = Reset MICDET latch             |
|                     | 8   | PLL_LCK     | Read or   | PLL Lock status                    |
|                     |     | (rr)        | Reset     | Read-                              |
|                     |     |             |           | 0 = PLL NOT locked                 |
|                     |     |             |           | 1 = PLL locked                     |
|                     |     |             |           | Write-                             |
|                     |     |             |           | 1 = Reset PLL_LCK latch            |
|                     | 7:0 | GPIO_STATUS | Read or   | GPIO and GPI Input Pin Status      |
|                     |     | [7:0]       | Reset     | GPIO_STATUS[7] = GPI8 pin status   |
|                     |     | (rr)        |           | GPIO_STATUS[6] = GPI7 pin status   |
|                     |     |             |           | GPIO_STATUS[5] = Reserved          |
|                     |     |             |           | GPIO_STATUS[4] = GPIO5 status      |
|                     |     |             |           | GPIO_STATUS[3] = GPIO4 status      |
|                     |     |             |           | GPIO_STATUS[2] = GPIO3 status      |
|                     |     |             |           | GPIO_STATUS[1] = Reserved          |
|                     |     |             |           | GPIO_STATUS[0] = Reserved          |
| R23 (17h)           | 12  | IRQ_INV     | 0b        | IRQ Invert                         |
| GPIO                |     | (rw)        |           | 0 = IRQ output active high         |
| Control (2)         |     |             |           | 1 = IRQ output active low          |

Table 30 GPIO Interrupt and Status Readback

# **SERIAL DATA OUTPUT (REGISTER READBACK)**

The GPIO pins can be configured to output serial data during register readback in 3-wire (open-drain) or 4-wire mode. The readback mode is configured using the register bits RD\_3W\_ENA and MODE 3W4W as described in Table 31.

Setting the RD\_3W\_ENA bit to 1 enables 3-wire readback using the SDIN pin in open-drain mode. Setting the RD\_3W\_ENA bit to 0 requires the use of a GPIO pin as SDOUT. To enable SDOUT on a GPIO pin, the following register settings are required:

- AIF\_TRIS = 0
- GPIOn\_SEL = 0110 for the selected SDOUT output pin
- GPIOn\_PU = 0 for the selected SDOUT output pin
- GPIOn\_PD = 0 for the selected SDOUT output pin

The register fields used to configure SDOUT on the GPIO pins are described in Table 31. Refer to "Control Interface" for more details of 3-wire and 4-wire interfacing.

| REGISTER<br>ADDRESS | BIT | LABEL     | DEFAULT | DESCRIPTION                        |
|---------------------|-----|-----------|---------|------------------------------------|
| R22 (16h)           | 15  | RD_3W_ENA | 1b      | 3- / 4-wire readback configuration |
|                     |     |           |         | 1 = 3-wire mode                    |
|                     |     |           |         | 0 = 4-wire mode, using GPIO pin    |
|                     | 14  | MODE_3W4W | 0b      | 3-wire mode                        |
|                     |     |           |         | 0 = push 0/1                       |
|                     |     |           |         | 1 = open-drain                     |
|                     |     |           |         | 4-wire mode                        |
|                     |     |           |         | 0 = push 0/1                       |
|                     |     |           |         | 1 = wired-OR                       |

Table 31 GPIO 3-Wire Readback Enable



# GPIO SUMMARY

The GPIO functions are summarised in Figure 22.



Figure 22 GPIO Control Diagram

Ma molfson

Details of the GPIO implementation are shown below. In order to avoid GPIO loops if a GPIO is configured as an output the corresponding input is disabled, as shown in Figure 23 below.



Figure 23 GPIO Pad

The GPIO register, i.e. latch structure, is shown in Figure 24 below. The de-bounce Control fields GPIOn\_DEB\_ENA determine whether the signal is de-bounced or not. (Note that TOCLK (via SYSCLK) needs to be present in order for the debounce circuit to work.) The polarity bits GPIO\_POL[7:0] control whether an interrupt is triggered by a logic 1 level (for GPIO\_POL[n] = 0) or a logic 0 level (for GPIO\_POL[n] = 1). The latch will cause the interrupt to be stored until it is reset by writing to the Interrupt Register. The latched signal is processed by the IRQ circuit, shown in Figure 22 above. The interrupt status bits can be read at any time from Register R18 (see Table 30) and are reset by writing a "1" to the applicable bit in Register R18.

Note that the interrupt behaviour is driven by level detection (not edge detection). Therefore, if an input remains asserted after the interrupt register has been reset, then the interrupt event will be triggered again even though no transition has occurred. If edge detection is required, this may be implemented as described in the following paragraphs.



Figure 24 GPIO Function

Three typical scenarios are presented in the following Figure 25, Figure 26 and Figure 27. The examples are:

- Latch a GPIO input (Figure 25)
- Debounce and latch a GPIO input (Figure 26)
- Use the GPIOn\_POL bit to implement an IRQ edge detect function (Figure 27)

The GPIO input or internal Interrupt event (eg. MICBIAS current detect) is latched as illustrated below:



Figure 25 GPIO Latch

The de-bounce function on the GPIO input pins enables transient behaviour to be filtered as illustrated below:



Figure 26 GPIO De-bounce

To implement an edge detect function on a GPIO input, the GPIOn\_POL bits may be used to alternate the GPIO polarity after each edge transition. For example, after a logic 1 has caused an Interrupt event, the polarity may be inverted prior to resetting the Interrupt register bit. In this way, the next interrupt event generated by this GPIO will occur when it returns to the logic 0 state. The GPIOn\_POL bit must be reversed after every GPIO edge transition, as illustrated below:



Figure 27 GPIO Edge Detect

# **GPIO IRQ HANDLING**

In the following diagram Figure 28 a typical IRQ scenario is illustrated.



Figure 28 GPIO IRQ Handling

# **DIGITAL AUDIO INTERFACE**

The digital audio interface is used for outputting ADC data from the WM8953. It uses three pins:

ADCDAT: ADC data output

ADCLRC: ADC data alignment clock

BCLK: Bit clock, for synchronisation

The clock signals BCLK and ADCLRC can be outputs when the WM8953 operates as a master, or inputs when it is a slave (see Master and Slave Mode Operation, below).

Four different audio data formats are supported:

- Left justified
- Right justified
- I<sup>2</sup>S
- DSP mode

All four of these modes are MSB first. They are described in Audio Data Formats, below. Refer to the "Electrical Characteristics" section for timing information.

Time Division Multiplexing (TDM) is available in all four data format modes. The WM8953 can be programmed to send and receive data in one of two time slots.

PCM operation is supported using the DSP mode.

## **MASTER AND SLAVE MODE OPERATION**

The WM8953 digital audio interface can operate as a master or slave as shown in Figure 29 and Figure 30.



Figure 29 Master Mode

Figure 30 Slave Mode

The dual Audio Interface approach of the WM8953 has been implemented in such a way that it gives the user and application as much flexibility as possible. The application needs to be carefully analysed and the WM8953 configured accordingly. The Audio Interface Output Control is illustrated in Figure 31.



Figure 31 Audio Interface Output Control

The Audio Interface output control is illustrated above. The master mode control register AIF\_MSTR and the left-right clock control register ADCLRC\_DIR determine whether the WM8953 generates the associated clocks. These registers are described in Table 32 below.

| REGISTER<br>ADDRESS | BIT | LABEL      | DEFAULT | DESCRIPTION                                      |
|---------------------|-----|------------|---------|--------------------------------------------------|
| R8 (08h)            | 15  | AIF_MSTR   | 0b      | Audio Interface Master Mode Select               |
|                     |     |            |         | 0 = Slave mode                                   |
|                     |     |            |         | 1 = Master mode                                  |
|                     | 11  | ADCLRC_DIR | 0b      | ADCLRC Direction                                 |
|                     |     |            |         | (Forces ADCLRC clock to be output in slave mode) |
|                     |     |            |         | 0 = ADCLRC normal operation                      |
|                     |     |            |         | 1 = ADCLRC clock output enabled                  |

**Table 32 Audio Interface Output Function Control** 

# **OPERATION WITH TDM**

Time division multiplexing (TDM) allows multiple devices to transfer data simultaneously on the same bus. The WM8953 supports TDM in master and slave modes for all data formats and word lengths. TDM is enabled using register bit AIFADC\_TDM. The TDM data slot is programmed using register bit AIFADC\_TDM CHAN.



Figure 32 TDM with WM8953 as Master

Figure 33 TDM with Other ADC as Master



Figure 34 TDM with Processor as Master

**Note:** The WM8953 is a 24-bit device. If the user operates the WM8953 in 32-bit mode then the 8 LSBs are not driven. It is therefore recommended to add a pull-down resistor if necessary to the ADCDAT line in TDM mode.

# **BCLK DIVIDE**

The BCLK frequency is controlled by BCLK\_DIV. The BCLK frequency must be set appropriately to support the sample rate of the ADC.

Internal clock divide and phase control mechanisms ensure that the BCLK and ADCLRC edges will occur in a predictable and repeatable position relative to each other and to the data for a given combination of ADC sample rate and BCLK\_DIV settings.

See "Clocking and Sample Rates" section for more information.



# **AUDIO DATA FORMATS (NORMAL MODE)**

In Right Justified mode, the LSB is available on the last rising edge of BCLK before a ADCLRC transition. All other bits are transmitted before (MSB first). Depending on word length, BCLK frequency and sample rate, there may be unused BCLK cycles after each ADCLRC transition.



Figure 35 Right Justified Audio Interface (assuming n-bit word length)

In Left Justified mode, the MSB is available on the first rising edge of BCLK following a ADCLRC transition. The other bits up to the LSB are then transmitted in order. Depending on word length, BCLK frequency and sample rate, there may be unused BCLK cycles before each ADCLRC transition.



Figure 36 Left Justified Audio Interface (assuming n-bit word length)

In  $1^2$ S mode, the MSB is available on the second rising edge of BCLK following a ADCLRC transition. The other bits up to the LSB are then transmitted in order. Depending on word length, BCLK frequency and sample rate, there may be unused BCLK cycles between the LSB of one sample and the MSB of the next.



Figure 37 I2S Justified Audio Interface (assuming n-bit word length)

In DSP mode, the left channel MSB is available on either the 1<sup>st</sup> (mode B) or 2<sup>nd</sup> (mode A) rising edge of BCLK (selectable by AIF\_LRCLK\_INV) following a rising edge of ADCLRC. Right channel data immediately follows left channel data. Depending on word length, BCLK frequency and sample rate, there may be unused BCLK cycles between the LSB of the right channel data and the next sample.

In device master mode, the ADCLRC output will resemble the frame pulse shown in Figure 38 and Figure 39. In device slave mode, Figure 40 and Figure 41, it is possible to use any length of frame pulse less than 1/fs, providing the falling edge of the frame pulse occurs greater than one BCLK period before the rising edge of the next frame pulse.



Figure 38 DSP Mode Audio Interface (mode A, AIF\_LRCLK\_INV=0, Master)



Figure 39 DSP Mode Audio Interface (mode B, AIF\_LRCLK\_INV=1, Master)



Figure 40 DSP Mode Audio Interface (mode A, AIF\_LRCLK\_INV=0, Slave)





Figure 41 DSP Mode Audio Interface (mode B, AIF\_LRCLK\_INV=1, Slave)

PCM operation is supported in DSP interface mode. WM8953 ADC data that is output on the Left Channel will be read as mono PCM data by the receiving equipment.

# **AUDIO DATA FORMATS (TDM MODE)**

TDM is supported in master and slave mode and is enabled by register bit AIF\_ADC\_TDM. All audio interface data formats support time division multiplexing (TDM).

Two time slots are available (Slot 0 and Slot 1), selected by register bit AIFADC\_TDM\_CHAN.

When TDM is enabled, the ADCDAT pin will be tri-stated immediately before and immediately after data transmission, to allow another ADC device to drive this signal line for the remainder of the sample period. Note that it is important that two ADC devices do not attempt to drive the data pin simultaneously. A short circuit may occur if the transmission time of the two ADC devices overlap with each other. See "Audio Interface Timing - TDM Mode" for details of the ADCDAT output relative to BCLK signal. Note that it is possible to ensure a gap exists between transmissions by setting the transmitted word length to a value higher than the actual length of the data. For example, if 32-bit word length is selected where only 24-bit data is available, then the WM8953 interface will tri-state after transmission of the 24-bit data, ensuring a gap after the WM8953's TDM slot.

When TDM is enabled, BCLK frequency must be high enough to allow data from both time slots to be transferred. The relative timing of Slot 0 and Slot 1 depends upon the selected data format as shown in Figure 42 to Figure 46.



Figure 42 TDM in Right-Justified Mode



Figure 43 TDM in Left-Justified Mode



Figure 44 TDM in I<sup>2</sup>S Mode



Figure 45 TDM in DSP Mode A



Figure 46 TDM in DSP Mode B

# **DIGITAL AUDIO INTERFACE CONTROL**

The register bits controlling audio data format, word length, left/right channel data source and TDM are summarised in Table 33.

| REGISTER<br>ADDRESS | BIT | LABEL        | DEFAULT  | DESCRIPTION                                                                 |
|---------------------|-----|--------------|----------|-----------------------------------------------------------------------------|
| R4 (04h)            | 15  | AIFADCL_SRC  | 0b       | Left ADC Data Source Select                                                 |
|                     |     |              |          | 0 = Left ADC data is output on left channel                                 |
|                     |     |              |          | 1 = Right ADC data is output on left channel                                |
|                     | 14  | AIFADCR_SRC  | 1b       | Right ADC Data Source Select                                                |
|                     |     |              |          | 0 = Left ADC data is output on right channel                                |
|                     |     |              |          | 1 = Right ADC data is output on right channel                               |
|                     | 13  | AIFADC_TDM   | 0b       | ADC TDM Enable                                                              |
|                     |     | _            |          | 0 = Normal ADCDAT operation                                                 |
|                     |     |              |          | 1 = TDM enabled on ADCDAT                                                   |
|                     | 12  | AIFADC_TDM_  | 0b       | ADCDAT TDM Channel Select                                                   |
|                     |     | CHAN         |          | 0 = ADCDAT outputs data on slot 0                                           |
|                     |     |              |          | 1 = ADCDAT output data on slot 1                                            |
|                     | 8   | AIF_BCLK_INV | 0b       | BCLK Invert                                                                 |
|                     |     |              |          | 0 = BCLK not inverted                                                       |
|                     |     |              |          | 1 = BCLK inverted                                                           |
|                     | 7   | AIF_LRCLK_IN | 0b       | Right, left and I <sup>2</sup> S modes – LRCLK polarity                     |
|                     |     | V            |          | 0 = normal LRCLK polarity                                                   |
|                     |     |              |          | 1 = invert LRCLK polarity                                                   |
|                     |     |              |          | DSP Mode – mode A/B select                                                  |
|                     |     |              |          | 0 = MSB is available on 2nd BCLK rising edge after LRC rising edge (mode A) |
|                     |     |              |          | 1 = MSB is available on 1st BCLK rising                                     |
|                     | 0.5 | A.E. 14/1    | 401-     | edge after LRC rising edge (mode B)                                         |
|                     | 6:5 | AIF_WL       | 10b      | Digital Audio Interface Word Length                                         |
|                     |     | [1:0]        |          | 00 = 16 bits                                                                |
|                     |     |              |          | 01 = 20 bits                                                                |
|                     |     |              |          | 10 = 24 bits                                                                |
|                     |     |              |          | 11 = 32 bits                                                                |
|                     |     |              |          | Note - see "Companding" for the selection of 8-bit mode.                    |
|                     | 4:3 | AIF_FMT      | 10b      | Digital Audio Interface Format                                              |
|                     |     | [1:0]        |          | 00 = Right justified                                                        |
|                     |     |              |          | 01 = Left justified                                                         |
|                     |     |              |          | 10 = I <sup>2</sup> S Format                                                |
|                     |     |              | <u> </u> | 11 = DSP Mode                                                               |

Table 33 Audio Data Format Control

## **AUDIO INTERFACE OUTPUT AND GPIO TRISTATE**

Register bit AIF\_TRIS can be used to tristate the audio interface and GPIO pins as described in Table 34.

All GPIO pins and digital audio interface pins will be tristated by this function, regardless of the state of other registers which control these pin configurations.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                                        |
|---------------------|-----|----------|---------|----------------------------------------------------|
| R9 (09h)            | 13  | AIF_TRIS | 0       | Audio Interface and GPIO Tristate                  |
|                     |     |          |         | 0 = Audio interface and GPIO pins operate normally |
|                     |     |          |         | 1 = Tristate all audio interface and GPIO pins     |

Table 34 Tri-stating the Audio Interface and GPIO Pins



## MASTER MODE BCLK AND ADCLRC ENABLE

The audio interface pins BCLK, ADCLRC and ADCDAT can be independently programmed to operate in master mode or slave mode using register bit AIF\_MSTR.

When the audio interface is operating in slave mode, the BCLK and ADCLRC clock outputs to these pins are by default disabled to allow the digital audio source to drive these pins.

It is also possible to force the ADCLRC to be output using register bit ADCLRC\_DIR, allowing mixed master and slave mode.

The clock generators for the audio interface are enabled according to the control signals shown in Figure 47.



Figure 47 Clock Output Control

| REGISTER<br>ADDRESS | BIT  | LABEL       | DEFAULT | DESCRIPTION                                      |
|---------------------|------|-------------|---------|--------------------------------------------------|
| R8 (08h)            | 15   | AIF_MSTR    | 0b      | Audio Interface Master Mode Select               |
|                     |      |             |         | 0 = Slave mode                                   |
|                     |      |             |         | 1 = Master mode                                  |
|                     | 11   | ADCLRC_DIR  | 0b      | ADCLRC Direction                                 |
|                     |      |             |         | (Forces ADCLRC clock to be output in slave mode) |
|                     |      |             |         | 0 = ADCLRC normal operation                      |
|                     |      |             |         | 1 = ADCLRC clock output enabled                  |
|                     | 10:0 | ADCLRC_RATE | 040h    | ADCLRC Rate                                      |
|                     |      | [10:0]      |         | ADCLRC clock output = BCLK /<br>ADCLRC_RATE      |
|                     |      |             |         | Integer (LSB = 1)<br>Valid from 82047            |

Table 35 Digital Audio Interface Clock Output Control

## **COMPANDING**

The WM8953 supports A-law and μ-law companding. This is selected as shown in Table 36.

| REGISTER<br>ADDRESS | BIT | LABEL        | DEFAULT | DESCRIPTION           |
|---------------------|-----|--------------|---------|-----------------------|
| R5 (05h)            | 2   | ADC_COMP     | 0b      | ADC Companding Enable |
|                     |     |              |         | 0 = disabled          |
|                     |     |              |         | 1 = enabled           |
|                     | 1   | ADC_COMPMODE | 0b      | ADC Companding Type   |
|                     |     |              |         | 0 = μ-law             |
|                     |     |              |         | 1 = A-law             |

**Table 36 Companding Control** 

Companding involves using a piecewise linear approximation of the following equations (as set out by ITU-T G.711 standard) for data compression:

 $\mu$ -law (where  $\mu$ =255 for the U.S. and Japan):

$$F(x) = \ln(1 + \mu|x|) / \ln(1 + \mu)$$
  $-1 \le x \le 1$ 

A-law (where A=87.6 for Europe):

$$F(x) = A|x| / (1 + InA)$$
 for  $x \le 1/A$  
$$F(x) = (1 + InA|x|) / (1 + InA)$$
 for  $1/A \le x \le 1$ 

The companded data is also inverted as recommended by the G.711 standard (all 8 bits are inverted for  $\mu$ -law, all even data bits are inverted for A-law). The data will be transmitted as the first 8 MSBs of data.

Companding converts 13 bits ( $\mu$ -law) or 12 bits (A-law) to 8 bits using non-linear quantization. This provides greater precision for low amplitude signals than for high amplitude signals, resulting in a greater usable dynamic range than 8 bit linear quantization. The companded signal is an 8-bit word comprising sign (1 bit), exponent (3 bits) and mantissa (4 bits).

8-bit mode is selected whenever ADC\_COMP=1. The use of 8-bit data allows samples to be passed using as few as 8 BCLK cycles per LRC frame. When using DSP mode B, 8-bit data words may be transferred consecutively every 8 BCLK cycles.

8-bit mode (without Companding) may be enabled by setting ADC\_COMPMODE=1, when ADC\_COMP=0.

| BIT7 | BIT[6:4] | BIT[3:0] |  |  |
|------|----------|----------|--|--|
| SIGN | EXPONENT | MANTISSA |  |  |

Table 37 8-bit Companded Word Composition



Figure 48 µ-Law Companding



Figure 49 A-Law Companding

# **CLOCKING AND SAMPLE RATES**

The internal clocks for the ADCs, DSP core functions and digital audio interface are derived from a common internal clock source, SYSCLK.

SYSCLK can either be derived directly from MCLK, or may be generated from a PLL using MCLK as an external reference. Many commonly-used audio sample rates can be derived directly from typical MCLK frequencies; the PLL provides additional flexibility for a wide range of MCLK frequencies. All clock configurations must be set up before enabling playback to avoid glitches.

The ADC sample rate is selectable, relative to SYSCLK, using ADC\_CLKDIV. This must be set according to the required sampling frequency and depending on the selected clocking mode (AIF\_LRCLKRATE).

In master mode, BCLK is also derived from SYSCLK via a programmable division set by BCLK\_DIV. The BCLK frequency must be set appropriately to support the sample rate of the ADC. The ADCLRC signal does not automatically match the ADC sample rate; this must be configured using ADCLRC\_RATE as described under "Digital Audio Interface Control".

A clock (OPCLK) derived from SYSCLK can be output on the GPIO pins to provide clocking for other parts of the system. This clock is enabled by OPCLK\_ENA and its frequency is set by OPCLKDIV.

A slow clock (TOCLK) derived from SYSCLK can be used to de-bounce the button/accessory detect inputs, and to set the timeout period for volume updates when zero-cross detect is used. This clock is enabled by TOCLK\_ENA and its frequency is set by TOCLK\_RATE.

Table 38 to Table 43 show the clocking and sample rate controls for MCLK input, BCLK output (in master mode), ADCs, and GPIO clock output.

The overall clocking scheme for the WM8953 is illustrated in Figure 50.



Figure 50 Clocking Scheme

## SYSCLK CONTROL

MCLK may be inverted by setting register bit MCLK\_INV. Note that it is not recommended to change the control bit MCLK\_INV while the WM8953 is processing data as this may lead to clock glitches and signal pop and clicks.

The SYSCLK\_SRC bit is used to select the source for SYSCLK. The source may be either MCLK or the PLL output. The selected source is divided by the SYSCLK pre-divider MCLK\_DIV to generate SYSCLK. The selected source may also be adjusted by the MCLK\_DIV divider. These register fields are described in Table 38. See "PLL" for more details of the Phase Locked Loop clock generator.

The WM8953 supports glitch-free SYSCLK source selection. When both clock sources are running and SYSCLK\_SRC is modified to select one of these clocks, a glitch-free clock transition will take place. The de-glitching circuit will ensure that the minimum pulse width will be no less than the pulse width of the faster of the two clock sources.

When the initial clock source is to be disabled before changing to the new clock source, the CLK\_FORCE bit must also be used to force the clock source transition to take place. In this case, glitch-free operation cannot be guaranteed.

| BIT   | LABEL             | DEFAULT                            | DESCRIPTION                                                                                                                                     |
|-------|-------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 14    | SYSCLK_SRC        | 0b                                 | SYSCLK Source Select                                                                                                                            |
|       |                   |                                    | 0 = MCLK                                                                                                                                        |
|       |                   |                                    | 1 = PLL output                                                                                                                                  |
| 13    | CLK_FORCE         | 0b                                 | Forces Clock Source Selection                                                                                                                   |
|       |                   |                                    | 0 = Existing SYSCLK source (MCLK or PLL output) must be active when changing to a new clock source.                                             |
|       |                   |                                    | 1 = Allows existing MCLK source to be disabled before changing to a new clock source.                                                           |
| 12:11 | MCLK_DIV<br>[1:0] | 00b                                | SYSCLK Pre-divider. Clock source (MCLK or PLL output) will be divided by this value to generate SYSCLK.  00 = Divide SYSCLK by 1  01 = Reserved |
|       |                   |                                    | 10 = Divide SYSCLK by 2                                                                                                                         |
|       |                   |                                    | 11 = Reserved                                                                                                                                   |
| 10    | MCI K INIV        | θh                                 | MCI K Invert                                                                                                                                    |
| 10    | WICEK_IIV         | OD                                 | 0 = Master clock not inverted                                                                                                                   |
|       |                   |                                    | 1 = Master clock inverted                                                                                                                       |
|       | 13                | 13 CLK_FORCE  12:11 MCLK_DIV [1:0] | 13 CLK_FORCE 0b  12:11 MCLK_DIV 00b [1:0]                                                                                                       |

Table 38 MCLK and SYSCLK Control



## **ADC SAMPLE RATE**

The ADC sample rate is selectable, relative to SYSCLK, by setting the register fields ADC\_CLKDIV. This must be set according to the SYSCLK frequency, and according to the selected clocking mode.

Two clocking modes are provided - Normal Mode (AIF\_LRCLKRATE = 0) allows selection of the commonly used sample rates from typical audio system clocking frequencies (eg. 12.288MHz); USB Mode (AIF\_LRCLKRATE = 1) allows many of these sample rates to be generated from a 12MHz USB clock. Depending on the available clock sources, the USB mode may be used to save power by supporting 44.1kHz operation without requiring the PLL.

The AIF\_LRCLKRATE field must be set as described in Table 39 to ensure correct operation of internal functions according to the SYSCLK / Fs ratio. Table 40 describes the available sample rates using four different common MCLK frequencies.

In Normal mode, the programmable division set by ADC\_CLKDIV must ensure that a 256  $^{\star}$  ADC Fs clock is generated for the ADC DSP.

In USB mode, the programmable division set by ADC\_CLKDIV must ensure that a 272  $^{\star}$  ADC Fs clock is generated for the ADC DSP.

Note that in USB mode, the ADC sample rates do not match exactly with the commonly used sample rates (e.g. 44.118 kHz instead of 44.100 kHz). At most, the difference is less than 0.5%. Data recorded at 44.100 kHz sample rate and replayed at 44.118 kHz will experience a slight (sub 0.5%) pitch shift as a result of this difference. Note also that the USB mode cannot be used to generate a 48kHz samples rate from a 12MHz MCLK; the PLL should be used in this case.

| REGISTER<br>ADDRESS | BIT | LABEL        | DEFAULT | DESCRIPTION                |
|---------------------|-----|--------------|---------|----------------------------|
| R7 (07h)            | 7:5 | ADC_CLKDIV   | 000b    | ADC Sample Rate Divider    |
|                     |     | [2:0]        |         | 000 = SYSCLK / 1.0         |
|                     |     |              |         | 001 = SYSCLK / 1.5         |
|                     |     |              |         | 010 = SYSCLK / 2.0         |
|                     |     |              |         | 011 = SYSCLK / 3.0         |
|                     |     |              |         | 100 = SYSCLK / 4.0         |
|                     |     |              |         | 101 = SYSCLK / 5.5         |
|                     |     |              |         | 110 = SYSCLK / 6.0         |
|                     |     |              |         | 111= Reserved              |
| R10 (0Ah)           | 10  | AIF_LRCLKRAT | 0b      | LRCLK Rate                 |
|                     |     | Е            |         | 0 = Normal mode (256 * fs) |
|                     |     |              |         | 1 = USB mode (272 * fs)    |

Table 39 ADC Sample Rate Control



| SYSCLK        | ADC SAMPLE RATE<br>DIVIDER | CLOCKING MODE | ADC<br>SAMPLE RATE |
|---------------|----------------------------|---------------|--------------------|
|               | 000 = SYSCLK / 1           |               | 48 kHz             |
|               | 001 = SYSCLK / 1.5         |               | 32 kHz             |
|               | 010 = SYSCLK / 2           | Name          | 24 kHz             |
| 40 000 MH=    | 011 = SYSCLK / 3           | Normal        | 16 kHz             |
| 12.288 MHz    | 100 = SYSCLK / 4           | (256 * Fs)    | 12 kHz             |
|               | 101 = SYSCLK / 5.5         | (250 FS)      | Not used           |
|               | 110 = SYSCLK / 6           |               | 8 kHz              |
|               | 111 = Reserved             |               | Reserved           |
|               | 000 = SYSCLK / 1           |               | 44.1 kHz           |
|               | 001 = SYSCLK / 1.5         |               | Not used           |
|               | 010 = SYSCLK / 2           | Name          | 22.05 kHz          |
| 44 2006 MH=   | 011 = SYSCLK / 3           | Normal        | Not used           |
| 11.2896 MHz   | 100 = SYSCLK / 4           | (256 * Fs)    | 11.025 kHz         |
|               | 101 = SYSCLK / 5.5         | (250 FS)      | 8.018 kHz          |
|               | 110 = SYSCLK / 6           |               | Not used           |
|               | 111 = Reserved             |               | Reserved           |
|               | 000 = SYSCLK / 1           |               | 44.118 kHz         |
|               | 001 = SYSCLK / 1.5         |               | Not used           |
|               | 010 = SYSCLK / 2           | USB Mode      | 22.059 kHz         |
| 12 MHz        | 011 = SYSCLK / 3           | USB Mode      | Not used           |
| 12 IVITIZ     | 100 = SYSCLK / 4           | (272 * Fs)    | 11.029 kHz         |
|               | 101 = SYSCLK / 5.5         | (272 15)      | 8.021 kHz          |
|               | 110 = SYSCLK / 6           |               | Not used           |
|               | 111 = Reserved             |               | Reserved           |
|               | 000 = SYSCLK / 1           |               | 8 kHz              |
|               | 001 = SYSCLK / 1.5         |               | Not used           |
|               | 010 = SYSCLK / 2           | Normal        | Not used           |
| 2.048 MHz     | 011 = SYSCLK / 3           | INUIIIIAI     | Not used           |
| 2.040 IVII IZ | 100 = SYSCLK / 4           | (256 * Fs)    | Not used           |
|               | 101 = SYSCLK / 5.5         | (200 13)      | Not used           |
|               | 110 = SYSCLK / 6           |               | Not used           |
|               | 111 = Reserved             |               | Reserved           |

Table 40 ADC Sample Rates



# **BCLK CONTROL**

In Master Mode, BCLK is derived from SYSCLK via a programmable division set by BCLK\_DIV, as described in Table 41. BCLK\_DIV must be set to an appropriate value to ensure that there are sufficient BCLK cycles to transfer the complete data words from the ADCs.

In Slave Mode, BCLK is generated externally and appears as an input to the ADC. The host device must provide sufficient BCLK cycles to transfer complete data words from the ADCs.

| REGISTER<br>ADDRESS | BIT | LABEL    | DEFAULT | DESCRIPTION                  |
|---------------------|-----|----------|---------|------------------------------|
| R6 (06h)            | 4:1 | BCLK_DIV | 0100b   | BCLK Frequency (Master Mode) |
|                     |     | [3:0]    |         | 0000 = SYSCLK                |
|                     |     |          |         | 0001 = SYSCLK / 1.5          |
|                     |     |          |         | 0010 = SYSCLK / 2            |
|                     |     |          |         | 0011 = SYSCLK / 3            |
|                     |     |          |         | 0100 = SYSCLK / 4            |
|                     |     |          |         | 0101 = SYSCLK / 5.5          |
|                     |     |          |         | 0110 = SYSCLK / 6            |
|                     |     |          |         | 0111 = SYSCLK / 8            |
|                     |     |          |         | 1000 = SYSCLK / 11           |
|                     |     |          |         | 1001 = SYSCLK / 12           |
|                     |     |          |         | 1010 = SYSCLK / 16           |
|                     |     |          |         | 1011 = SYSCLK / 22           |
|                     |     |          |         | 1100 = SYSCLK / 24           |
|                     |     |          |         | 1101 = SYSCLK / 32           |
|                     |     |          |         | 1110 = SYSCLK / 44           |
|                     |     |          |         | 1111 = SYSCL:K / 48          |

Table 41 BCLK Control

## **OPCLK CONTROL**

A clock output (OPCLK) derived from SYSCLK may be output via GPIO3, GPIO4 or GPIO5. This clock is enabled by register bit OPCLK\_ENA, and its frequency is controlled by OPCLKDIV.

This output of this clock is also dependent upon the GPIO register settings described under "General Purpose Input/Output".

| REGISTER<br>ADDRESS | BIT  | LABEL     | DEFAULT | DESCRIPTION               |
|---------------------|------|-----------|---------|---------------------------|
| R6 (06h)            | 12:9 | OPCLKDIV  | 0000b   | GPIO Output Clock Divider |
|                     |      | [3:0]     |         | 0000 = SYSCLK             |
|                     |      |           |         | 0001 = SYSCLK / 2         |
|                     |      |           |         | 0010 = SYSCLK / 3         |
|                     |      |           |         | 0011 = SYSCLK / 4         |
|                     |      |           |         | 0100 = SYSCLK / 5.5       |
|                     |      |           |         | 0101 = SYSCLK / 6         |
|                     |      |           |         | 0110 = SYSCLK / 8         |
|                     |      |           |         | 0111 = SYSCLK / 12        |
|                     |      |           |         | 1000 = SYSCLK / 16        |
|                     |      |           |         | 1001 to 1111 = Reserved   |
| R2 (02h)            | 11   | OPCLK_ENA | 0b      | GPIO Clock Output Enable  |
|                     |      | (rw)      |         | 0 = disabled              |
|                     |      |           |         | 1 = enabled               |

Table 42 OPCLK Control



## **TOCLK CONTROL**

A slow clock (TOCLK) is derived from SYSCLK to enable input de-bouncing and volume update timeout functions. This clock is enabled by register bit TOCLK\_ENA, and its frequency is controlled by TOCLK\_RATE, as described in Table 43.

| REGISTER<br>ADDRESS | BIT | LABEL      | DEFAULT | DESCRIPTION                                                                                                                                                                                     |
|---------------------|-----|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R6 (06h)            | 15  | TOCLK_RATE | Ob      | Timeout Clock Rate (Selects clock to be used for volume update timeout and GPIO input debounce)  0 = SYSCLK / 2 <sup>21</sup> (Slower Response)  1 = SYSCLK / 2 <sup>19</sup> (Faster Response) |
|                     | 14  | TOCLK_ENA  | 0b      | Timeout Clock Enable  (This clock is required for volume update timeout and GPIO input de-bounce)  0 = disabled  1 = enabled                                                                    |

**Table 43 TOCLK Control** 

# **USB MODE**

It is possible to reduce power consumption by disabling the PLL in some applications. One such application is when SYSCLK is generated from a 12MHz USB clock source. Setting the AIF\_LRCLKRATE bit as described earlier (see "ADC Sample Rates") allows a sample rate close to 44.1kHz to be generated with no additional PLL power consumption.

In this configuration, SYSCLK must be driven directly from MCLK and by disabling the PLL. This is achieved by setting SYSCLK\_SRC=0, PLL\_ENA=0.

| REGISTER<br>ADDRESS | BIT | LABEL         | DEFAULT | DESCRIPTION                |
|---------------------|-----|---------------|---------|----------------------------|
| R10 (0Ah)           | 10  | AIF_LRCLKRATE | 0b      | LRCLK Rate                 |
|                     |     |               |         | 0 = Normal mode (256 * fs) |
|                     |     |               |         | 1 = USB mode (272 * fs)    |

Table 44 USB Mode Control

# PLL

The integrated PLL can be used to generate SYSCLK for the WM8953 from a wide range of MCLK reference frequencies. The PLL is enabled by the PLL\_ENA register bit. If required, the input reference clock can be divided by 2 by setting the register bit PRESCALE.

The PLL frequency ratio R is equal to  $f_2/f_1$  (see Figure 50). This ratio is the real number represented by register fields PLLN and PLLK, where PLLN is an integer (LSB = 1) and PLLK is the fractional portion of the number (MSB = 0.5). The fractional portion is only valid when enabled by the field SDM. De-selection of fractional mode results in lower power consumption.

For PLL stability, input frequencies and divisions must be chosen so that  $5 \le PLLN \le 13$ . Best performance is achieved for  $7 \le N \le 9$ . Also, the PLL performs best when  $f_2$  is set between 90MHz and 100MHz.

If PLLK is regarded as a 16-bit integer (instead of a fractional quantity), then PLLN and PLLK may be determined as follows:

- PLLN = int R
- PLLK = int (2<sup>16</sup> (R PLLN))

The PLL Control register settings are described in Table 45.

| REGISTER<br>ADDRESS | BIT | LABEL       | DEFAULT | DESCRIPTION                                                          |
|---------------------|-----|-------------|---------|----------------------------------------------------------------------|
| R2 (02h)            | 15  | PLL_ENA     | 0       | PLL Enable                                                           |
|                     |     | (rw)        |         | 0 = disabled                                                         |
|                     |     |             |         | 1 = enabled                                                          |
| R60 (3Ch)           | 7   | SDM         | 0       | Enable PLL Integer Mode                                              |
|                     |     |             |         | 0 = Integer mode                                                     |
|                     |     |             |         | 1 = Fractional mode                                                  |
|                     | 6   | PRESCALE    | 0b      | Divide MCLK by 2 at PLL input                                        |
|                     |     |             |         | 0 = Divide by 1                                                      |
|                     |     |             |         | 1 = Divide by 2                                                      |
|                     | 3:0 | PLLN[3:0]   | 8h      | Integer (N) part of PLL frequency ratio.                             |
| R61 (3Dh)           | 7:0 | PLLK [15:8] | 31h     | Fractional (K) part of PLL frequency ratio. (Most significant bits)  |
| R62 (3Eh)           | 7:0 | PLLK [7:0]  | 26h     | Fractional (K) part of PLL frequency ratio. (Least significant bits) |

Table 45 PLL Control

# **EXAMPLE PLL CALCULATION**

To generate 12.288MHz SYSCLK from a 12MHz reference clock:

There is a fixed divide by 4 at the PLL output (see Figure 50) followed by a selectable divide by 2 in the same path. PLL output  $f_2$  should be set in the range 90MHz - 100MHz. Enabling the divide by 2 (MCLK\_DIV = 10b) sets the required  $f_2$  = 4 x 2 x 12.288MHz = 98.304MHz.

There is a selectable pre-scale (divide MCLK by 2) at the PLL input ( $f_1$  - see Figure 75). The PLL frequency ratio  $f_2/f_1$  must be set in the range 5 - 13. Disabling the MCLK pre-scale (PRESCALE = 0b) sets the required ratio  $f_2/f_1$  = 8.192.

The required settings for this example are:

- MCLK\_DIV = 10b
- PRESCALE = 0b
- PLL\_ENA = 1
- SDM = 1
- PLLN = 8 = 8h
- PLLK = 0.192 = 3126h

# **EXAMPLE PLL SETTINGS**

Table 46 provides example PLL settings for generating common SYSCLK frequencies from a variety of MCLK reference frequencies.

| MCLK  | SYSCLK  | MCLKDIV | F2                        | PRESCALE | F1                  | R        | N  | K     |
|-------|---------|---------|---------------------------|----------|---------------------|----------|----|-------|
| (MHz) | (MHz)   |         | = SYSCLK * 4<br>* MCLKDIV |          | = MCLK/<br>PRESCALE | = F2/F1  |    |       |
| 12    | 11.2896 | 2       | 90.3168                   | 1        | 12                  | 7.5264   | 7H | 86C2H |
| 12    | 12.288  | 2       | 98.304                    | 1        | 12                  | 8.192    | 8H | 3126H |
| 13    | 11.2896 | 2       | 90.3168                   | 1        | 13                  | 6.947446 | 6H | F28BH |
| 13    | 12.288  | 2       | 98.304                    | 1        | 13                  | 7.561846 | 7H | 8FD5H |
| 14.4  | 11.2896 | 2       | 90.3168                   | 1        | 14.4                | 6.272    | 6H | 45A1H |
| 14.4  | 12.288  | 2       | 98.304                    | 1        | 14.4                | 6.826667 | 6H | D3A0H |
| 19.2  | 11.2896 | 2       | 90.3168                   | 2        | 9.6                 | 9.408    | 9H | 6872H |
| 19.2  | 12.288  | 2       | 98.304                    | 2        | 9.6                 | 10.24    | AH | 3D70H |
| 19.68 | 11.2896 | 2       | 90.3168                   | 2        | 9.84                | 9.178537 | 9H | 2DB4H |
| 19.68 | 12.288  | 2       | 98.304                    | 2        | 9.84                | 9.990243 | 9H | FD80H |
| 19.8  | 11.2896 | 2       | 90.3168                   | 2        | 9.9                 | 9.122909 | 9H | 1F76H |
| 19.8  | 12.288  | 2       | 98.304                    | 2        | 9.9                 | 9.929697 | 9H | EE00H |
| 24    | 11.2896 | 2       | 90.3168                   | 2        | 12                  | 7.5264   | 7H | 86C2H |
| 24    | 12.288  | 2       | 98.304                    | 2        | 12                  | 8.192    | 8H | 3126H |
| 26    | 11.2896 | 2       | 90.3168                   | 2        | 13                  | 6.947446 | 6H | F28BH |
| 26    | 12.288  | 2       | 98.304                    | 2        | 13                  | 7.561846 | 7H | 8FD5H |
| 27    | 11.2896 | 2       | 90.3168                   | 2        | 13.5                | 6.690133 | 6H | B0ACH |
| 27    | 12.288  | 2       | 98.304                    | 2        | 13.5                | 7.281778 | 7H | 4822H |

**Table 46 PLL Frequency Examples** 



# **CONTROL INTERFACE**

The WM8953 is controlled by writing to its control registers. Readback is available for certain registers, including device ID, power management registers and some GPIO status bits. The control interface can operate as either a 2-, 3- or 4-wire control interface, with additional variants as detailed below:

- 1 2-wire
  - open-drain
- 2. 3-wire
  - push 0/1
  - open drain
- 3 4-wire
  - push 0/1
  - wired-OR

Readback is provided on the bi-directional pin SDIN in 2-/3-wire modes and on a GPIO pin in 4-wire mode

#### **SELECTION OF CONTROL MODE**

The MODE pin determines the 2- or 3-/4-wire mode as shown in Table 47.

| MODE | INTERFACE FORMAT |
|------|------------------|
| Low  | 2 wire           |
| High | 3- or 4- wire    |

**Table 47 Control Interface Mode Selection** 

# 2-WIRE SERIAL CONTROL MODE

The WM8953 is controlled by writing to registers through a 2-wire serial control interface. A control word consists of 24 bits. The first 8 bits (B23 to B16) are address bits that select which control register is accessed. The remaining 16 bits (B15 to B0) are data bits, corresponding to the 16 bits in each control register. Many devices can be controlled by the same bus, and each device has a unique 7-bit address (this is not the same as the 8-bit address of each register in the WM8953). The default device address is 0011010 (0x34h).

The WM8953 operates as a slave device only. 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 + Read/Write bit, MSB first). If the device address received matches the address of the WM8953, then the WM8953 responds by pulling SDIN low on the next clock pulse (ACK). If the address is not recognised or the R/W bit is '1' when operating in write only mode, the WM8953 returns to the idle condition and wait for a new start condition and valid address.

The WM8953 supports a multitude of read and write operations, which are:

- Single write
- Single read
- Multiple write using auto-increment
- Multiple read using auto-increment



These modes are shown in the section below. Terminology used in the following figures:

| TERMINOLOGY | DESCRIPTION     |           |  |  |  |  |  |
|-------------|-----------------|-----------|--|--|--|--|--|
| S           | Start Condition |           |  |  |  |  |  |
| Sr          | Repeated start  |           |  |  |  |  |  |
| Α           | Acknowledge     |           |  |  |  |  |  |
| Р           | Stop Condition  |           |  |  |  |  |  |
| R₩          | ReadNotWrite    | 0 = Write |  |  |  |  |  |
|             |                 | 1 = Read  |  |  |  |  |  |

Table 48 Terminology



Figure 51 2-Wire Serial Control Interface (single write)



Figure 52 2-Wire Serial Control Interface (single read)



Figure 53 2-Wire Serial Control Interface (multiple write using auto-increment)



Figure 54 2-Wire Serial Control Interface (multiple read using auto-increment)

In 2-wire mode, the WM8953 has two possible device addresses, which can be selected using the CSB/ADDR pin.

| CSB/ADDR STATE | DEVICE ADDRESS    |
|----------------|-------------------|
| Low            | 0011010 (0 x 34h) |
| High           | 0011011 (0 x 36h) |

Table 49 2-Wire Control Interface Address Selection

# 3-WIRE / 4-WIRE SERIAL CONTROL MODES

The WM8953 is controlled by writing to registers through a 3- or 4-wire serial control interface. A control word consists of 24 bits. The first bit is the read/write bit (R/W), which is followed by 7 address bits (A6 to A0) that determine which control register is accessed. The remaining 16 bits (B15 to B0) are data bits, corresponding to the 16 bits in each control register.

The 3- or 4-wire modes are selected by the RD\_3W\_ENA register bit. Additionally the MODE\_3W4W control bit can be used to select between push 0/1 and open-drain or wired-OR modes, as described in Table 50 below.

| REGISTER<br>ADDRESS | BIT | LABEL     | DEFAULT | DESCRIPTION                        |
|---------------------|-----|-----------|---------|------------------------------------|
| R22 (16h)           | 15  | RD_3W_ENA | 1b      | 3- / 4-wire readback configuration |
|                     |     |           |         | 1 = 3-wire mode                    |
|                     |     |           |         | 0 = 4-wire mode, using GPIO pin    |
|                     | 14  | MODE_3W4W | 0b      | 3-wire mode                        |
|                     |     |           |         | 0 = push 0/1                       |
|                     |     |           |         | 1 = open-drain                     |
|                     |     |           |         | 4-wire mode                        |
|                     |     |           |         | 0 = push 0/1                       |
|                     |     |           |         | 1 = wired-OR                       |

Table 50 3-Wire / 4-Wire Control Interface selection

3-wire control mode is selected by setting RD\_3W\_ENA = 1. In 3-wire mode, every rising edge of SCLK clocks in one data bit from the SDIN pin. A rising edge on CSB/ADDR latches in a complete control word consisting of the last 24 bits.

In Write operations (R/W=0), all SDIN bits are driven by the controlling device.

In Read operations (R/W=1), the SDIN pin is driven by the controlling device to clock in the register address, after which the WM8953 drives the SDIN pin to output the applicable data bits.

The 3-wire control mode timing is illustrated in Figure 55.



Figure 55 3-Wire Serial Control Interface

4-wire control mode is selected by setting RD 3W ENA = 0.

In Write operations (R/W=0), this mode is the same as 3-wire mode described above.

In Read operations (R/W=1), a GPIO pin must be selected to output SDOUT by setting GPIOn\_SEL=0110b (n= 3, 4 or 5). In this mode, the SDIN pin is ignored following receipt of the valid register address. SDOUT is driven by the WM8953.

In 4-wire Push 0/1 mode, SDOUT is driven low when not outputting register data bits. In Wired-OR mode, SDOUT is undriven when not outputting register data bits.

The 4-wire control mode timing is illustrated in Figure 56 and Figure 57.





Figure 56 4-Wire Readback (Push 0/1)



Figure 57 4-Wire Readback (wired-OR)



# **POWER MANAGEMENT**

# **POWER MANAGEMENT REGISTERS**

The WM8953 has two control registers that allow users to select which functions are active. For minimum power consumption, unused functions should be disabled. To minimise pop or click noise, it is important to enable or disable functions in the correct order.

| REGISTER<br>ADDRESS | BIT | LABEL            | DEFAULT  | DESCRIPTION                                   |
|---------------------|-----|------------------|----------|-----------------------------------------------|
| R1 (1h)             | 4   | MICBIAS_ENA      | 0b       | MICBIAS Enable                                |
|                     |     | (rw)             |          | 0 = OFF (high impedance output)               |
|                     |     |                  |          | 1 = ON                                        |
|                     | 2:1 | VMID_MODE        | 00b      | Vmid Divider Enable and Select                |
|                     |     | [1:0]            |          | 00 = Vmid disabled (for OFF mode)             |
|                     |     | (rw)             |          | $01 = 2 \times 50$ kΩ divider (Normal mode)   |
|                     |     |                  |          | $10 = 2 \times 250$ kΩ divider (Standby mode) |
|                     |     |                  |          | 11 = 2 x 5kΩ divider (for fast start-up)      |
|                     | 0   | VREF_ENA<br>(rw) | 0b       | VREF Enable (Bias for all analogue functions) |
|                     |     | ()               |          | 0 = VREF bias disabled                        |
|                     |     |                  |          | 1 = VREF bias enabled                         |
| R2 (02h)            | 15  | PLL_ENA          | 0b       | PLL Enable                                    |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     |     |                  |          | 1 = enabled                                   |
|                     | 14  | TSHUT_ENA        | 0b       | Thermal Sensor Enable                         |
|                     |     | (rw)             |          | 0 = Thermal sensor disabled                   |
|                     |     |                  |          | 1 = Thermal sensor enabled                    |
|                     | 11  | OPCLK_ENA        | 0b       | GPIO Clock Output Enable                      |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     |     |                  |          | 1 = enabled                                   |
|                     | 9   | AINL_ENA         | 0b       | Left Input Path Enable                        |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     |     |                  |          | 1 = enabled                                   |
|                     | 8   | AINR_ENA         | 0b       | Left Input Path Enable                        |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     |     |                  |          | 1 = enabled                                   |
|                     | 7   | LIN34_ENA        | 0b       | LIN34 Input PGA Enable                        |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     |     |                  |          | 1 = enabled                                   |
|                     | 6   | LIN12_ENA        | 0b       | LIN12 Input PGA Enable                        |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     |     |                  |          | 1 = enabled                                   |
|                     | 5   | RIN34_ENA        | 0b       | RIN34 Input PGA Enable                        |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     |     | DINIAO ENIA      | 01       | 1 = enabled                                   |
|                     | 4   | RIN12_ENA        | 0b       | RIN12 Input PGA Enable                        |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     | _   | ADOL ENA         | Ob       | 1 = enabled                                   |
|                     | 1   | ADCL_ENA         | 0b       | Left ADC Enable                               |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     | _   | ADCD ENA         | Oh       | 1 = enabled                                   |
|                     | 0   | ADCR_ENA         | 0b       | Right ADC Enable                              |
|                     |     | (rw)             |          | 0 = disabled                                  |
|                     |     |                  | <u> </u> | 1 = enabled                                   |

Table 51 Power Management



WM8953

# **CHIP RESET AND ID**

The device ID can be read back from register 0. Writing to this register will reset the device.

| REGISTER<br>ADDRESS    | BIT  | LABEL                       | DEFAULT | DESCRIPTION                                                           |
|------------------------|------|-----------------------------|---------|-----------------------------------------------------------------------|
| R0 (00h)<br>Reset / ID | 15:0 | SW_RESET_C<br>HIP_ID [15:0] | 8990h   | Writing to this register resets all registers to their default state. |
|                        |      | (rr)                        |         | Reading from this register will indicate device family ID 8990h.      |

Table 52 Chip Reset and ID



# **POWER DOMAINS**



Figure 58 WM8953 Power Domains

REGISTE

D

≤

P

# MA WOLSON®

#### Dec Addr Hex Addr Bin Default SW RESET CHIP ID[15:0] n 1000\_1001\_1001\_0000 MICBIAS\_EN VREF ENA Power Management (1) VMID MODE[1:0] 0000 0000 0000 0000 PLL\_ENA TSHUT\_ENA OPCLK\_ENA AINL\_ENA AINR\_ENA LIN34\_ENA LIN12\_ENA RIN34\_ENA RIN12\_ENA ADCL\_ENA ADCR\_ENA Power Management (2) Λ 0110 0000 0000 0000 0000\_0000\_0000\_0000 AIF\_LRCLK\_I AIFADCL\_SF AIFADCR\_S AIFADC\_TDM\_ IF\_BCLK\_IN AIFADC\_TDN AIF WL[1:0] AIF FMT[1:0] Audio Interface (1) 0100\_0000\_0101\_0000 HAN ADC\_COMPI Audio Interface (2) ADC\_COMP 0100\_0000\_0000\_0000 Clocking (1) TOCLK\_RATE TOCLK\_ENA OPCLKDIV[3:0] BCLK\_DIV[3:0] 0000\_0001\_1100\_1000 CLK FORCE MCLK DIV[1:0] MCLK INV SYSCLK SRC ADC\_CLKDIVI2:01 Clocking (2) 0000 0000 0000 0000 Audio Interface (3) AIF\_MSTR ADCLRC\_DIF ADCLRC\_RATE[10:0] 0000\_0000\_0100\_0000 Audio Interface (4) AIF TRIS 0000 0000 0100 0000 AIF\_LRCLKF ATE Α LRCLK Rate 0000\_0000\_0000\_0100 В Reserved 0000 000p 1100 0000 р С Reserved р 0000 000p 1100 0000 D Reserved 0000\_0000\_0000\_0000 ADCL\_DATIN DC\_HPF\_E ADCR\_DATIN ADC CTRI ADC\_HPF\_CUT[1:0] 0000 0001 0000 0000 Left ADC Digital Volume ADC\_VU ADCL\_VOL[7:0] 0000\_000p\_1100\_0000 ADCR\_VOL[7:0] Right ADC Digital Volume ADC VU 0000 000p 1100 0000 Reserved 0000\_0000\_0000\_0000 GPIO CTRL 1 IRQ TEMPOK MICSHRT MICDET PLL\_LCK GPIO\_STATUS[7:0] 0000\_pppp\_pppp\_pppp Reserved 0001\_0000\_0000\_0000 GPIO4\_DEB\_ ENA GPIO4\_IRQ\_ NA GPIO3\_DEB\_ ENA GPIO3\_IRQ\_ NA GPI03 & GPI04 GPIO4\_PU GPIO4\_PD GPIO4\_SEL[3:0] GPIO3\_PU GPIO3\_PD GPIO3\_SEL[3:0] 0001\_0000\_0001\_0000 GPIO5\_DEB ENA GPIO5\_IRQ\_ NA GPIO5\_PU GPIO5 GPIO5\_PD GPIO5\_SEL[3:0] 0001 0000 0001 0000 GPI8\_DEB\_E GPI8\_IRQ\_E NA A TEMPOK\_IRO MICSHRT\_IF MICDET\_IRO LL\_LCK\_IRC GPI7\_DEB\_E NA GPI7\_IRQ\_EI A GPIOCTRL 2 RD\_3W\_ENA MODE\_3W4W GPI8\_ENA GPI7\_ENA 1000\_0000\_0000\_0000 Q\_ENA TEMPOK\_PO IICSHRT\_PO LL\_LCK\_PO MICDET PO GPIO POL IRQ INV GPIO\_POL[7:0] 0000 1000 0000 0000 IPVU[0] LI12MUTE LI12ZC LIN12VOL[4:0] Left Line Input 1&2 Volume 0000\_000p\_1000\_1011 Left Line Input 3&4 Volume IPVU[1] LI34MUTE LI34ZC LIN34VOL[4:0] 0000\_000p\_1000\_1011 RIN12VOL[4:0] 1A Right Line Input 1&2 Volume IPVU[2] RI12MUTE RI12ZC 0000\_000p\_1000\_1011 Right Line Input 3&4 Volume IPVU[3] RI34MUTE RI34ZC RIN34VOL[4:0] 0000\_000p\_1000\_1011 1C Reserved 0000\_000p\_0000\_0000 р 1D Reserved р 0000\_000p\_0000\_0000 1E 0000\_0000\_0110\_0110 Reserved 1F Reserved 0000 0000 0010 0010

| Dec Addr | Hex Addr | Name                 | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7            | 6        | 5      | 4           | 3       | 2    | 1                   | 0                   | Bin Default         |
|----------|----------|----------------------|------------|----|----|----|----|----|---|--------|--------------|----------|--------|-------------|---------|------|---------------------|---------------------|---------------------|
| 32       | 20       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | р      | 0            | 1        | 1      | 1           | 1       | 0    | 0                   | 1                   | 0000_000p_0111_1001 |
| 33       | 21       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | р      | 0            | 1        | 1      | 1           | 1       | 0    | 0                   | 1                   | 0000_000p_0111_1001 |
| 34       | 22       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 1                   | 1                   | 0000_0000_0000_0011 |
| 35       | 23       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 1                   | 1                   | 0000_0000_0000_0011 |
| 36       | 24       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 1        | 0      | 1           | 0       | 1    | 0                   | 1                   | 0000_0000_0101_0101 |
| 37       | 25       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 1      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0001_0000_0000 |
| 38       | 26       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 1        | 1      | 1           | 1       | 0    | 0                   | 1                   | 0000_0000_0111_1001 |
| 39       | 27       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 40       | 28       | Input Mixer2         | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | LMP4         | LMN3     | LMP2   | LMN1        | RMP4    | RMN3 | RMP2                | RMN1                | 0000_0000_0000_0000 |
| 41       | 29       | Input Mixer3         | 0          | 0  | 0  | 0  | 0  | 0  | 0 | L34MNB | L34MNBST     | 0        | L12MNB | L12MNBST    | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 42       | 2A       | Input Mixer4         | 0          | 0  | 0  | 0  | 0  | 0  | 0 | R34MNB | R34MNBST     | 0        | R12MNB | R12MNBST    | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 43       | 2B       | Input Mixer5         | 0          | 0  | 0  | 0  | 0  | 0  | 0 |        | LI2BVOL[2:0] |          | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 44       | 2C       | Input Mixer6         | 0          | 0  | 0  | 0  | 0  | 0  | 0 |        | RI2BVOL[2:0] |          | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 45       | 2D       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 46       | 2E       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 47       | 2F       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 48       | 30       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 49       | 31       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 50       | 32       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 51       | 33       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 1      | 1            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0001_1000_0000 |
| 52       | 34       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 53       | 35       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 54       | 36       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 55       | 37       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 56       | 38       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 57       | 39       | Anti-Pop             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | BUFIOEN | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 58       | 3A       | MICBIAS              | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | MCDS         | CTH[1:0] |        | MCDTHR[2:0] |         | MCD  | 0                   | MBSEL               | 0000_0000_0000_0000 |
| 59       | 3B       | Reserved             | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 0                   | 0                   | 0000_0000_0000_0000 |
| 60       | 3C       | PLL1                 | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | SDM          | PRESCALE | 0      | 0           |         | PLLI | N[3:0]              |                     | 0000_0000_0000_1000 |
| 61       | 3D       | PLL2                 | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | PLLK1[7:0]   |          |        |             |         |      | 0000_0000_0011_0001 |                     |                     |
| 62       | 3E       | PLL3                 | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | PLLK2[7:0]   |          |        |             |         |      |                     | 0000_0000_0010_0110 |                     |
| 117      | 75       | Access Control       | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | EXT_ACCESS<br>_ENA  | 0                   | 0000_0000_0000_0000 |
| 122      | 7A       | Extended ADC Control | ADCL_ADCR_ | 0  | 1  | 0  | 0  | 0  | 0 | 0      | 0            | 0        | 0      | 0           | 0       | 0    | 1                   | 1                   | 0010_0000_0000_0011 |



**Note:**A bin default value of 'p' indicates a register field where a default value is not applicable e.g. a volume update bit.

# **REGISTER BITS BY ADDRESS**

| REGISTER<br>ADDRESS              | BIT   | LABEL                                  | DEFAULT                                                                        | DESCRIPTION                                                                                                                                                   |  |  |  |  |  |
|----------------------------------|-------|----------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| R0 (00h)<br>Reset / ID           | 15:0  | SW_RESET_CHIP_<br>ID<br>[15:0]<br>(rr) | 8990h                                                                          | Writing to this register resets all registers to their default state. Reading from this register will indicate device family ID 8990h.                        |  |  |  |  |  |
| R1 (01h)                         | 15:8  |                                        | 00h                                                                            | Reserved - Do Not Change                                                                                                                                      |  |  |  |  |  |
| Power                            | 7:5   |                                        | 000b                                                                           | Reserved - Do Not Change                                                                                                                                      |  |  |  |  |  |
| Management<br>(1)                | 4     | MICBIAS_ENA<br>(rw)                    | 0b                                                                             | MICBIAS Enable 0 = OFF (high impedance output) 1 = ON                                                                                                         |  |  |  |  |  |
|                                  | 3     |                                        | 0b                                                                             | Reserved - Do Not Change                                                                                                                                      |  |  |  |  |  |
|                                  | 2:1   | VMID_MODE                              | 00b                                                                            | Vmid Divider Enable and Select                                                                                                                                |  |  |  |  |  |
|                                  |       | [1:0]<br>(rw)                          |                                                                                | 00 = Vmid disabled (for OFF mode)<br>01 = 2 x 50kΩ divider (Normal mode)<br>10 = 2 x 250kΩ divider (Standby mode)<br>11 = 2 x 5kΩ divider (for fast start-up) |  |  |  |  |  |
|                                  | 0     | VREF_ENA<br>(rw)                       | 0b                                                                             | VREF Enable (Bias for all analogue functions)  0 = VREF bias disabled                                                                                         |  |  |  |  |  |
| R02 (02h)<br>Power<br>Management | 15    | PLL_ENA<br>(rw)                        | 0b                                                                             | 1 = VREF bias enabled PLL Enable 0 = disabled 1 = enabled                                                                                                     |  |  |  |  |  |
| (2)                              | 14    | TSHUT_ENA (rw)                         | Thermal Sensor Enable  0 = Thermal sensor disabled  1 = Thermal sensor enabled |                                                                                                                                                               |  |  |  |  |  |
|                                  | 13:12 |                                        | 10b                                                                            | Reserved - Do Not Change                                                                                                                                      |  |  |  |  |  |
|                                  | 11    | OPCLK_ENA (rw)                         | 0b                                                                             | GPIO Clock Output Enable 0 = disabled 1 = enabled                                                                                                             |  |  |  |  |  |
|                                  | 10    |                                        | 0b                                                                             | Reserved - Do Not Change                                                                                                                                      |  |  |  |  |  |
|                                  | 9     | AINL_ENA<br>(rw)                       | 0b                                                                             | Left Input Path Enable 0 = disabled 1 = enabled                                                                                                               |  |  |  |  |  |
|                                  | 8     | AINR_ENA<br>(rw)                       | 0b                                                                             | Right Input Path Enable 0 = disabled 1 = enabled                                                                                                              |  |  |  |  |  |
|                                  | 7     | LIN34_ENA<br>(rw)                      | 0b                                                                             | LIN34 Input PGA Enable 0 = disabled 1 = enabled                                                                                                               |  |  |  |  |  |
|                                  | 6     | LIN12_ENA<br>(rw)                      | 0b                                                                             | LIN12 Input PGA Enable 0 = disabled 1 = enabled                                                                                                               |  |  |  |  |  |
|                                  | 5     | RIN34_ENA<br>(rw)                      | 0b                                                                             | RIN34 Input PGA Enable 0 = disabled 1 = enabled                                                                                                               |  |  |  |  |  |
|                                  | 4     | RIN12_ENA<br>(rw)                      | 0b                                                                             | RIN12 Input PGA Enable 0 = disabled 1 = enabled                                                                                                               |  |  |  |  |  |
|                                  | 3:2   |                                        | 00b                                                                            | Reserved - Do Not Change                                                                                                                                      |  |  |  |  |  |
|                                  | 1     | ADCL_ENA (rw)                          | 0b                                                                             | Left ADC Enable 0 = disabled 1 = enabled                                                                                                                      |  |  |  |  |  |



| REGISTER<br>ADDRESS        | BIT  | LABEL         | DEFAULT | DESCRIPTION                                                                 |
|----------------------------|------|---------------|---------|-----------------------------------------------------------------------------|
|                            | 0    | ADCR_ENA      | 0b      | Right ADC Enable                                                            |
|                            |      | (rw)          |         | 0 = disabled                                                                |
|                            |      |               |         | 1 = enabled                                                                 |
| R03 (03h)                  | 15:0 |               | 0000h   | Reserved - Do Not Change                                                    |
| Power<br>Management<br>(3) |      |               |         |                                                                             |
| R04 (04h)                  | 15   | AIFADCL_SRC   | 0b      | Left Digital Audio channel source                                           |
| Audio                      |      |               |         | 0 = Left ADC data is output on left channel                                 |
| Interface (1)              |      |               |         | 1 = Right ADC data is output on left channel                                |
|                            | 14   | AIFADCR_SRC   | 1b      | Right Digital Audio channel source                                          |
|                            |      |               |         | 0 = Left ADC data is output on right channel                                |
|                            |      |               |         | 1 = Right ADC data is output on right channel                               |
|                            | 13   | AIFADC_TDM    | 0b      | ADC TDM Enable                                                              |
|                            |      |               |         | 0 = Normal ADCDAT operation                                                 |
|                            |      |               |         | 1 = TDM enabled on ADCDAT                                                   |
|                            | 12   | AIFADC_TDM_   | 0b      | ADCDAT TDM Channel Select                                                   |
|                            |      | CHAN          |         | 0 = ADCDAT outputs data on slot 0                                           |
|                            |      |               |         | 1 = ADCDAT output data on slot 1                                            |
|                            | 11:9 |               | 0b      | Reserved - Do Not Change                                                    |
|                            | 8    | AIF_BCLK_INV  | 0b      | BCLK Invert                                                                 |
|                            |      |               |         | 0 = BCLK not inverted                                                       |
|                            |      |               |         | 1 = BCLK inverted                                                           |
|                            | 7    | AIF_LRCLK_INV | 0b      | Right, left and I <sup>2</sup> S modes – LRCLK polarity                     |
|                            |      |               |         | 0 = normal LRCLK polarity                                                   |
|                            |      |               |         | 1 = invert LRCLK polarity                                                   |
|                            |      |               |         | DSP Mode – mode A/B select                                                  |
|                            |      |               |         | 0 = MSB is available on 2nd BCLK rising edge after LRC rising edge (mode A) |
|                            |      |               |         | 1 = MSB is available on 1st BCLK rising edge after LRC rising edge (mode B) |
|                            | 6:5  | AIF_WL        | 10b     | Digital Audio Interface Word Length                                         |
|                            |      | [1:0]         |         | 00 = 16 bits                                                                |
|                            |      |               |         | 01 = 20 bits                                                                |
|                            |      |               |         | 10 = 24 bits                                                                |
|                            | 4.0  | A.E. E.A.E.   | 401     | 11 = 32 bits                                                                |
|                            | 4:3  | AIF_FMT       | 10b     | Digital Audio Interface Format                                              |
|                            |      | [1:0]         |         | 00 = Right justified<br>01 = Left justified                                 |
|                            |      |               |         | 10 = I <sup>2</sup> S Format                                                |
|                            |      |               |         | 11 = DSP Mode                                                               |
|                            | 2:0  |               | 0b      | Reserved - Do Not Change                                                    |
| R05 (05h)                  | 15:8 |               | 40h     | Reserved - Do Not Change  Reserved - Do Not Change                          |
| Audio                      | 7:3  |               | 00000b  | Reserved - Do Not Change  Reserved - Do Not Change                          |
| Interface (2)              | 2    | ADC_COMP      | 00000b  | ADC Companding Enable                                                       |
| , ,                        | _    | , 150_00/VII  | 0.0     | 0 = disabled                                                                |
|                            |      |               |         | 1 = enabled                                                                 |
|                            | 1    | ADC_COMPMODE  | 0b      | ADC Companding Type                                                         |
|                            | '    | ADO_COMEMODE  | OD      | 0 = μ-law                                                                   |
|                            |      |               |         | 1 = A-law                                                                   |
|                            | 0    |               | 0b      | Reserved - Do Not Change                                                    |
| L                          |      | 1             | UU      | 110001 VOU - DO 1101 Offaringe                                              |



WM8953

| REGISTER<br>ADDRESS       | BIT  | LABEL       | DEFAULT | DESCRIPTION                                                                                         |  |  |  |  |
|---------------------------|------|-------------|---------|-----------------------------------------------------------------------------------------------------|--|--|--|--|
| R06 (06h)<br>Clocking (1) | 15   | TOCLK_RATE  | 0b      | Timeout Clock Rate (Selects clock to be used for volume update timeout and GPIO input de-bounce)    |  |  |  |  |
|                           |      |             |         | 0 = SYSCLK / 2 <sup>21</sup> (Slower Response)<br>1 = SYSCLK / 2 <sup>19</sup> (Faster Response)    |  |  |  |  |
|                           | 4.4  | TOOLIK ENIA | Ol-     |                                                                                                     |  |  |  |  |
|                           | 14   | TOCLK_ENA   | 0b      | Timeout Clock Enable (This clock is required for volume update timeout and GPIO input de-bounce)    |  |  |  |  |
|                           |      |             |         | 0 = disabled                                                                                        |  |  |  |  |
|                           |      |             |         | 1 = enabled                                                                                         |  |  |  |  |
|                           | 13   |             | 0b      | Reserved - Do Not Change                                                                            |  |  |  |  |
|                           | 12:9 | OPCLKDIV    | 0000b   | GPIO Output Clock Divider                                                                           |  |  |  |  |
|                           |      | [3:0]       |         | 0000 = SYSCLK                                                                                       |  |  |  |  |
|                           |      |             |         | 0001 = SYSCLK / 2                                                                                   |  |  |  |  |
|                           |      |             |         | 0010 = SYSCLK / 3                                                                                   |  |  |  |  |
|                           |      |             |         | 0011 = SYSCLK / 4                                                                                   |  |  |  |  |
|                           |      |             |         | 0100 = SYSCLK / 5.5                                                                                 |  |  |  |  |
|                           |      |             |         | 0101 = SYSCLK / 6                                                                                   |  |  |  |  |
|                           |      |             |         | 0110 = SYSCLK / 8                                                                                   |  |  |  |  |
|                           |      |             |         | 0111 = SYSCLK / 12                                                                                  |  |  |  |  |
|                           |      |             |         | 1000 = SYSCLK / 16                                                                                  |  |  |  |  |
|                           |      |             |         | 1001 to 1111 = Reserved                                                                             |  |  |  |  |
|                           | 8:5  |             | 1110b   | Reserved - Do Not Change                                                                            |  |  |  |  |
|                           | 4:1  | BCLK_DIV    | 0100b   | BCLK Frequency (Master Mode)                                                                        |  |  |  |  |
|                           |      | [3:0]       |         | 0000 = SYSCLK                                                                                       |  |  |  |  |
|                           |      |             |         | 0001 = SYSCLK / 1.5                                                                                 |  |  |  |  |
|                           |      |             |         | 0010 = SYSCLK / 2                                                                                   |  |  |  |  |
|                           |      |             |         | 0011 = SYSCLK / 3                                                                                   |  |  |  |  |
|                           |      |             |         | 0100 = SYSCLK / 4                                                                                   |  |  |  |  |
|                           |      |             |         | 0101 = SYSCLK / 5.5                                                                                 |  |  |  |  |
|                           |      |             |         | 0110 = SYSCLK / 6                                                                                   |  |  |  |  |
|                           |      |             |         | 0111 = SYSCLK / 8                                                                                   |  |  |  |  |
|                           |      |             |         | 1000 = SYSCLK / 11                                                                                  |  |  |  |  |
|                           |      |             |         | 1001 = SYSCLK / 12                                                                                  |  |  |  |  |
|                           |      |             |         | 1010 = SYSCLK / 16                                                                                  |  |  |  |  |
|                           |      |             |         | 1011 = SYSCLK / 22                                                                                  |  |  |  |  |
|                           |      |             |         | 1100 = SYSCLK / 24                                                                                  |  |  |  |  |
|                           |      |             |         | 1101 = SYSCLK / 32                                                                                  |  |  |  |  |
|                           |      |             |         | 1110 = SYSCLK / 44                                                                                  |  |  |  |  |
|                           | 0    |             | Ob      | 1111 = SYSCL:K / 48                                                                                 |  |  |  |  |
| D07 (07h)                 | 0    |             | 0b      | Reserved - Do Not Change                                                                            |  |  |  |  |
| R07 (07h)<br>Clocking (2) | 15   | evectiv ede | 0b      | Reserved - Do Not Change                                                                            |  |  |  |  |
| Clocking (2)              | 14   | SYSCLK_SRC  | 0b      | SYSCLK Source Select 0 = MCLK                                                                       |  |  |  |  |
|                           |      |             |         |                                                                                                     |  |  |  |  |
|                           | 12   | CLK FORCE   | Oh      | 1 = PLL output                                                                                      |  |  |  |  |
|                           | 13   | CLK_FORCE   | 0b      | Forces Clock Source Selection                                                                       |  |  |  |  |
|                           |      |             |         | 0 = Existing SYSCLK source (MCLK or PLL output) must be active when changing to a new clock source. |  |  |  |  |
|                           |      |             |         | 1 = Allows existing MCLK source to be disabled before changing to a new clock source.               |  |  |  |  |



| REGISTER<br>ADDRESS | BIT   | LABEL         | DEFAULT | DESCRIPTION                                                |
|---------------------|-------|---------------|---------|------------------------------------------------------------|
|                     | 12:11 | MCLK_DIV      | 00b     | SYSCLK Pre-divider. Clock source (MCLK or PLL output) will |
|                     |       | [1:0]         |         | be divided by this value to generate SYSCLK.               |
|                     |       |               |         | 00 = Divide SYSCLK by 1                                    |
|                     |       |               |         | 01 = Reserved                                              |
|                     |       |               |         | 10 = Divide SYSCLK by 2                                    |
|                     | 40    | MOLIC INIV    | Oh      | 11 = Reserved                                              |
|                     | 10    | MCLK_INV      | 0b      | MCLK Invert                                                |
|                     |       |               |         | 0 = Master clock not inverted<br>1 = Master clock inverted |
|                     | 9:8   |               | 00b     |                                                            |
|                     | 7:5   | ADC CLKDIV    | 000b    | Reserved - Do Not Change                                   |
|                     | 7.5   | ADC_CLKDIV    | 0000    | ADC Sample Rate Divider  000 = SYSCLK / 1.0                |
|                     |       | [2:0]         |         | 000 - STSCLK / 1.0<br>001 = SYSCLK / 1.5                   |
|                     |       |               |         | 010 = SYSCLK / 2.0                                         |
|                     |       |               |         | 010 - STSCLK / 2.0<br>011 = SYSCLK / 3.0                   |
|                     |       |               |         | 100 = SYSCLK / 4.0                                         |
|                     |       |               |         | 100 = SYSCLK / 5.5                                         |
|                     |       |               |         | 110 = SYSCLK / 6.0                                         |
|                     |       |               |         | 111= Reserved                                              |
|                     | 4:0   |               | 00000b  | Reserved - Do Not Change                                   |
| R08 (08h)           | 15    | AIF MSTR      | 0b      | Audio Interface Master Mode Select                         |
| Audio               | 10    | 7th _MOTI     | OD .    | 0 = Slave mode                                             |
| Interface (3)       |       |               |         | 1 = Master mode                                            |
| ` '                 | 14:12 |               | 000b    | Reserved - Do Not Change                                   |
|                     | 11    | ADCLRC_DIR    | 0b      | ADCLRC Direction                                           |
|                     |       | /\Boziko_Birk |         | (Forces ADCLRC clock to be output in slave mode)           |
|                     |       |               |         | 0 = ADCLRC normal operation                                |
|                     |       |               |         | 1 = ADCLRC clock output enabled                            |
|                     | 10:0  | ADCLRC_RATE   | 040h    | ADCLRC Rate                                                |
|                     |       | [10:0]        |         | ADCLRC clock output = BCLK / ADCLRC_RATE                   |
|                     |       |               |         | Integer (LSB = 1)                                          |
|                     |       |               |         | Valid from 82047                                           |
| R09 (09h)           | 15:14 |               | 00b     | Reserved - Do Not Change                                   |
| Audio               | 13    | AIF_TRIS      | 0b      | Audio Interface and GPIO Tristate                          |
| Interface (4)       |       |               |         | 0 = Audio interface and GPIO pins operate normally         |
|                     |       |               |         | 1 = Tristate all audio interface and GPIO pins             |
|                     | 12    |               | 0b      | Reserved - Do Not Change                                   |
|                     | 11:0  |               | 040h    | Reserved - Do Not Change                                   |
| R10 (0Ah)           | 15:11 |               | 00000b  | Reserved - Do Not Change                                   |
| LRCLK Rate          | 10    | AIF_LRCLKRATE | 0b      | LRCLK Rate                                                 |
|                     |       |               |         | 0 = Normal mode (256 * fs)                                 |
|                     |       |               |         | 1 = USB mode (272 * fs)                                    |
|                     | 9:8   |               | 00b     | Reserved - Do Not Change                                   |
|                     | 7:0   |               | 04h     | Reserved - Do Not Change                                   |
| R11 (0Bh)           | 15:0  |               | 0060h   | Reserved - Do Not Change                                   |
| R12 (0Ch)           | 15:0  |               | 0060h   | Reserved - Do Not Change                                   |
| R13 (0Dh)           | 15:0  |               | 0000h   | Reserved - Do Not Change                                   |
| R14 (0Eh)           | 15:9  |               | 00h     | Reserved - Do Not Change                                   |
| ADC Control         | 8     | ADC_HPF_ENA   | 1b      | ADC Digital High Pass Filter Enable                        |
|                     |       |               |         | 0 = disabled                                               |
|                     |       |               |         | 1 = enabled                                                |
|                     | 7     | 1             | 0b      | Reserved - Do Not Change                                   |



| REGISTER<br>ADDRESS | BIT   | LABEL       | DEFAULT   | DESCRIPTION                                                                                            |
|---------------------|-------|-------------|-----------|--------------------------------------------------------------------------------------------------------|
| ADDITEOU            | 6:5   | ADC_HPF_CUT | 00b       | ADC Digital High Pass Filter Cut-Off Frequency (fc)                                                    |
|                     |       | [1:0]       |           | 00 = Hi-fi mode (fc=4Hz at fs=48kHz)                                                                   |
|                     |       |             |           | 01 = Voice mode 1 (fc=127Hz at fs=16kHz)                                                               |
|                     |       |             |           | 10 = Voice mode 2 (fc=130Hz at fs=8kHz)                                                                |
|                     |       |             |           | 11 = Voice mode 3 (fc=267Hz at fs=8kHz)                                                                |
|                     |       |             |           | (Note: fc scales with sample rate. See Table 16 for cut-off frequencies at all supported sample rates) |
|                     | 4:2   |             | 000b      | Reserved - Do Not Change                                                                               |
|                     | 1     | ADCL_DATINV | 0b        | Left ADC Invert                                                                                        |
|                     |       |             |           | 0 = Left ADC output not inverted                                                                       |
|                     |       |             |           | 1 = Left ADC output inverted                                                                           |
|                     | 0     | ADCR_DATINV | 0b        | Right ADC Invert                                                                                       |
|                     |       |             |           | 0 = Right ADC output not inverted                                                                      |
|                     |       |             |           | 1 = Right ADC output inverted                                                                          |
| R15 (0Fh)           | 15:9  |             | 00h       | Reserved - Do Not Change                                                                               |
| Left ADC            | 8     | ADC_VU      | N/A       | ADC Volume Update                                                                                      |
| Digital Volume      |       |             |           | Writing a 1 to this bit will cause left and right ADC volume to                                        |
|                     |       |             |           | be updated simultaneously                                                                              |
|                     | 7:0   | ADCL_VOL    | 1100_     | Left ADC Digital Volume                                                                                |
|                     |       | [7:0]       | 0000b     | (See Table 14 for volume range)                                                                        |
|                     |       |             | (0dB)     |                                                                                                        |
| R16 (10h)           | 15:9  |             | 00h       | Reserved - Do Not Change                                                                               |
| Right ADC           | 8     | ADC_VU      | N/A       | ADC Volume Update                                                                                      |
| Digital Volume      |       |             |           | Writing a 1 to this bit will cause left and right ADC volume to be updated simultaneously              |
|                     | 7:0   | ADCR_VOL    | 1100_     | Right ADC Digital Volume                                                                               |
|                     |       | [7:0]       | 0000b     | (See Table 14 for volume range)                                                                        |
|                     |       |             | (0dB)     |                                                                                                        |
| R17 (11h)           | 15:0  |             | 0000h     | Reserved - Do Not Change                                                                               |
| R18 (12h)           | 15:13 |             | 000b      | Reserved - Do Not Change                                                                               |
| GPIO Control        | 12    | IRQ         | Read Only | IRQ Readback                                                                                           |
| (1)                 |       | (ro)        |           | (Allows polling of IRQ status)                                                                         |
|                     | 11    | TEMPOK      | Read or   | Temperature OK status                                                                                  |
|                     |       | (rr)        | Reset     | Read-                                                                                                  |
|                     |       |             |           | 0 = Device temperature NOT ok                                                                          |
|                     |       |             |           | 1 = Device temperature ok                                                                              |
|                     |       |             |           | Write -                                                                                                |
|                     |       |             |           | 1 = Reset TEMPOK latch                                                                                 |
|                     | 10    | MICSHRT     | Read or   | MICBIAS short status                                                                                   |
|                     |       | (rr)        | Reset     | Read-                                                                                                  |
|                     |       |             |           | 0 = MICBIAS ok                                                                                         |
|                     |       |             |           | 1 = MICBIAS shorted                                                                                    |
|                     |       |             |           | Write-                                                                                                 |
|                     |       | MODET       | D /       | 1 = Reset MICSHRT latch                                                                                |
|                     | 9     | MICDET      | Read or   | MICBIAS detect status                                                                                  |
|                     |       | (rr)        | Reset     | MICBIAS microphone detect Readback                                                                     |
|                     |       |             |           | Read-                                                                                                  |
|                     |       |             |           | 0 = No Microphone detected                                                                             |
|                     |       |             |           | 1 = Microphone detected                                                                                |
|                     |       |             |           | Write-                                                                                                 |
|                     |       |             |           | 1 = Reset MICDET latch                                                                                 |



| REGISTER<br>ADDRESS | BIT  | LABEL         | DEFAULT | DESCRIPTION                                                         |
|---------------------|------|---------------|---------|---------------------------------------------------------------------|
|                     | 8    | PLL_LCK       | Read or | PLL Lock status                                                     |
|                     |      | (rr)          | Reset   | Read-                                                               |
|                     |      |               |         | 0 = PLL NOT locked                                                  |
|                     |      |               |         | 1 = PLL locked                                                      |
|                     |      |               |         | Write-                                                              |
|                     |      |               |         | 1 = Reset PLL_LCK latch                                             |
|                     | 7:0  | GPIO_STATUS   | Read or | GPIO and GPI Input Pin Status                                       |
|                     |      | [7:0]         | Reset   | GPIO_STATUS[7] = GPI8 pin status                                    |
|                     |      | (LL)          |         | GPIO_STATUS[6] = GPI7 pin status                                    |
|                     |      |               |         | GPIO_STATUS[5] = Reserved                                           |
|                     |      |               |         | GPIO_STATUS[4] = GPIO5 pin status                                   |
|                     |      |               |         | GPIO_STATUS[3] = GPIO4 pin status                                   |
|                     |      |               |         | GPIO_STATUS[2] = GPIO3 pin status                                   |
|                     |      |               |         | GPIO_STATUS[1] = Reserved                                           |
|                     |      |               |         | GPIO_STATUS[0] = Reserved                                           |
| R19 (13h)           | 15:0 |               | 1000h   | Reserved - Do Not Change                                            |
| R20 (14h)           | 15   | GPIO4_DEB_ENA | 0b      | GPIO4 Input De-Bounce                                               |
| GPIO3 and           |      |               |         | 0 = disabled (Not de-bounced)                                       |
| GPIO4               |      |               |         | 1 = enabled (Requires MCLK input and TOCLK_ENA=1)                   |
|                     | 14   | GPIO4_IRQ_ENA | 0b      | GPIO4 IRQ Enable                                                    |
|                     |      |               |         | 0 = disabled                                                        |
|                     | 40   | ODIO4 DIL     | OI:     | 1 = enabled (GPIO4 input will generate IRQ)                         |
|                     | 13   | GPIO4_PU      | 0b      | GPIO4 Pull-Up Resistor Enable                                       |
|                     |      |               |         | 0 = Pull-up disabled                                                |
|                     | 12   | CDIO4 DD      | 1b      | 1 = Pull-up enabled (Approx 150kΩ)  GPIO4 Pull-Down Resistor Enable |
|                     | 12   | GPIO4_PD      | l lb    | 0 = Pull-down disabled                                              |
|                     |      |               |         | 1 = Pull-down enabled (Approx 150kΩ)                                |
|                     | 11:8 | GPIO4_SEL     | 0000b   | GPIO4 Function Select                                               |
|                     | 11.0 | [3:0]         | 00000   | 0000 = Input pin                                                    |
|                     |      | [5.0]         |         | 0001 = Clock output (f=SYSCLK/OPCLKDIV)                             |
|                     |      |               |         | 0010 = Logic '0'                                                    |
|                     |      |               |         | 0011 = Logic '1'                                                    |
|                     |      |               |         | 0100 = PLL Lock output                                              |
|                     |      |               |         | 0101 = Temperature OK output                                        |
|                     |      |               |         | 0110 = SDOUT data output                                            |
|                     |      |               |         | 0111 = IRQ output                                                   |
|                     |      |               |         | 1000 = MIC Detect                                                   |
|                     |      |               |         | 1001 = MIC Short Circuit Detect                                     |
|                     |      |               |         | 1010 to 1111 = Reserved                                             |
|                     | 7    | GPIO3_DEB_ENA | 0b      | GPIO3 Input De-Bounce                                               |
|                     |      |               |         | 0 = disabled (Not de-bounced)                                       |
|                     |      |               |         | 1 = enabled (Requires MCLK input and TOCLK_ENA=1)                   |
|                     | 6    | GPIO3_IRQ_ENA | 0b      | GPIO3 IRQ Enable                                                    |
|                     |      |               |         | 0 = disabled                                                        |
|                     |      | ODIOS DI      | 0.      | 1 = enabled (GPIO3 input will generate IRQ)                         |
|                     | 5    | GPIO3_PU      | 0b      | GPIO3 Pull-Up Resistor Enable                                       |
|                     |      |               |         | 0 = Pull-up disabled                                                |
|                     |      | ODIO2 DD      | 41-     | 1 = Pull-up enabled (Approx 150kΩ)                                  |
|                     | 4    | GPIO3_PD      | 1b      | GPIO3 Pull-Down Resistor Enable                                     |
|                     |      |               |         | 0 = Pull-down disabled                                              |
|                     |      |               |         | 1 = Pull-down enabled (Approx 150k $\Omega$ )                       |



**WM8953** 

| REGISTER<br>ADDRESS           | BIT   | LABEL               | DEFAULT | DESCRIPTION                                                                                                                                                                                                                                                                                          |
|-------------------------------|-------|---------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | 3:0   | GPIO3_SEL<br>[3:0]  | 0000Ь   | GPIO3 Function Select  0000 = Input pin  0001 = Clock output (f=SYSCLK/OPCLKDIV)  0010 = Logic '0'  0011 = Logic '1'  0100 = PLL Lock output  0101 = Temperature OK output  0110 = SDOUT data output  0111 = IRQ output  1000 = MIC Detect  1001 = MIC Short Circuit Detect                          |
| D24 (45b)                     | 15:8  |                     | 10h     | 1010 to 1111 = Reserved                                                                                                                                                                                                                                                                              |
| R21 (15h)<br>GPIO5            | 7     | GPIO5_DEB_ENA       | 0b      | Reserved - Do Not Change  GPIO5 Input De-Bounce 0 = disabled (Not de-bounced) 1 = enabled (Requires MCLK input and TOCLK_ENA=1)                                                                                                                                                                      |
|                               | 6     | GPIO5_IRQ_ENA       | 0b      | GPIO5 IRQ Enable  0 = disabled  1 = enabled (GPIO5 input will generate IRQ)                                                                                                                                                                                                                          |
|                               | 5     | GPIO5_PU            | 0b      | GPIO5 Pull-Up Resistor Enable 0 = Pull-up disabled 1 = Pull-up enabled (Approx 150kΩ)                                                                                                                                                                                                                |
|                               | 4     | GPIO5_PD            | 1b      | GPIO5 Pull-Down Resistor Enable 0 = Pull-down disabled 1 = Pull-down enabled (Approx 150kΩ)                                                                                                                                                                                                          |
|                               | 3:0   | GPIO5_SEL<br>[3:0]  | 0000Ь   | GPIO5 Function Select  0000 = Input pin  0001 = Clock output (f=SYSCLK/OPCLKDIV)  0010 = Logic '0'  0011 = Logic '1'  0100 = PLL Lock output  0101 = Temperature OK output  0110 = SDOUT data output  1011 = IRQ output  1000 = MIC Detect  1001 = MIC Short Circuit Detect  1010 to 1111 = Reserved |
| R22 (16h)<br>GPI7 and<br>GPI8 | 15    | RD_3W_ENA           | 1b      | 3- / 4-wire readback configuration 1 = 3-wire mode 0 = 4-wire mode, using GPIO pin                                                                                                                                                                                                                   |
|                               | 14    | MODE_3W4W           | Ob      | 3-wire mode 0 = push 0/1 1 = open-drain 4-wire mode 0 = push 0/1 1 = wired-OR                                                                                                                                                                                                                        |
|                               | 13:12 |                     | 00b     | Reserved - Do Not Change                                                                                                                                                                                                                                                                             |
|                               | 11    | TEMPOK_IRQ_ENA      | 0b      | Temperature Sensor IRQ Enable 0 = disabled 1 = enabled                                                                                                                                                                                                                                               |
|                               | 10    | MICSHRT_IRQ_EN<br>A | 0b      | MICBIAS short circuit detect IRQ Enable 0 = disabled 1 = enabled                                                                                                                                                                                                                                     |



| REGISTER<br>ADDRESS | BIT   | LABEL            | DEFAULT  | DESCRIPTION                                                                         |
|---------------------|-------|------------------|----------|-------------------------------------------------------------------------------------|
|                     | 9     | MICDET_IRQ_ENA   | 0b       | MICBIAS current detect IRQ Enable                                                   |
|                     |       |                  |          | 0 = disabled                                                                        |
|                     |       |                  |          | 1 = enabled                                                                         |
|                     | 8     | PLL_LCK_IRQ_ENA  | 0b       | PLL Lock IRQ Enable                                                                 |
|                     |       |                  |          | 0 = disabled                                                                        |
|                     |       |                  |          | 1 = enabled                                                                         |
|                     | 7     | GPI8_DEB_ENA     | 0b       | GPI8 Input De-Bounce                                                                |
|                     |       |                  |          | 0 = disabled (Not de-bounced)                                                       |
|                     |       | ODIO IDO ENA     | 01       | 1 = enabled (Requires MCLK input and TOCLK_ENA=1)                                   |
|                     | 6     | GPI8_IRQ_ENA     | 0b       | GPI8 IRQ Enable                                                                     |
|                     |       |                  |          | 0 = disabled                                                                        |
|                     | 5     |                  | Oh       | 1 = enabled (GPI8 input will generate IRQ)                                          |
|                     | 4     | CDIO ENIA        | 0b<br>0b | Reserved - Do Not Change                                                            |
|                     | 4     | GPI8_ENA         | db       | GPI8 Input Pin Enable                                                               |
|                     |       |                  |          | 0 = RIN3/GPI8 pin disabled as GPI8 input<br>1 = RIN3/GPI8 pin enabled as GPI8 input |
|                     | 3     | GPI7_DEB_ENA     | 0b       | GPI7 Input De-Bounce                                                                |
|                     | 3     | GFII_DEB_ENA     | OD       | 0 = disabled (Not de-bounced)                                                       |
|                     |       |                  |          | 1 = enabled (Requires MCLK input and TOCLK_ENA=1)                                   |
|                     | 2     | GPI7_IRQ_ENA     | 0b       | GPI7 IRQ Enable                                                                     |
|                     | _     | OI II_II (Q_EIV) | OD .     | 0 = disabled                                                                        |
|                     |       |                  |          | 1 = enabled (GPI7 input will generate IRQ)                                          |
|                     | 1     |                  | 0b       | Reserved - Do Not Change                                                            |
|                     | 0     | GPI7_ENA         | 0b       | GPI7 Input Pin Enable                                                               |
|                     |       | 0                |          | 0 = LIN3/GPI7 pin disabled as GPI7 input                                            |
|                     |       |                  |          | 1 = LIN3/GPI7 pin enabled as GPI7 input                                             |
| R23 (17h)           | 15:13 |                  | 0000b    | Reserved - Do Not Change                                                            |
| GPIO Control        | 12    | IRQ_INV          | 0b       | IRQ Invert                                                                          |
| (2)                 |       | (rw)             |          | 0 = IRQ output active high                                                          |
|                     |       |                  |          | 1 = IRQ output active low                                                           |
|                     | 11    | TEMPOK_POL       | 1b       | Temperature Sensor polarity                                                         |
|                     |       | (rw)             |          | 0 = Non-inverted                                                                    |
|                     |       |                  |          | 1 = Inverted                                                                        |
|                     | 10    | MICSHRT_POL      | 0b       | MICBIAS short circuit detect polarity                                               |
|                     |       | (rw)             |          | 0 = Non-inverted                                                                    |
|                     |       |                  |          | 1 = Inverted                                                                        |
|                     | 9     | MICDET_POL       | 0b       | MICBIAS current detect polarity                                                     |
|                     |       | (rw)             |          | 0 = Non-inverted                                                                    |
|                     |       |                  |          | 1 = Inverted                                                                        |
|                     | 8     | PLL_LCK_POL      | 0b       | PLL Lock Polarity                                                                   |
|                     |       | (rw)             |          | 0 = Non-inverted                                                                    |
|                     | 7.0   | 0010 00117.01    | 001-     | 1 = Inverted                                                                        |
|                     | 7:0   | GPIO_POL[7:0]    | 00h      | GPIOn Input Polarity                                                                |
|                     |       | (rw)             |          | 0 = Non-inverted<br>1 = Inverted                                                    |
|                     |       |                  |          | GPIO_POL[7]: GPI8 polarity                                                          |
|                     |       |                  |          | GPIO_POL[6]: GPI7 polarity                                                          |
|                     |       |                  |          | GPIO_POL[5]: Reserved                                                               |
|                     |       |                  |          | GPIO_POL[4]: GPIO5 polarity                                                         |
|                     |       |                  |          | GPIO_POL[3]: GPIO4 polarity                                                         |
|                     |       |                  |          | GPIO_POL[2]: GPIO3 polarity                                                         |
|                     |       |                  |          | GPIO_POL[1]: Reserved                                                               |
|                     |       |                  |          | GPIO_POL[0]: Reserved                                                               |
| R24 (18h)           | 15:9  |                  | 00h      | Reserved - Do Not Change                                                            |



| REGISTER<br>ADDRESS       | BIT       | LABEL        | DEFAULT    | DESCRIPTION                                                                                                                                   |
|---------------------------|-----------|--------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| LIN12 Input<br>PGA Volume | 8         | IPVU[0]      | N/A        | Input PGA Volume Update Writing a 1 to this bit will cause all input PGA volumes to be updated simultaneously (LIN12, LIN34, RIN12 and RIN34) |
|                           | 7         | LI12MUTE     | 1b         | LIN12 PGA Mute                                                                                                                                |
|                           |           | LI IZIMO I Z |            | 0 = Disable Mute                                                                                                                              |
|                           |           |              |            | 1 = Enable Mute                                                                                                                               |
|                           | 6         | LI12ZC       | 0b         | LIN12 PGA Zero Cross Detector                                                                                                                 |
|                           |           |              |            | 0 = Change gain immediately                                                                                                                   |
|                           |           |              |            | 1 = Change gain on zero cross only                                                                                                            |
|                           | 5         |              | 0b         | Reserved - Do Not Change                                                                                                                      |
|                           | 4:0       | LIN12VOL     | 01011b     | LIN12 Volume                                                                                                                                  |
|                           |           | [4:0]        |            | (See Table 8 for PGA volume range)                                                                                                            |
| R25 (19h)                 | 15:9      |              | 00h        | Reserved - Do Not Change                                                                                                                      |
| LIN34 Input               | 8         | IPVU[1]      | N/A        | Input PGA Volume Update                                                                                                                       |
| PGA Volume                |           |              |            | Writing a 1 to this bit will cause all input PGA volumes to be updated simultaneously (LIN12, LIN34, RIN12 and RIN34)                         |
|                           | 7         | LI34MUTE     | 1b         | LIN34 PGA Mute                                                                                                                                |
|                           |           |              |            | 0 = Disable Mute                                                                                                                              |
|                           | 6         | 1.12470      | Oh         | 1 = Enable Mute LIN34 PGA Zero Cross Detector                                                                                                 |
|                           | 6         | LI34ZC       | 0b         |                                                                                                                                               |
|                           |           |              |            | 0 = Change gain immediately 1 = Change gain on zero cross only                                                                                |
|                           | 5         |              | 0b         | Reserved - Do Not Change                                                                                                                      |
|                           | 4:0       | LIN34VOL     | 01011b     | LIN34 Volume                                                                                                                                  |
|                           | 1.0       | [4:0]        | 010115     | (See Table 8 for PGA volume range)                                                                                                            |
| R26 (1Ah)                 | 15:9      | []           | 00h        | Reserved - Do Not Change                                                                                                                      |
| RIN12 Input               | 8         | IPVU[2]      | N/A        | Input PGA Volume Update                                                                                                                       |
| PGA Volume                |           |              |            | Writing a 1 to this bit will cause all input PGA volumes to be updated simultaneously (LIN12, LIN34, RIN12 and RIN34)                         |
|                           | 7         | RI12MUTE     | 1b         | RIN12 PGA Mute                                                                                                                                |
|                           |           |              |            | 0 = Disable Mute                                                                                                                              |
|                           |           |              |            | 1 = Enable Mute                                                                                                                               |
|                           | 6         | RI12ZC       | 0b         | RIN12 PGA Zero Cross Detector                                                                                                                 |
|                           |           |              |            | 0 = Change gain immediately                                                                                                                   |
|                           |           |              |            | 1 = Change gain on zero cross only                                                                                                            |
|                           | 5         | DINAN (C)    | 0b         | Reserved - Do Not Change                                                                                                                      |
|                           | 4:0       | RIN12VOL     | 01011b     | RIN12 Volume                                                                                                                                  |
| D27 (1Dh)                 | 1F:0      | [4:0]        | 00h        | (See Table 8 for PGA volume range)                                                                                                            |
| R27 (1Bh)<br>RIN34 Input  | 15:9<br>8 | IPVU[3]      | 00h<br>N/A | Reserved - Do Not Change Input PGA Volume Update                                                                                              |
| PGA Volume                | 0         | الديماني     | IN/A       | Writing a 1 to this bit will cause all input PGA volumes to be updated simultaneously (LIN12, LIN34, RIN12 and RIN34)                         |
|                           | 7         | RI34MUTE     | 1b         | RIN34 PGA Mute                                                                                                                                |
|                           |           |              |            | 0 = Disable Mute                                                                                                                              |
|                           |           |              |            | 1 = Enable Mute                                                                                                                               |
|                           | 6         | RI34ZC       | 0b         | RIN34 PGA Zero Cross Detector                                                                                                                 |
|                           |           |              |            | 0 = Change gain immediately                                                                                                                   |
|                           |           |              |            | 1 = Change gain on zero cross only                                                                                                            |
|                           | 5         |              | 0b         | Reserved - Do Not Change                                                                                                                      |
|                           | 4:0       | RIN34VOL     | 01011b     | RIN34 Volume                                                                                                                                  |
|                           |           | [4:0]        |            | (See Table 8 for PGA volume range)                                                                                                            |
| R28 (1Ch)                 | 15:0      |              | 0000h      | Reserved - Do Not Change                                                                                                                      |
| R29 (1Dh)                 | 15:0      |              | 0000h      | Reserved - Do Not Change                                                                                                                      |
| R30 (1Eh)                 | 15:0      | İ            | 0066h      | Reserved - Do Not Change                                                                                                                      |



| REGISTER<br>ADDRESS | BIT  | LABEL    | DEFAULT | DESCRIPTION                          |
|---------------------|------|----------|---------|--------------------------------------|
| R31 (1Fh)           | 15:0 |          | 0022h   | Reserved - Do Not Change             |
| R32 (20h)           | 15:0 |          | 0079h   | Reserved - Do Not Change             |
| R33 (21h)           | 15:0 |          | 0079h   | Reserved - Do Not Change             |
| R34 (22h)           | 15:0 |          | 0003h   | Reserved - Do Not Change             |
| R35 (23h)           | 15:0 |          | 0003h   | Reserved - Do Not Change             |
| R36 (24h)           | 15:0 |          | 0055h   | Reserved - Do Not Change             |
| R37 (25h)           | 15:0 |          | 0100h   | Reserved - Do Not Change             |
| R38 (26h)           | 15:0 |          | 0079h   | Reserved - Do Not Change             |
| R39 (27h)           | 15:0 |          | 0000h   | Reserved - Do Not Change             |
| R40 (28h)           | 15:8 |          | 00h     | Reserved - Do Not Change             |
| Input Mixers        | 7    | LMP4     | 0b      | LIN34 PGA Non-Inverting Input Select |
| (2)                 |      |          |         | 0 = LIN4 not connected to PGA        |
|                     |      |          |         | 1 = LIN4 connected to PGA            |
|                     | 6    | LMN3     | 0b      | LIN34 PGA Inverting Input Select     |
|                     |      |          |         | 0 = LIN3 not connected to PGA        |
|                     |      |          |         | 1 = LIN3 connected to PGA            |
|                     | 5    | LMP2     | 0b      | LIN12 PGA Non-Inverting Input Select |
|                     |      |          |         | 0 = LIN2 not connected to PGA        |
|                     |      |          |         | 1 = LIN2 connected to PGA            |
|                     | 4    | LMN1     | 0b      | LIN12 PGA Inverting Input Select     |
|                     |      |          |         | 0 = LIN1 not connected to PGA        |
|                     |      |          |         | 1 = LIN1 connected to PGA            |
|                     | 3    | RMP4     | 0b      | RIN34 PGA Non-Inverting Input Select |
|                     |      |          |         | 0 = RIN4 not connected to PGA        |
|                     |      |          |         | 1 = RIN4 connected to PGA            |
|                     | 2    | RMN3     | 0b      | RIN34 PGA Inverting Input Select     |
|                     |      |          |         | 0 = RIN3 not connected to PGA        |
|                     |      |          |         | 1 = RIN3 connected to PGA            |
|                     | 1    | RMP2     | 0b      | RIN12 PGA Non-Inverting Input Select |
|                     |      |          |         | 0 = RIN2 not connected to PGA        |
|                     |      |          |         | 1 = RIN2 connected to PGA            |
|                     | 0    | RMN1     | 0b      | RIN12 PGA Inverting Input Select     |
|                     |      |          |         | 0 = RIN1 not connected to PGA        |
|                     |      |          |         | 1 = RIN1 connected to PGA            |
| R41 (29h)           | 15:9 |          | 00h     | Reserved - Do Not Change             |
| Input Mixers        | 8    | L34MNB   | 0b      | LIN34 PGA Output to INMIXL Mute      |
| (3)                 |      |          |         | 0 = Mute                             |
|                     |      |          |         | 1 = Un-Mute                          |
|                     | 7    | L34MNBST | 0b      | LIN34 PGA Output to INMIXL Gain      |
|                     |      |          |         | 0 = 0dB                              |
|                     |      |          |         | 1 = +30dB                            |
|                     | 6    |          | 0b      | Reserved - Do Not Change             |
|                     | 5    | L12MNB   | 0b      | LIN12 PGA Output to INMIXL Mute      |
|                     |      |          |         | 0 = Mute                             |
|                     |      |          |         | 1 = Un-Mute                          |
|                     | 4    | L12MNBST | 0b      | LIN12 PGA Output to INMIXL Gain      |
|                     |      |          |         | 0 = 0dB                              |
|                     |      |          |         | 1 = +30dB                            |
|                     | 3:0  |          | 0h      | Reserved - Do Not Change             |



| REGISTER<br>ADDRESS       | BIT  | LABEL    | DEFAULT | DESCRIPTION                                                |
|---------------------------|------|----------|---------|------------------------------------------------------------|
| R42 (2Ah)                 | 15:9 |          | 00h     | Reserved - Do Not Change                                   |
| Input Mixers              | 8    | R34MNB   | 0b      | RIN34 PGA Output to INMIXR Mute                            |
| (4)                       |      |          |         | 0 = Mute                                                   |
|                           |      |          |         | 1 = Un-Mute                                                |
|                           | 7    | R34MNBST | 0b      | RIN34 PGA Output to INMIXR Gain                            |
|                           |      |          |         | 0 = 0dB                                                    |
|                           |      |          |         | 1 = +30dB                                                  |
|                           | 6    |          | 0b      | Reserved - Do Not Change                                   |
|                           | 5    | R12MNB   | 0b      | RIN12 PGA Output to INMIXR Mute                            |
|                           |      |          |         | 0 = Mute                                                   |
|                           |      |          |         | 1 = Un-Mute                                                |
|                           | 4    | R12MNBST | 0b      | RIN12 PGA Output to INMIXR Gain                            |
|                           |      |          |         | 0 = 0dB                                                    |
|                           |      |          |         | 1 = +30dB                                                  |
|                           | 3:0  |          | 0h      | Reserved - Do Not Change                                   |
| R43 (2Bh)                 | 15:9 |          | 00h     | Reserved - Do Not Change                                   |
| Input Mixers              | 8:6  | LI2BVOL  | 000b    | LIN2 Pin to INMIXL Gain and Mute                           |
| (5)                       |      | [2:0]    |         | 000 = Mute                                                 |
|                           |      |          |         | 001 = -12dB                                                |
|                           |      |          |         | 010 = -9dB                                                 |
|                           |      |          |         | 011 = -6dB                                                 |
|                           |      |          |         | 100 = -3dB                                                 |
|                           |      |          |         | 101 = 0dB                                                  |
|                           |      |          |         | 110 = +3dB                                                 |
|                           | 5:0  |          | 000000b | 111 = +6dB                                                 |
| D44 (2Cb)                 | 15:9 |          | 000000B | Reserved - Do Not Change                                   |
| R44 (2Ch)<br>Input Mixers | 8:6  | RI2BVOL  | 000b    | Reserved - Do Not Change  RIN2 Pin to INMIXR Gain and Mute |
| (6)                       | 0.0  | [2:0]    | doob    | 000 = Mute                                                 |
| (-)                       |      | [2.0]    |         | 000 = Mate<br>001 = -12dB                                  |
|                           |      |          |         | 010 = -9dB                                                 |
|                           |      |          |         | 011 = -6dB                                                 |
|                           |      |          |         | 100 = -3dB                                                 |
|                           |      |          |         | 101 = 0dB                                                  |
|                           |      |          |         | 110 = +3dB                                                 |
|                           |      |          |         | 111 = +6dB                                                 |
|                           | 5:0  |          | 000000b | Reserved - Do Not Change                                   |
| R45 (2Dh)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R46 (2Eh)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R47 (2Fh)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R48 (30h)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R49 (31h)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R50 (32h)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R51 (33h)                 | 15:0 |          | 0180h   | Reserved - Do Not Change                                   |
| R52 (34h)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R53 (35h)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R54 (36h)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R55 (37h)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R56 (38h)                 | 15:0 |          | 0000h   | Reserved - Do Not Change                                   |
| R57 (39h)                 | 15:7 |          | 00h     | Reserved - Do Not Change                                   |
|                           |      |          |         |                                                            |



| REGISTER<br>ADDRESS        | BIT     | LABEL           | DEFAULT | DESCRIPTION                                                                                                                                                                                           |
|----------------------------|---------|-----------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | 3       | BUFIOEN         | 0b      | Enables the VGS / R current generator and the analogue input bias  0 = Disabled  1 = Enabled                                                                                                          |
|                            | 2:0     |                 | 000b    | Reserved - Do Not Change                                                                                                                                                                              |
| R58 (3Ah)                  | 15:8    |                 | 00h     | Reserved - Do Not Change                                                                                                                                                                              |
| Microphone                 | 7:6     | MCDSCTH         | 00b     | MICBIAS Short Circuit Current Detect Threshold                                                                                                                                                        |
| Bias                       |         | [1:0]           |         | 00 = 600uA<br>01 = 1200uA<br>10 = 1800uA<br>11 = 2400uA<br>These values are for AVDD=3.3V and scale proportionally with AVDD.                                                                         |
|                            | 5:3     | MDCTHR<br>[2:0] | 000b    | MICBIAS Current Detect Threshold 000 = 200uA 001 = 350uA 010 = 500uA 011 = 650uA 100 = 800uA 110 = 950uA 110 = 1100uA 111 = 1200uA These values are for AVDD=3.3V and scale proportionally with AVDD. |
|                            | 2       | MCD             | 0b      | MICBIAS Current and Short Circuit Detect Enable  0 = disabled  1 = enabled                                                                                                                            |
|                            | 1       |                 | 0b      | Reserved - Do Not Change                                                                                                                                                                              |
|                            | 0       | MBSEL           | 0b      | Microphone Bias Voltage Control 0 = 0.9 * AVDD 1 = 0.65 * AVDD                                                                                                                                        |
| R59 (3Bh)                  | 15:0    |                 | 0000h   | Reserved - Do Not Change                                                                                                                                                                              |
| R60 (3Ch)                  | 15:8    |                 | 00h     | Reserved - Do Not Change                                                                                                                                                                              |
| PLL (1)                    | 7       | SDM             | 0b      | Enable PLL Integer Mode 0 = Integer mode 1 = Fractional mode                                                                                                                                          |
|                            | 6       | PRESCALE        | 0b      | Divide MCLK by 2 at PLL input 0 = Divide by 1 1 = Divide by 2                                                                                                                                         |
|                            | 5:4     |                 | 00b     | Reserved - Do Not Change                                                                                                                                                                              |
|                            | 3:0     | PLLN            | 8h      | Integer (N) part of PLL frequency ratio.                                                                                                                                                              |
|                            |         | [3:0]           |         | Use values greater than 5 and less than 13.                                                                                                                                                           |
| R61 (3Dh)                  | 15:8    |                 | 00h     | Reserved - Do Not Change                                                                                                                                                                              |
| PLL (2)                    | 7:0     | PLLK<br>[15:8]  | 31h     | Fractional (K) part of PLL frequency ratio (Most significant bits)                                                                                                                                    |
| R62 (3Eh)                  | 15:8    |                 | 00h     | Reserved - Do Not Change                                                                                                                                                                              |
| PLL (2)                    | 7:0     | PLLK<br>[7:0]   | 26h     | Fractional (K) part of PLL frequency ratio (Least significant bits)                                                                                                                                   |
| R63 (3Fh) to<br>R116 (74h) | Reserve | d               |         |                                                                                                                                                                                                       |
| R117 (75h)                 | 15:2    |                 | 0000h   | Reserved - Do Not Change                                                                                                                                                                              |
| Access<br>Control          | 1       | EXT_ACCESS_ENA  | 0b      | Extended Register Map Access 0 = disabled                                                                                                                                                             |
|                            |         |                 |         | 1 = enabled                                                                                                                                                                                           |



| REGISTER<br>ADDRESS         | BIT     | LABEL          | DEFAULT | DESCRIPTION              |
|-----------------------------|---------|----------------|---------|--------------------------|
|                             | 0       |                | 0b      | Reserved - Do Not Change |
| R118 (76h) to<br>R121 (79h) | Reserve | ed             |         |                          |
| R122 (7Ah)                  | 15      | ADCL_ADCR_LINK | 0b      | 0 = ADC Sync disabled    |
| Extended ADC                |         |                |         | 1 = ADC Sync enabled     |
| Control                     | 14:0    |                | 2003h   | Reserved - Do Not Change |
| R123 (7Bh) to               | Reserve | :d             |         |                          |
| R127 (7Fh)                  |         |                |         |                          |



# **DIGITAL FILTER CHARACTERISTICS**

| PARAMETER            | TEST CONDITIONS | MIN    | TYP   | MAX      | UNIT |
|----------------------|-----------------|--------|-------|----------|------|
| ADC Filter           |                 |        |       |          |      |
| Passband             | +/- 0.05dB      | 0      |       | 0.454 fs |      |
|                      | -6dB            |        | 0.5fs |          |      |
| Passband Ripple      |                 |        |       | +/- 0.05 | dB   |
| Stopband             |                 | 0.546s |       |          |      |
| Stopband Attenuation | f > 0.546 fs    | -60    |       |          | dB   |
| Group Delay          |                 |        | 18/fs |          |      |

# **ADC FILTER RESPONSES**





Figure 59 ADC Digital Filter Frequency Response

Figure 60 ADC Digital Filter Ripple

# **ADC HIGH PASS FILTER RESPONSES**



Figure 61 ADC Digital High Pass Filter Frequency Response (48kHz, Hi-Fi Mode, ADC\_HPF\_CUT[1:0]=00)



Figure 62 ADC Digital High Pass Filter Ripple (48kHz, Voice Mode, ADC\_HPF\_CUT=01, 10 and 11)

# **APPLICATIONS INFORMATION**

# RECOMMENDED EXTERNAL COMPONENTS



### Notes:

- 1. Wolfson recommend using a single, common ground reference. Where this is not possible care should be taken to optimise split ground configuration for audio performance.
- 2. Supply decoupling capacitors on DCVDD, DBVDD and AVDD should be positioned as close to the WM8953 as possible. Values indicated are minimum requirements.
- Capacitor types should be carefully chosen. Capacitors with very low ESR are recommended for optimum performance.
   The 2k2 MICBIAS resistors on each of the MIC inputs are typical values and will be suitable for many electret type microphones.
   However, it is recommended that engineers refer to individual microphone specifications prior to finalising the value of this component.

# **PACKAGE DIMENSIONS**



| Symbols | Dimensions (mm) |           |       |      |  |  |  |  |
|---------|-----------------|-----------|-------|------|--|--|--|--|
|         | MIN             | NOM       | MAX   | NOTE |  |  |  |  |
| Α       | 0.615           | 0.7       | 0.785 |      |  |  |  |  |
| A1      | 0.225           | 0.250     | 0.275 |      |  |  |  |  |
| A2      | 0.355           | 0.380     | 0.405 |      |  |  |  |  |
| D       |                 | 3.226 BSC |       |      |  |  |  |  |
| D1      |                 | 2.500 BSC |       |      |  |  |  |  |
| E       |                 | 3.440 BSC |       |      |  |  |  |  |
| E1      |                 | 3.00 BSC  |       |      |  |  |  |  |
| е       |                 | 0.50 BSC  |       | 5    |  |  |  |  |
| f       | 0.060 BSC       |           |       |      |  |  |  |  |
| g       | 0.035           | 0.070     | 0.105 |      |  |  |  |  |
| h       |                 | 0.315 BSC |       |      |  |  |  |  |

- NOTES:

  1. PRIMARY DATUM -Z- AND SEATING PLANE ARE DEFINED BY THE SPHERICAL CROWNS OF THE SOLDER BALLS.

  2. THIS DIMENSION INCLUDES STAND-OFF HEIGHT 'A1' AND BACKSIDE COATING.

  3. A1 CORNER IS IDENTIFIED BY INKLASER MARK ON TOP PACKAGE.

  4. BILATERAL TOLERANCE ZONE IS APPLIED TO EACH SIDE OF THE PACKAGE BODY.

  5. 'e' REPRESENTS THE BASIC SOLDER BALL GRID PITCH.

  6. THIS DRAWING IS SUBJECT TO CHANGE WITHOUT NOTICE.

  7. FOLLOWS JEDEC DESIGN GUIDE MO-211-C.



# **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 plc 26 Westfield Road Edinburgh EH11 2QB

United Kingdom

Tel :: +44 (0)131 272 7000 Fax :: +44 (0)131 272 7001

Email :: sales@wolfsonmicro.com

