## WM8950

## ADC with Microphone Input and Programmable Digital Filters

## DESCRIPTION

The WM8950 is a low power, high quality mono ADC designed for portable applications such as Digital Still Camera, Digital Voice Recorder or games console accessories.

The device integrates support for a differential or single ended mic. External component requirements are reduced as no separate microphone amplifiers are required.

Advanced Sigma Delta Converters are used along with digital decimation filters to give high quality audio at sample rates from 8 to $48 \mathrm{ks} / \mathrm{s}$. Additional digital filtering options are available, to cater for application filtering such as wind noise reduction, noise rejection, plus an advanced mixed signal ALC function with noise gate is provided.

An on-chip PLL is provided to generate the required Master Clock from an external reference clock. The PLL clock can also be output if required elsewhere in the system.
The WM8950 operates at supply voltages from 2.5 to 3.6 V , although the digital supplies can operate at voltages down to 1.71 V to save power. Different sections of the chip can also be powered down under software control by way of the selectable two or three wire control interface.

WM8950 is supplied in a very small $4 \times 4 \mathrm{~mm}$ QFN package, offering high levels of functionality in minimum board area, with high thermal performance.

## FEATURES

## Mono ADC:

- Audio sample rates:8, $11.025,16,22.05,24,32,44.1,48 \mathrm{kHz}$
- SNR 94dB, THD -83dB ('A'-weighted @ 8 - 48ks/s)
- Multiple auxiliary analogue inputs


## Mic Preamps

- Differential or single end Microphone Interface
- Programmable preamp gain
- Pseudo differential inputs with common mode rejection
- Programmable ALC / Noise Gate in ADC path
- Low-noise bias supplied for electret microphones


## OTHER FEATURES

- 5 band EQ
- Programmable High-Pass Filter (wind noise reduction)
- Fully Programmable IIR Filter (notch filter)
- On-chip PLL
- Low power, low voltage
- 2.5V to 3.6 V (digital: 1.71 V to 3.6 V )
- power consumption 10 mA all-on $48 \mathrm{ks} / \mathrm{s}$ mode
- $4 \times 4 \times 0.9 \mathrm{~mm} 24$ lead QFN package


## APPLICATIONS

- Digital Still Camera
- General Purpose low power audio ADC
- Games console accessories
- Voice recorders



## TABLE OF CONTENTS

DESCRIPTION ..... 1
FEATURES ..... 1
APPLICATIONS ..... 1
TABLE OF CONTENTS ..... 2
PIN CONFIGURATION ..... 3
ORDERING INFORMATION ..... 3
PIN DESCRIPTION ..... 4
ABSOLUTE MAXIMUM RATINGS ..... 5
RECOMMENDED OPERATING CONDITIONS ..... 5
ELECTRICAL CHARACTERISTICS ..... 6
TERMINOLOGY ..... 7
SIGNAL TIMING REQUIREMENTS ..... 8
SYSTEM CLOCK TIMING ..... 8
AUDIO INTERFACE TIMING - MASTER MODE ..... 8
AUDIO INTERFACE TIMING - SLAVE MODE ..... 9
CONTROL INTERFACE TIMING - 3-WIRE MODE ..... 10
CONTROL INTERFACE TIMING - 2-WIRE MODE ..... 11
DEVICE DESCRIPTION ..... 12
INTRODUCTION ..... 12
INPUT SIGNAL PATH ..... 13
ANALOGUE TO DIGITAL CONVERTER (ADC) ..... 18
INPUT AUTOMATIC LEVEL CONTROL (ALC) ..... 22
DIGITAL AUDIO INTERFACES ..... 36
AUDIO SAMPLE RATES ..... 41
MASTER CLOCK AND PHASE LOCKED LOOP (PLL) ..... 42
GENERAL PURPOSE INPUT/OUTPUT ..... 44
CONTROL INTERFACE ..... 44
RESETTING THE CHIP ..... 45
POWER SUPPLIES ..... 46
ADC POWER UP/DOWN SEQUENCE ..... 46
POWER MANAGEMENT ..... 47
REGISTER MAP ..... 49
DIGITAL FILTER CHARACTERISTICS ..... 50
TERMINOLOGY ..... 50
ADC FILTER RESPONSES ..... 50
DE-EMPHASIS FILTER RESPONSES ..... 51
HIGH-PASS FILTER ..... 52
5-BAND EQUALISER ..... 53
APPLICATIONS INFORMATION ..... 57
RECOMMENDED EXTERNAL COMPONENTS ..... 57
PACKAGE DIAGRAM ..... 58
IMPORTANT NOTICE ..... 59
REVISION HISTORY ..... 60

## PIN CONFIGURATION



## ORDERING INFORMATION

| ORDER CODE | TEMPERATURE <br> RANGE | PACKAGE | MOISTURE SENSITIVITY <br> LEVEL | PACKAGE BODY <br> TEMPERATURE |
| :---: | :---: | :---: | :---: | :---: |
| WM8950CGEFL/V | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 24-lead QFN $(4 \times 4 \times 0.9 \mathrm{~mm})$ <br> (Pb-free) | MSL3 | $260^{\circ} \mathrm{C}$ |
| WM8950CGEFL/RV | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $24-l e a d ~ Q F N ~(4 \times 4 \times 0.9 \mathrm{~mm})$ <br> (Pb-free, tape and reel) | MSL3 | $260^{\circ} \mathrm{C}$ |

## Note:

Reel Quantity $=3,500$

## PIN DESCRIPTION

| PIN NO | NAME | TYPE |  |
| :---: | :---: | :--- | :--- |
| 1 | MICBIAS | Analogue Output | DESCRIPTION |
| 2 | AVDD | Supply | Analogue supply (feeds ADC) |
| 3 | AGND | Supply | Analogue ground (feeds ADC) |
| 4 | DCVDD | Supply | Digital core supply |
| 5 | DBVDD | Supply | Digital buffer (input/output) supply |
| 6 | DGND | Supply | Digital ground |
| 7 | ADCDAT | Digital Output | ADC digital audio data output |
| 8 | TP | Test Pin | Connect to ground |
| 9 | FRAME | Digital Input / Output | ADC sample rate clock or frame synch |
| 10 | BCLK | Digital Input / Output | Digital audio bit clock |
| 11 | MCLK | Digital Input | Master clock input |
| 12 | CSB/GPIO | Digital Input / Output | 3-Wire MPU chip select or general purpose input/output pin. |
| 13 | SCLK | Digital Input | 3-Wire MPU clock Input / 2-Wire MPU Clock Input |
| 14 | SDIN | Digital Input / Output | 3-Wire MPU data Input / 2-Wire MPU Data Input |
| 15 | MODE | Digital Input | Control interface mode selection pin. |
| 16 | DNC | Do not connect | Leave this pin floating |
| 17 | DNC | Do not connect | Leave this pin floating |
| 18 | AGND2 | Supply | Analogue ground |
| 19 | DNC | Do not connect | Leave this pin floating |
| 20 | AVDD2 | Supply | Analogue supply |
| 21 | AUX | Analogue Input | Auxiliary analogue input |
| 22 | VMID | Reference | Decoupling for midrail reference voltage |
| 23 | MICN | Analogue Input | Microphone negative input |
| 24 | MICP | Analogue Input | Microphone positive input (common mode) |

## Note:

It is recommended that the QFN ground paddle should be connected to analogue ground on the application PCB.

## 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.

Cirrus Logic 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^{\circ} \mathrm{C} / 85 \%$ Relative Humidity. Not normally stored in moisture barrier bag.
MSL2 = out of bag storage for 1 year at $<30^{\circ} \mathrm{C} / 60 \%$ Relative Humidity. Supplied in moisture barrier bag.
MSL3 $=$ out of bag storage for 168 hours at $<30^{\circ} \mathrm{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 |
| :--- | :---: | :---: |
| DBVDD, DCVDD, AVDD, AVDD2 supply voltages | -0.3 V | +4.2 |
| Voltage range digital inputs | DGND -0.3 V | DVDD +0.3 V |
| Voltage range analogue inputs | AGND -0.3 V | AVDD +0.3 V |
| Operating temperature range, $\mathrm{T}_{\mathrm{A}}$ | $-40^{\circ} \mathrm{C}$ | $+85^{\circ} \mathrm{C}$ |
| Storage temperature prior to soldering | $30^{\circ} \mathrm{C} \mathrm{max} / 85 \% \mathrm{RH}$ max |  |
| Storage temperature after soldering | $-65^{\circ} \mathrm{C}$ | $+150^{\circ} \mathrm{C}$ |

## Notes:

1. Analogue and digital grounds must always be within 0.3 V of each other.
2. All digital and analogue supplies are completely independent from each other.

## 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 supplies range | AVDD, AVDD2 | 2.5 |  | 3.6 | V |
| Ground | DGND, AGND, AGND2 |  | 0 |  | V |

## Notes:

1. When using PLL, DCVDD must be 1.9 V or higher.
2. AVDD must be $\geq$ DBVDD and DCVDD.
3. DBVDD must be $\geq$ DCVDD.
4. When using PLL, DCVDD must be $\geq 1.9 \mathrm{~V}$.

## ELECTRICAL CHARACTERISTICS

## Test Conditions

DCVDD $=1.8 \mathrm{~V}, \mathrm{AVDD}=\mathrm{DBVDD}=3.3 \mathrm{~V}, \mathrm{SPKVDD}=3.3 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, 1 \mathrm{kHz}$ signal, $\mathrm{fs}=48 \mathrm{kHz}$,
24-bit audio data unless otherwise stated.

| PARAMETER | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Microphone Inputs (MICN, MICP) |  |  |  |  |  |  |
| Full-scale Input Signal Level (Note 1) - note this changes with AVDD | $\mathrm{V}_{\text {INFS }}$ | $\begin{aligned} & \text { PGABOOST }=0 \mathrm{~dB} \\ & \text { INPPGAVOL }=0 \mathrm{~dB} \end{aligned}$ |  | $\begin{gathered} 1.0 \\ 0 \end{gathered}$ |  | Vrms <br> dBV |
| Mic PGA equivalent input noise | At 35.25 dB gain |  |  | 150 |  | uV |
| Input resistance | $\mathrm{R}_{\text {MICIN }}$ | Gain set to 35.25 dB |  | 1.6 |  | $\mathrm{k} \Omega$ |
| Input resistance | $\mathrm{R}_{\text {MIICIN }}$ | Gain set to 0dB |  | 47 |  | $\mathrm{k} \Omega$ |
| Input resistance | $\mathrm{R}_{\text {MICIN }}$ | Gain set to -12dB |  | 75 |  | $\mathrm{k} \Omega$ |
| Input resistance | $\mathrm{R}_{\text {MICIP }}$ | (Constant for all gain settings) |  | 94 |  | $\mathrm{k} \Omega$ |
| Input Capacitance | $\mathrm{C}_{\text {micin }}$ |  |  | 10 |  | pF |

MIC Input Programmable Gain Amplifier (PGA)

| Maximum Programmable Gain |  |  | 35.25 |  | dB |  |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: |
| Minimum Programmable Gain |  |  |  | -12 |  | dB |
| Programmable Gain Step Size |  | Guaranteed monotonic |  | 0.75 |  | dB |
| Mute Attenuation |  |  | 108 |  | dB |  |

Selectable Input Gain Boost (0/+20dB)

| Gain Boost |  |  | 0 |  | 20 | $d B$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Automatic Level Control (ALC)/Limiter

| Target Record Level |  |  | -28.5 |  | -6 | dB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Maximum Programmable Gain |  |  |  | 35.25 |  | dB |
| Minimum Programmable Gain |  |  |  | -12 |  | dB |
| Programmable Gain Step Size |  | Guaranteed Monotonic |  | 0.75 |  | dB |
| Gain Hold Time (Note 2) | $\mathrm{t}_{\text {HoL }}$ | $\begin{gathered} \text { MCLK }=12.288 \mathrm{MHz} \\ \text { (Note 4) } \end{gathered}$ | $\begin{gathered} 0,2.67,5.33,10.67, \ldots, 43691 \\ \text { (time doubles with each step) } \end{gathered}$ |  |  | ms |
| Gain Ramp-Up (Decay) Time (Note 3) | $\mathrm{t}_{\mathrm{DCY}}$ | ALCMODE=0 (ALC), MCLK $=12.288 \mathrm{MHz}$ (Note 4) | $3.3,6.6,13.1, \ldots, 3360$ <br> (time doubles with each step) |  |  | ms |
|  |  | ALCMODE=1 (limiter), MCLK=12.288MHz (Note 4) | $0.73,1.45,2.91, \ldots, 744$ <br> (time doubles with each step) |  |  |  |
| Gain Ramp-Down (Attack) Time (Note 3) | $\mathrm{t}_{\text {ATK }}$ | ALCMODE=0 (ALC), MCLK $=12.288 \mathrm{MHz}$ (Note 4) | $\begin{gathered} 0.83,1.66,3.33, \ldots, 852 \\ \text { (time doubles with each step) } \end{gathered}$ |  |  | ms |
|  |  | ALCMODE=1 (limiter), MCLK=12.288MHz (Note 4) | $\begin{aligned} & 0.18,0.36,0.73, \ldots, 186 \\ & \text { (time doubles with each step) } \end{aligned}$ |  |  |  |

## Analogue to Digital Converter (ADC)

| Signal to Noise Ratio (Note 5, 6) |  | A-weighted, <br> OdB PGA gain | 85 | 94 | dB |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| Total Harmonic Distortion + Noise <br> (Note 6) | THD+N | -1dBFS input <br> 0dB PGA gain | -75 | -83 |  | dB |
| Auxiliary Analogue Input (AUX) |  |  |  |  |  |  |
| Full-scale Input Signal Level (0dB) <br> -note this changes with AVDD | $\mathrm{V}_{\text {INFs }}$ |  |  | 1.0 <br> 0 | Vrms <br> dBV |  |
| Input Resistance | $\mathrm{R}_{\text {AUXIN }}$ | AUXMODE=0 |  | 20 | $\mathrm{k} \Omega$ |  |
| Input Capacitance | $\mathrm{C}_{\text {AUXIN }}$ |  |  | 10 | pF |  |

Test Conditions
DCVDD $=1.8 \mathrm{~V}, \mathrm{AVDD}=\mathrm{DBVDD}=3.3 \mathrm{~V}, \mathrm{SPKVDD}=3.3 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, 1 \mathrm{kHz}$ signal, fs $=48 \mathrm{kHz}$,
24-bit audio data unless otherwise stated.

| PARAMETER | SYMBOL | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Microphone Bias |  |  |  |  |  |  |
| Bias Voltage (MBVSEL=0) | $\mathrm{V}_{\text {MICBIAS }}$ |  |  | $0.9 \times$ AVDD |  | V |
| Bias Voltage (MBVSEL=1) | $\mathrm{V}_{\text {MICBIAS }}$ |  |  | $0.75 \times$ AVDD |  | V |
| Bias Current Source | $\mathrm{I}_{\text {micbias }}$ |  |  |  | 3 | mA |
| Output Noise Voltage | Vn | 1 K to 20kHz |  | 15 |  | $\mathrm{nV} / \sqrt{ } \mathrm{Hz}$ |
| Digital Input / Output |  |  |  |  |  |  |
| Input HIGH Level | $\mathrm{V}_{\mathrm{IH}}$ |  | $0.7 \times$ DVDD |  |  | V |
| Input LOW Level | $\mathrm{V}_{\mathrm{IL}}$ |  |  |  | $0.3 \times$ DVDD | V |
| Output HIGH Level | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{los}=1 \mathrm{~mA}$ | $0.9 \times$ DVDD |  |  | V |
| Output LOW Level | $\mathrm{V}_{\text {OL }}$ | $\mathrm{l}_{\mathrm{OH}}-1 \mathrm{~mA}$ |  |  | $0.1 \times$ DVDD | V |

## TERMINOLOGY

1. MICN input only in single ended microphone configuration. Maximum input signal to MICP without distortion is -3dBV.
2. Hold Time is the length of time between a signal detected being too quiet and beginning to ramp up the gain. It does not apply to ramping down the gain when the signal is too loud, which happens without a delay.
3. Ramp-up and Ramp-Down times are defined as the time it takes for the PGA to change its gain by 6 dB .
4. All hold, ramp-up and ramp-down times scale proportionally with MCLK
5. Signal-to-noise ratio $(\mathrm{dB})-$ SNR is a measure of the difference in level between the full scale output and the output with no signal applied. (No Auto-zero or Automute function is employed in achieving these results).
6. THD $+\mathrm{N}(\mathrm{dB})-\mathrm{THD}+\mathrm{N}$ is a ratio, of the rms values, of (Noise + Distortion)/Signal.

## SIGNAL TIMING REQUIREMENTS

## SYSTEM CLOCK TIMING



Figure 1 System Clock Timing Requirements

## Test Conditions

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

| PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| System Clock Timing Information |  |  |  |  |  |  |
| MCLK cycle time | $\mathrm{T}_{\text {MClky }}$ | MCLK as direct SYSCLK source (CLKSEL=0) | 81.38 |  |  | ns |
|  |  | MCLK as input to PLL (see note) (CLKSEL=1) | 20 |  |  | ns |
| MCLK duty cycle | $\mathrm{T}_{\text {Mclkds }}$ |  | 60:40 |  | 40:60 |  |

Note: PLL pre-scaling and PLL N and K values should be set appropriately so that SYSCLK is no greater than 12.288 MHz .

## AUDIO INTERFACE TIMING - MASTER MODE



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

## Test Conditions

DCVDD $=1.8 \mathrm{~V}, \mathrm{DBVDD}=\mathrm{AVDD}=\mathrm{SPKVDD}=3.3 \mathrm{~V}, \mathrm{DGND}=\mathrm{AGND}=\mathrm{SPKGND}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Master $\mathrm{Mode}, \mathrm{fs}=48 \mathrm{kHz}$, MCLK=256fs, 24-bit data, unless otherwise stated.

| PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Audio Data Input Timing Information |  |  |  |  |  |
| FRAME propagation delay from BCLK falling edge | $\mathrm{t}_{\mathrm{DL}}$ |  |  | 10 | ns |
| ADCDAT propagation delay from BCLK falling edge | $\mathrm{t}_{\mathrm{DDA}}$ |  |  | 10 | ns |

## AUDIO INTERFACE TIMING - SLAVE MODE



Figure 3 Digital Audio Data Timing - Slave Mode

## Test Conditions

$D C V D D=1.8 \mathrm{~V}$, $\operatorname{DBVDD}=A V D D=S P K V D D=3.3 V, D G N D=A G N D=S P K G N D=0 V, T_{A}=+25^{\circ} \mathrm{C}$, Slave $\mathrm{Mode}, \mathrm{fs}=48 \mathrm{kHz}, \mathrm{MCLK}=256 \mathrm{fs}$, 24-bit data, unless otherwise stated.

| PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Audio Data Input Timing Information | $\mathrm{t}_{\mathrm{BCY}}$ | 50 |  |  | ns |
| BCLK cycle time | $\mathrm{t}_{\mathrm{BCH}}$ | 20 |  |  | ns |
| BCLK pulse width high | $\mathrm{t}_{\mathrm{BCL}}$ | 20 |  |  | ns |
| BCLK pulse width low | $\mathrm{t}_{\text {LRSU }}$ | 10 |  |  | ns |
| FRAME set-up time to BCLK rising edge | $\mathrm{t}_{\text {LRH }}$ | 10 |  |  | ns |
| FRAME hold time from BCLK rising edge | $\mathrm{t}_{\mathrm{DD}}$ |  |  | 20 | ns |
| ADCDAT propagation delay from BCLK falling edge |  |  |  |  |  |

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

CONTROL INTERFACE TIMING - 3-WIRE MODE


Figure 4 Control Interface Timing - 3-Wire Serial Control Mode

## Test Conditions

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

| PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Program Register Input Information | $\mathrm{t}_{\text {SCs }}$ | 80 |  |  | ns |
| SCLK rising edge to CSB rising edge | $\mathrm{t}_{\text {SCY }}$ | 200 |  |  | ns |
| SCLK pulse cycle time | $\mathrm{t}_{\text {SCL }}$ | 80 |  |  | ns |
| SCLK pulse width low | $\mathrm{t}_{\text {SCH }}$ | 80 |  |  | ns |
| SCLK pulse width high | $\mathrm{t}_{\mathrm{DSU}}$ | 40 |  |  | ns |
| SDIN to SCLK set-up time | $\mathrm{t}_{\mathrm{DHO}}$ | 40 |  |  | ns |
| SCLK to SDIN hold time | $\mathrm{t}_{\mathrm{CSL}}$ | 40 |  |  | ns |
| CSB pulse width low | $\mathrm{t}_{\mathrm{CSH}}$ | 40 |  | ns |  |
| CSB pulse width high | $\mathrm{t}_{\mathrm{CSS}}$ | 40 |  |  | ns |
| CSB rising to SCLK rising | $\mathrm{t}_{\text {ps }}$ | 0 |  | 5 | ns |
| Pulse width of spikes that will be suppressed |  |  |  |  |  |

CONTROL INTERFACE TIMING - 2-WIRE MODE


Figure 5 Control Interface Timing - 2-Wire Serial Control Mode

## Test Conditions

$D C V D D=1.8 \mathrm{~V}, \mathrm{DBVDD}=\mathrm{AVDD}=\mathrm{SPKVDD}=3.3 \mathrm{~V}, \mathrm{DGND}=\mathrm{AGND}=\mathrm{SPKGND}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Slave Mode, fs $=48 \mathrm{kHz}$, MCLK = 256fs, 24-bit data, unless otherwise stated

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

## DEVICE DESCRIPTION

## INTRODUCTION

The WM8950 is a low power audio ADC, with flexible line and microphone input. Applications for this device include games console accessories, digital still cameras, voice recorders and other general purpose audio applications.

The chip offers great flexibility in use, and so can support many different modes of operation as follows:

## MICROPHONE INPUTS

Microphone inputs are provided, allowing for either a differential microphone input or a single ended microphone to be connected. These inputs have a user programmable gain range of -12dB to +35.25 dB using internal resistors. After the input PGA stage comes a boost stage which can add a further 20 dB of gain. A microphone bias is output from the chip which can be used to bias the microphones. The signal routing can be configured to allow manual adjustment of mic levels, or to allow the ALC loop to control the level of mic signal that is transmitted.

Total gain through the microphone paths of up to +55.25 dB can be selected

## PGA AND ALC OPERATION

A programmable gain amplifier is provided in the input path to the ADC. This may be used manually or in conjunction with a mixed analogue/digital automatic level control (ALC) which keeps the recording volume constant.


#### Abstract

AUX INPUT The device includes a mono input, AUX, that can be used as an input for warning tones (beep) etc. This path can also be summed into the input in a flexible fashion, either to the input PGA as a second microphone input or as a line input. The configuration of this circuit, with integrated on-chip resistors allows several analogue signals to be summed into the single AUX input if required.


## ADC

The mono ADC uses a multi-bit high-order oversampling architecture to deliver optimum performance with low power consumption. Various sample rates are supported, from the $8 \mathrm{ks} / \mathrm{s}$ rate typically used in voice dictation, up to the $48 \mathrm{ks} / \mathrm{s}$ rate used in high quality audio applications.

## DIGITAL FILTERING

Advanced Sigma Delta Converters are used along with digital decimation and interpolation filters to give high quality audio at sample rates from $8 \mathrm{ks} / \mathrm{s}$ to $48 \mathrm{ks} / \mathrm{s}$.

Application specific digital filters are also available which help to reduce the effect of specific noise sources such as 'wind noise'. The filters include a programmable ADC high-pass filter, an IIR filter with fully programmable coefficients, and a 5-band equaliser that can be applied to the record path in order to improve the overall audio sound from the device.

## AUDIO INTERFACES

The WM8950 has a standard audio interface, to support the transmission of audio data from the chip. This interface is a 4 wire standard audio interface which supports a number of audio data formats including $I^{2}$ S, DSP Mode, MSB-First, left justified and MSB-First, right justified, and can operate in master or slave modes.

## CONTROL INTERFACES

To allow full software control over all its features, the WM8950 offers a choice of 2 or 3 wire MPU control interface. It is fully compatible and an ideal partner for a wide range of industry standard microprocessors, controllers and DSPs. The selection between 2 -wire mode and 3 -wire mode is determined by the state of the MODE pin. If MODE is high then 3-wire control mode is selected, if MODE is low then 2 -wire control mode is selected.

In 2 wire mode, only slave operation is supported, and the address of the device is fixed as 0011010.

## CLOCKING SCHEMES

WM8950 offers the normal audio clocking scheme operation, where 256fs MCLK is provided to the ADC.

WM8950

However, a PLL is also included which may be used to generate the internal master clock frequency in the event that this is not available from the system controller. The PLL uses an input reference (typically, the 12 MHz USB clock) to generate high quality audio clocks. If the PLL is not required for generation of these clocks, it can be reconfigured to generate alternative clocks which may then be output on the CSB/GPIO pin and used elsewhere in the system.

## POWER CONTROL

The design of the WM8950 has given much attention to power consumption without compromising performance. It operates at low supply voltages, and includes the facility to power off any unused parts of the circuitry under software control, includes standby and power off modes

## INPUT SIGNAL PATH

The WM8950 has 3 flexible analogue inputs: two microphone inputs, and an auxiliary input. These inputs can be used in a variety of ways. The input signal path before the ADC has a flexible PGA block which then feeds into a gain boost/mixer stage.

## MICROPHONE INPUTS

The WM8950 can accommodate a variety of microphone configurations including single ended and differential inputs. The inputs through the MICN, MICP and optionally AUX pins are amplified through the input PGA as shown in Figure 6.

A pseudo differential input is the preferential configuration where the positive terminal of the input PGA is connected to the MICP input pin by setting MICP2INPPGA=1. The microphone ground should then be connected to MICN (when MICN2INPPGA=1) or optionally to AUX (when AUX2INPPGA=1) input pins.

Alternatively a single ended microphone can be connected to the MICN input with MICN2INPPGA set to 1. The non-inverting terminal of the input PGA should be connected internally to VMID by setting MICP2INPPGA to 0 .


Figure 6 Microphone Input PGA Circuit (switch positions shown are for differential mic input)

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R44 <br> Input Control | 0 | MICP2INPPGA | 1 | Connect input PGA amplifier positive <br> terminal to MICP or VMID. <br> $0=$ input PGA amplifier positive terminal <br> connected to VMID <br> $1=$ input PGA amplifier positive terminal <br> connected to MICP through variable resistor <br> string |
|  | 1 | MICN2INPPGA | 1 | Connect MICN to input PGA negative <br> terminal. <br> 0=MICN not connected to input PGA <br> $1=$ MICN connected to input PGA amplifier <br> negative terminal. |
|  |  |  |  | AUX2INPPGA |
|  | 0 | Select AUX amplifier output as input PGA <br> signal source. <br> 0=AUX not connected to input PGA <br> $1=A U X$ connected to input PGA amplifier <br> negative terminal. |  |  |

The input PGA is enabled by the IPPGAEN register bit.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R2 | 2 | INPPGAEN | 0 | Input microphone PGA enable <br> $0=$ disabled <br> $1=$ enabled |
| Power <br> Management 2 |  |  |  |  |

## INPUT PGA VOLUME CONTROL

The input microphone PGA has a gain range from -12 dB to +35.25 dB in 0.75 dB steps. The gain from the MICN input to the PGA output and from the AUX amplifier to the PGA output are always common and controlled by the register bits INPPGAVOL[5:0]. These register bits also affect the MICP pin when MICP2INPPGA=1.

When the Automatic Level Control (ALC) is enabled the input PGA gain is then controlled automatically and the INPPGAVOL bits should not be used.

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R45 <br> Input PGA volume control | 5:0 | INPPGAVOL | 010000 | Input PGA volume $\begin{aligned} & 000000=-12 \mathrm{~dB} \\ & 000001=-11.25 \mathrm{~dB} \end{aligned}$ $010000=0 \mathrm{~dB}$ $111111=35.25 \mathrm{~dB}$ |
|  | 6 | INPPGAMUTE | 0 | Mute control for input PGA: <br> $0=$ Input PGA not muted, normal operation $1=$ Input PGA muted (and disconnected from the following input BOOST stage). |
|  | 7 | INPPGAZC | 0 | Input PGA zero cross enable: <br> 0=Update gain when gain register changes <br> 1=Update gain on $1^{\text {st }}$ zero cross after gain register write. |

WM8950

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R32 <br> ALC control 1 | 8 | ALCSEL | 0 | ALC function select: <br> 0=ALC off (PGA gain set by INPPGAVOL <br> register bits) <br> $1=A L C$ on (ALC controls PGA gain) |

Table 1 Input PGA Volume Control

## AUXILIARY INPUT

An auxiliary input circuit (Figure 7) is provided which consists of an amplifier which can be configured either as an inverting buffer for a single input signal or as a mixer/summer for multiple inputs with the use of external resistors. The circuit is enabled by the register bit AUXEN.


Figure 7 Auxiliary Input Circuit

The AUXMODE register bit controls the auxiliary input mode of operation:
In buffer mode (AUXMODE=0) the switch labelled AUXSW in Figure 7 is open and the signal at the AUX pin will be buffered and inverted through the aux circuit using only the internal components.

In mixer mode (AUXMODE=1) the on-chip input resistor is bypassed, this allows the user to sum in multiple inputs with the use of external resistors. When used in this mode there will be gain variations through this path from part to part due to the variation of the internal $20 \mathrm{k} \Omega$ resistors relative to the higher tolerance external resistors.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R1 <br> Power <br> management 1 <br> m |  | AUXEN | 0 | Auxiliary input buffer enable <br> $0=$ OFF <br> $1=$ ON |
| R44 <br> Input control | 3 | AUXMODE | 0 | $0=$ inverting buffer <br> $1=$ mixer (on-chip input resistor bypassed) |

Table 2 Auxiliary Input Buffer Control

WM8950

INPUT BOOST
The input BOOST circuit has 3 selectable inputs: the input microphone PGA output, the AUX amplifier output and the MICP input pin (when not using a differential microphone configuration). These three inputs can be mixed together and have individual gain boost/adjust as shown in Figure 8.


Figure 8 Input Boost Stage

The input PGA path can have a +20 dB boost (PGABOOST=1) a 0 dB pass through ( $\mathrm{PGABOOST}=0$ ) or be completely isolated from the input boost circuit (INPPGAMUTE=1).

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R45 <br> Input PGA gain <br> control | 6 | INPPGAMUTE | 0 | Mute control for input PGA: <br> 0=Input PGA not muted, normal operation <br> = Input PGA muted (and disconnected from <br> the following input BOOST stage). |
| R47 <br> Input BOOST <br> control | 8 | PGABOOST | 1 | 0 = PGA output has +OdB gain through input <br> BOOST stage. <br> $1=$ PGA output has +20dB gain through <br> input BOOST stage. |

Table 3 Input BOOST Stage Control

The Auxiliary amplifier path to the BOOST stage is controlled by the AUX2BOOSTVOL[2:0] register bits. When AUX2BOOSTVOL=000 this path is completely disconnected from the BOOST stage. Settings 001 through to 111 control the gain in 3 dB steps from -12 dB to +6 dB .

The MICP path to the BOOST stage is controlled by the MICP2BOOSTVOL[2:0] register bits. When MICP2BOOSTVOL=000 this input pin is completely disconnected from the BOOST stage. Settings 001 through to 111 control the gain in 3 dB steps from -12 dB to +6 dB .

WM8950

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R47 <br> Input BOOST control | 2:0 | AUX2BOOSTVOL | 000 | Controls the auxiliary amplifier to the input boost stage: <br> 000=Path disabled (disconnected) <br> $001=-12 \mathrm{~dB}$ gain through boost stage <br> $010=-9 \mathrm{~dB}$ gain through boost stage <br> ... <br> $111=+6 \mathrm{~dB}$ gain through boost stage |
|  | 6:4 | MICP2BOOSTVOL | 000 | Controls the MICP pin to the input boost stage (NB, when using this path set MICPZIUNPPGA=0): <br> 000=Path disabled (disconnected) <br> $001=-12 \mathrm{~dB}$ gain through boost stage <br> $010=-9 \mathrm{~dB}$ gain through boost stage $\ldots$ <br> $111=+6 \mathrm{~dB}$ gain through boost stage |

Table 4 Input BOOST Stage Control

The BOOST stage is enabled under control of the BOOSTEN register bit.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R2 <br> Power <br> management 2 | 4 | BOOSTEN | 0 | Input BOOST enable <br> $0=$ Boost stage OFF <br> $1=$ Boost stage ON |

Table 5 Input BOOST Enable Control

## MICROPHONE BIASING CIRCUIT

The MICBIAS output provides a low noise reference voltage suitable for biasing electret type microphones and the associated external resistor biasing network. Refer to the Applications Information section for recommended external components. The MICBIAS voltage can be altered via the MBVSEL register bit. If MBVSEL $=0$, the MICBIAS voltage is $0.9 \times$ AVDD. If $\mathrm{MBVSEL}=1$, the MICBIAS voltage is $0.75 \times$ AVDD. The output can be enabled or disabled using MICBEN.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R1 <br> Power <br> management 1$; 4$ | MICBEN | 0 | Microphone Bias Enable <br> $0=$ OFF (high impedance output) <br> $1=$ ON |  |

Table 6 Microphone Bias Enable

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R44 | 8 | MBVSEL | 0 | Microphone Bias Voltage Control <br> Input Control |
|  |  |  |  | $=0.9 \times$ AVDD <br> $1=0.75 \times$ AVDD |

Table 7 Microphone Bias Voltage Control

The internal MICBIAS circuitry is shown in Figure 9. Note that the maximum source current capability for MICBIAS is 3 mA . The external biasing resistors therefore must be large enough to limit the MICBIAS current to 3 mA .


Figure 9 Microphone Bias Schematic

## ANALOGUE TO DIGITAL CONVERTER (ADC)

The WM8950 uses a multi-bit, oversampled sigma-delta ADC channel. 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. With a 3.3 V supply voltage, the full scale level is $1.0 \mathrm{~V}_{\text {rms }}$. Any voltage greater than -1 dBfs may overload the ADC and cause distortion.

## ADC DIGITAL FILTERS

The ADC filters perform true 24 bit signal processing to convert the raw multi-bit oversampled data from the ADC to the correct sampling frequency to be output on the digital audio interface. The digital filter path is illustrated in Figure 10.


Figure 10 ADC Digital Filter Path

The ADC is enabled by the ADCEN register bit.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R2 <br> Power <br> management 2 | 0 | ADCEN | 0 | $0=$ ADC disabled <br> $1=$ ADC enabled |

Table 8 ADC Enable

WM8950

The polarity of the output signal can also be changed under software control using the ADCPOL register bit. The oversampling rate of the ADC can be adjusted using the ADCOSR register bit. With $\operatorname{ADCOSR}=0$ the oversample rate is 64 x which gives lowest power operation and when ADCOSR $=1$ the oversample rate is 128 x which gives best performance.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R14 <br> ADC Control | 3 | ADCOSR | 0 | ADC oversample rate select: <br> $0=64 x$ (lower power) <br> $1=128 x$ (best performance) |
|  | 0 | ADCPOL | 0 | $0=$ normal <br> $1=$ inverted |

Table 9 ADC Oversample Rate Select

## SELECTABLE HIGH-PASS FILTER

A selectable high-pass filter is provided. To disable this filter set HPFEN=0. The filter has two modes controlled by HPFAPP. In Audio Mode (HPFAPP=0) the filter is first order, with a cut-off frequency of 3.7 Hz . In Application Mode (HPFAPP=1) the filter is second order, with a cut-off frequency selectable via the HPFCUT register. The cut-off frequencies when HPFAPP=1 are shown in Table 11.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R14 <br> ADC Control | 8 | HPFEN | 1 | High-Pass Filter Enable <br> $0=$ disabled <br> 1=enabled |
|  | 7 | HPFAPP | 0 | Select audio mode or application mode <br> $0=$ Audio mode $\left(1^{\text {st }}\right.$ order, fc $\left.=\sim 3.7 \mathrm{~Hz}\right)$ <br> 1=Application mode $\left(2^{\text {nd }}\right.$ order, fc $=$ <br> HPFCUT $)$ |
|  | $6: 4$ | HPFCUT | 000 | Application mode cut-off frequency <br> See Table 11 for details. |

Table 10 ADC Filter Select

| HPFCUT <br> [2:0] | SAMPLE FREQUENCY (kHz) |  |  |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{8}$ | $\mathbf{1 1 . 0 2 5}$ | $\mathbf{1 2}$ | $\mathbf{1 6}$ | $\mathbf{2 2 . 0 5}$ | $\mathbf{2 4}$ | $\mathbf{3 2}$ | $\mathbf{4 4 . 1}$ | $\mathbf{4 8}$ |  |
|  | SR=101/100 |  |  | SR=011/010 |  |  | SR=001/000 |  |  |  |
| $\mathbf{0 0 0}$ | 82 | 113 | 122 | 82 | 113 | 122 | 82 | 113 | 122 |  |
| $\mathbf{0 0 1}$ | 102 | 141 | 153 | 102 | 141 | 153 | 102 | 141 | 153 |  |
| $\mathbf{0 1 0}$ | 131 | 180 | 196 | 131 | 180 | 196 | 131 | 180 | 196 |  |
| $\mathbf{0 1 1}$ | 163 | 225 | 245 | 163 | 225 | 245 | 163 | 225 | 245 |  |
| $\mathbf{1 0 0}$ | 204 | 281 | 306 | 204 | 281 | 306 | 204 | 281 | 306 |  |
| $\mathbf{1 0 1}$ | 261 | 360 | 392 | 261 | 360 | 392 | 261 | 360 | 392 |  |
| $\mathbf{1 1 0}$ | 327 | 450 | 490 | 327 | 450 | 490 | 327 | 450 | 490 |  |
| $\mathbf{1 1 1}$ | 408 | 563 | 612 | 408 | 563 | 612 | 408 | 563 | 612 |  |

Table 11 High-Pass Filter Cut-off Frequencies (HPFAPP=1) Values in Hz

Note that the High-Pass filter values (when HPFAPP=1) work on the basis that the SR register bits are set correctly for the actual sample rate as shown in Table 11.

## PROGRAMMABLE IIR FILTER

An IIR filter with fully programmable coefficients is provided, typically used as a notch filter for removing narrow band noise at a given frequency. This notch filter has a variable centre frequency and bandwidth, programmable via two coefficients, a 0 and a1. These coefficients should be converted to 2's complement numbers to determine the register values. a0 and a1 are represented by the register bits NFA0[13:0] and NFA1[13:0]. Because these coefficient values require four register writes to setup there is an NFU (Notch Filter Update) flag which should be set only when all four registers are setup.

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R27 <br> Notch Filter 1 | 6:0 | NFA0[13:7] | 0 | Notch filter a0 coefficient, bits [13:7] |
|  | 7 | NFEN | 0 | Notch filter enable: <br> $0=$ Disabled <br> 1=Enabled |
|  | 8 | NFU | 0 | Notch filter update. The notch filter values used internally only update when one of the NFU bits is set high. |
| R28 <br> Notch Filter 2 | 6:0 | NFAO[6:0] | 0 | Notch filter a0 coefficient, bits [6:0] |
|  | 8 | NFU] | 0 | Notch filter update. The notch filter values used internally only update when one of the NFU bits is set high. |
| R29 <br> Notch Filter 3 | 6:0 | NFA1[13:7] | 0 | Notch filter a1 coefficient, bits [13:7] |
|  | 8 | NFU | 0 | Notch filter update. The notch filter values used internally only update when one of the NFU bits is set high. |
| R30 <br> Notch Filter 4 | 6:0 | NFA1[6:0] | 0 | Notch filter a1 coefficient, bits [6:0] |
|  | 8 | NFU | 0 | Notch filter update. The notch filter values used internally only update when one of the NFU bits is set high. |

Table 12 Notch Filter Function

The coefficients are calculated as follows:

$$
\begin{aligned}
& a_{0}=\frac{1-\tan \left(w_{b} / 2\right)}{1+\tan \left(w_{b} / 2\right)} \\
& a_{1}=-\left(1+a_{0}\right) \cos \left(w_{0}\right)
\end{aligned}
$$

Where:

$$
\begin{aligned}
& w_{0}=2 \pi f_{c} / f_{s} \\
& w_{b}=2 \pi f_{b} / f_{s}
\end{aligned}
$$

$f_{c}=$ centre frequency in $\mathrm{Hz}, f_{b}=-3 \mathrm{~dB}$ bandwidth in Hz , $f_{s}=$ sample frequency in Hz

The coefficients are calculated as follows:

$$
\begin{aligned}
& \text { NFA0 }=-a 0 \times 2^{13} \\
& \text { NFA1 }=-a 1 \times 2^{12}
\end{aligned}
$$

These values are then converted to 2 's complement notation to determine the register values.

## NOTCH FILTER WORKED EXAMPLE

The following example illustrates how to calculate the a0 and a1 coefficients for a desired centre frequency and -3dB bandwidth.

```
\(\mathrm{fc}=1000 \mathrm{~Hz}\)
\(\mathrm{fb}=100 \mathrm{~Hz}\)
\(\mathrm{fs}=48000 \mathrm{~Hz}\)
\(w_{0}=2 \pi f_{c} / f_{s}=2 \pi \times(1000 / 48000)=0.1308996939\) rads
\(w_{b}=2 \pi f_{b} / f_{s}=2 \pi \times(100 / 48000)=0.01308996939\) rads
\(a_{0}=\frac{1-\tan \left(w_{b} / 2\right)}{1+\tan \left(w_{b} / 2\right)}=\frac{1-\tan (0.01308996939 / 2)}{1+\tan (0.01308996939 / 2)}=0.9869949627\)
\(a_{1}=-\left(1+a_{0}\right) \cos \left(w_{0}\right)=-(1+0.9869949627) \cos (0.1308996939)=-1.969995945\)
NFn_A0 \(=-\mathrm{a} 0 \times 213=-8085\) (rounded to nearest whole number)
NFn_A1 = -a1 x 212 = 8069 (rounded to nearest whole number)
```

These values are then converted to 2's complement:
$N F A 0=14 ’ h 206 B=14 ’ b 10000001101011$
NFA1 $=14$ 'h1F85 $=14$ 'b011111100000101

## DIGITAL ADC VOLUME CONTROL

The output of the ADCs can be digitally attenuated over a range from -127 dB to 0 dB in 0.5 dB steps The gain for a given eight-bit code $X$ is given by:

Gain $=0.5 x(x-255) d B$ for $1 \leq x \leq 255$, MUTE for $x=0$

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R15 | $7: 0$ | ADCVOL | 11111111 | ADC Digital Volume Control |
| ADC Digital |  | $[7: 0]$ | $(0 \mathrm{~dB})$ | $00000000=$ Digital Mute |
| Volume |  |  |  | $00000001=-127 \mathrm{~dB}$ |
|  |  |  |  | $00000010=-126.5 \mathrm{~dB}$ |
|  |  |  |  | $\ldots 0.5 \mathrm{~dB}$ steps up to |
|  |  |  |  |  |
|  |  |  |  |  |

Table 13 ADC Volume

## INPUT AUTOMATIC LEVEL CONTROL (ALC)

The WM8950 has an automatic PGA gain control circuit, which can function as an input peak limiter or as an automatic level control (ALC).

The Automatic Level Control (ALC) provides continuous adjustment of the input PGA in response to the amplitude of the input signal. A digital peak detector monitors the input signal amplitude and compares it to a register defined threshold level (ALCLVL).

If the signal is below the threshold, the ALC will increase the gain of the PGA at a rate set by ALCDCY. If the signal is above the threshold, the ALC will reduce the gain of the PGA at a rate set by ALCATK.

The ALC has two modes selected by the ALCMODE register: normal mode and peak limiter mode. The ALC/limiter function is enabled by setting the register bit R32[8] ALCSEL.

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R32 (20h) <br> ALC Control 1 | 2:0 | ALCMIN <br> [2:0] | 000 (-12dB) | Set minimum gain of PGA $\begin{aligned} & 000=-12 \mathrm{~dB} \\ & 001=-6 \mathrm{~dB} \\ & 010=0 \mathrm{~dB} \\ & 011=+6 \mathrm{~dB} \\ & 100=+12 \mathrm{~dB} \\ & 101=+18 \mathrm{~dB} \\ & 110=+24 \mathrm{~dB} \\ & 111=+30 \mathrm{~dB} \end{aligned}$ |
|  | 5:3 | ALCMAX [2:0] | $\begin{aligned} & \hline 111 \\ & (+35.25 \mathrm{~dB}) \end{aligned}$ | Set Maximum Gain of PGA $\begin{aligned} 111 & =+35.25 \mathrm{~dB} \\ 110 & =+29.25 \mathrm{~dB} \\ 101 & =+23.25 \mathrm{~dB} \\ 100 & =+17.25 \mathrm{~dB} \\ 011 & =+11.25 \mathrm{~dB} \\ 010 & =+5.25 \mathrm{~dB} \\ 001 & =-0.75 \mathrm{~dB} \\ 000 & =-6.75 \mathrm{~dB} \end{aligned}$ |
|  | 8 | ALCSEL | 0 | ALC function select <br> $0=A L C$ disabled <br> 1 = ALC enabled |
| R33 (21h) <br> ALC Control 2 | 3:0 | ALCLVL <br> [3:0] | $\begin{aligned} & 1011 \\ & (-12 \mathrm{~dB}) \end{aligned}$ | ALC target - sets signal level at ADC input $1111=-6 \mathrm{dBFS}$ <br> $1110=-7.5 \mathrm{dBFS}$ <br> $1101=-9 \mathrm{dBFS}$ <br> $1100=-10.5 \mathrm{dBFS}$ <br> $1011=-12 \mathrm{dBFS}$ <br> $1010=-13.5 \mathrm{dBFS}$ <br> $1001=-15 \mathrm{dBFS}$ <br> $1000=-16.5 \mathrm{dBFS}$ <br> $0111=-18 \mathrm{dBFS}$ <br> $0110=-19.5 \mathrm{dBFS}$ <br> $0101=-21 \mathrm{dBFS}$ <br> $0100=-22.5 \mathrm{dBFS}$ <br> $0011=-24 \mathrm{dBFS}$ <br> $0010=-25.5 \mathrm{dBFS}$ <br> $0001=-27 \mathrm{dBFS}$ <br> $0000=-28.5 \mathrm{dBFS}$ |

WM8950

| REGISTER | BIT | LABEL | DEFAULT | DESCRIPTION |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8 | ALCZC | $0 \text { (zero }$ cross off) | ALC uses zero cross detection circuit. <br> 0 = Disabled (recommended) <br> 1 = Enabled |  |  |  |
|  | 7:4 | $\begin{aligned} & \text { ALCHLD } \\ & \text { [3:0] } \end{aligned}$ | $\begin{aligned} & 0000 \\ & (0 \mathrm{~ms}) \end{aligned}$ | ALC hold time before gain is increased.$\begin{aligned} & 0000=0 \mathrm{~ms} \\ & 0001=2.67 \mathrm{~ms} \\ & 0010=5.33 \mathrm{~ms} \\ & 0011=10.66 \mathrm{~ms} \\ & 0100=21.32 \mathrm{~ms} \\ & 0101=42.64 \mathrm{~ms} \\ & 0110=85.28 \mathrm{~ms} \\ & 0111=0.17 \mathrm{~s} \\ & 1000=0.34 \mathrm{~s} \\ & 1001=0.68 \mathrm{~s} \\ & 1010 \text { or higher }=1.36 \mathrm{~s} \end{aligned}$ |  |  |  |
| R34 (22h) <br> ALC Control 3 | 8 | ALCMODE | 0 | Determines the ALC mode of operation: <br> $0=$ ALC mode (Normal Operation) <br> 1 = Limiter mode. |  |  |  |
|  | 7:4 | $\begin{aligned} & \text { ALCDCY } \\ & \text { [3:0] } \end{aligned}$ | $\begin{aligned} & \hline 0011 \\ & (26 \mathrm{~ms} / 6 \mathrm{~dB}) \end{aligned}$ | Decay (gain ramp-up) time (ALCMODE ==0) |  |  |  |
|  |  |  |  |  | Per step | Per 6dB | $90 \%$ of range |
|  |  |  |  | 0000 | 410us | 3.38 ms | 23.6 ms |
|  |  |  |  | 0001 | 820us | 6.56 ms | 47.2 ms |
|  |  |  |  | 0010 | 1.64 ms | 13.1 ms | 94.5 ms |
|  |  |  |  | $\ldots$ (time doubles with every step) |  |  |  |
|  |  |  |  | 1010 or higher | 420ms | 3.36s | 24.2s |
|  |  |  | $\begin{aligned} & 0011 \\ & (5.8 \mathrm{~ms} / 6 \mathrm{~dB}) \end{aligned}$ | Decay (gain ramp-up) time (ALCMODE ==1) |  |  |  |
|  |  |  |  |  | Per step | Per 6dB | $90 \%$ of range |
|  |  |  |  | 0000 | 90.8us | 726us | 5.23 ms |
|  |  |  |  | 0001 | 182us | 1.45 ms | 10.5 ms |
|  |  |  |  | 0010 | 363us | 2.91 ms | 20.9 ms |
|  |  |  |  | $\ldots$..tim | doubles | th every |  |
|  |  |  |  | 1010 | 93ms | 744ms | 5.36s |
|  | 3:0 | ALCATK[3:0] | $\begin{aligned} & 0010 \\ & (3.3 \mathrm{~ms} / 6 \mathrm{~dB}) \end{aligned}$ | ALC attack (gain ramp-down) time (ALCMODE ==0) |  |  |  |
|  |  |  |  |  | Per step | Per 6dB | 90\% of range |
|  |  |  |  | 0000 | 104us | 832us | 6 ms |
|  |  |  |  | 0001 | 208us | 1.66 ms | 12 ms |
|  |  |  |  | 0010 | 416us | 3.33 ms | 24 ms |
|  |  |  |  | ... (time doubles with every step) |  |  |  |
|  |  |  |  | $1010$ <br> or higher | 106ms | 852ms | 6.13s |

WM8950


Table 14 ALC Control Registers

When the ALC is disabled, the input PGA remains at the last controlled value of the ALC. An input gain update must be made by writing to the INPPGAVOLL/R register bits.

## NORMAL MODE

In normal mode, the ALC will attempt to maintain a constant signal level by increasing or decreasing the gain of the PGA. The following diagram shows an example of this.


Figure 11 ALC Normal Mode Operation

## LIMITER MODE

In limiter mode, the ALC will reduce peaks that go above the threshold level, but will not increase the PGA gain beyond the starting level. The starting level is the PGA gain setting when the ALC is enabled in limiter mode. If the ALC is started in limiter mode, this is the gain setting of the PGA at start-up. If the ALC is switched into limiter mode after running in ALC mode, the starting gain will be the gain at switchover. The diagram below shows an example of limiter mode.


ALCSEL


Figure 12 ALC Limiter Mode Operation

## ATTACK AND DECAY TIMES

The attack and decay times set the update times for the PGA gain. The attack time is the time constant used when the gain is reducing. The decay time is the time constant used when the gain is increasing. In limiter mode, the time constants are faster than in ALC mode. The time constants are shown below in terms of a single gain step, a change of 6 dB and a change of $90 \%$ of the PGAs gain range.

Note that, these times will vary slightly depending on the sample rate used (specified by the SR register).

NORMAL MODE

| ALCMODE $=0$ (Normal Mode) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Attack Time (s) |  |  |  |
|  | $\mathrm{t}_{\text {ATK90\% }}$ |  |  |  |
| ALCATK | $\mathrm{t}_{\text {ATK }}$ | $\mathrm{t}_{\text {ATK } 6 \text { AB }}$ | $632 \mu \mathrm{~s}$ |  |
| 0000 | $104 \mu \mathrm{~s}$ | 1.66 ms | 12 ms |  |
| 0001 | $208 \mu \mathrm{~s}$ | 3.33 ms | 24 ms |  |
| 0010 | $416 \mu \mathrm{~s}$ | 6.66 ms | 48 ms |  |
| 0011 | $832 \mu \mathrm{~s}$ | 13.3 ms | 96 ms |  |
| 0100 | 1.66 ms | 26.6 ms | 192 ms |  |
| 0101 | 3.33 ms | 53.2 ms | 384 ms |  |
| 0110 | 6.66 ms | 106 ms | 767 ms |  |
| 0111 | 13.3 ms | 213.2 ms | 1.53 s |  |
| 1000 | 26.6 ms | 426 ms | 3.07 s |  |
| 1001 | 53.2 ms | 852 ms | 6.13 s |  |
| 1010 | 106 ms |  |  |  |


| ALCMODE $=0$ (Normal Mode) |  |  |  |
| :---: | :---: | :---: | :---: |
|  | Decay Time (s) |  |  |
| ALCDCY | $\mathrm{t}_{\mathrm{DCY}}$ | $\mathrm{t}_{\mathrm{DCY} 6 \mathrm{~dB}}$ | $\mathrm{t}_{\mathrm{DCY} 90 \%}$ |
| 0000 | 410us | 3.28 ms | 23.6 ms |
| 0001 | 820 ${ }^{\text {s }}$ | 6.56 ms | 47.2 ms |
| 0010 | 1.64 ms | 13.1 ms | 94.5 ms |
| 0011 | 3.28 ms | 26.2 ms | 189 ms |
| 0100 | 6.56 ms | 52.5 ms | 378 ms |
| 0101 | 13.1 ms | 105ms | 756 ms |
| 0110 | 26.2 ms | 210 ms | 1.51 s |
| 0111 | 52.5 ms | 420 ms | 3.02s |
| 1000 | 105 ms | 840 ms | 6.05 s |
| 1001 | 210 ms | 1.68 s | 12.1s |
| 1010 | 420 ms | 3.36s | 24.2s |

Table 15 ALC Normal Mode (Attack and Decay times)

LIMITER MODE

| ALCMODE $=1$ (Limiter Mode) |  |  | Attack Time (s) |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |
| ALCATK | $\mathrm{t}_{\text {ATKLIM }}$ | $\mathrm{t}_{\text {ATKLIM6 } 6 \mathrm{~B}}$ | $\mathrm{t}_{\text {ATKLIM } 90 \%}$ |  |
| 0000 | $22.7 \mu \mathrm{~s}$ | $182 \mu \mathrm{~s}$ | 1.1 ms |  |
| 0001 | $45.4 \mu \mathrm{~S}$ | $363 \mu \mathrm{~s}$ | 2.62 ms |  |
| 0010 | $90.8 \mu \mathrm{~S}$ | $726 \mu \mathrm{~s}$ | 5.23 ms |  |
| 0011 | $182 \mu \mathrm{~S}$ | 1.45 ms | 10.5 ms |  |
| 0100 | $363 \mu \mathrm{~S}$ | 2.91 ms | 20.9 ms |  |
| 0101 | $726 \mu \mathrm{~S}$ | 5.81 ms | 41.8 ms |  |
| 0110 | 1.45 ms | 11.6 ms | 83.7 ms |  |
| 0111 | 2.9 ms | 23.2 ms | 167 ms |  |
| 1000 | 5.81 ms | 46.5 ms | 335 ms |  |
| 1001 | 11.6 ms | 93 ms | 669 ms |  |
| 1010 | 23.2 ms | 186 ms | 1.34 s |  |

WM8950

| ALCMODE $=1$ (Limiter Mode) |  |  |  |
| :---: | :---: | :---: | :---: |
|  | Attack Time (s) |  |  |
| ALCDCY | $\mathrm{t}_{\text {DCYLIM }}$ | $\mathrm{t}_{\text {DCYLIM6dB }}$ | $\mathrm{t}_{\text {DCYLIM90\% }}$ |
| 0000 | $90.8 \mu \mathrm{~s}$ | $726 \mu \mathrm{~s}$ | 5.23 ms |
| 0001 | $182 \mu \mathrm{~S}$ | 1.45 ms | 10.5 ms |
| 0010 | $363 \mu \mathrm{~S}$ | 2.91 ms | 20.9 ms |
| 0011 | $726 \mu \mathrm{~S}$ | 5.81 ms | 41.8 ms |
| 0100 | 1.45 ms | 11.6 ms | 83.7 ms |
| 0101 | 2.91 ms | 23.2 ms | 167 ms |
| 0110 | 5.81 ms | 46.5 ms | 335 ms |
| 0111 | 11.6 ms | 93 ms | 669 ms |
| 1000 | 23.2 ms | 186 ms | 1.34 s |
| 1001 | 46.5 ms | 372 ms | 2.68 s |
| 1010 | 93 ms | 744 ms | 5.36 s |

Table 16 ALC Limiter Mode (Attack and Decay times)

## MINIMUM AND MAXIMUM GAIN

The ALCMIN and ALCMAX register bits set the minimum/maximum gain value that the PGA can be set to whilst under the control of the ALC. This has no effect on the PGA when ALC is not enabled.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R32 | $5: 3$ | ALCMAX | 111 | Set Maximum Gain of PGA |
| ALC Control 1 | $2: 0$ | ALCMIN | 000 | Set minimum gain of PGA |

Table 17 ALC Max/Min Gain

In normal mode, ALCMAX sets the maximum boost which can be applied to the signal. In limiter mode, ALCMAX will normally have no effect (assuming the starting gain value is less than the maximum gain specified by ALCMAX) because the maximum gain is set at the starting gain level.

ALCMIN sets the minimum gain value which can be applied to the signal.


Figure 13 ALC Min/Max Gain

| ALCMAX | Maximum Gain (dB) |
| :--- | :---: |
| 111 | 35.25 |
| 110 | 29.25 |
| 101 | 23.25 |
| 100 | 17.25 |
| 011 | 11.25 |
| 010 | 5.25 |
| 001 | -0.75 |
| 000 | -6.75 |

Table 18 ALC Max Gain Values

| ALCMIN | Minimum Gain (dB) |
| :--- | :---: |
| 000 | -12 |
| 001 | -6 |
| 010 | 0 |
| 011 | 6 |
| 100 | 12 |
| 101 | 18 |
| 110 | 24 |
| 111 | 30 |

Table 19 ALC Min Gain Values

Note that if the ALC gain setting strays outside the ALC operating range, either by starting the ALC outside of the range or changing the ALCMAX or ALCMIN settings during operation, the ALC will immediately adjust the gain to return to the ALC operating range. It is recommended that the ALC starting gain is set between the ALCMAX and ALCMIN limits.

## ALC HOLD TIME (NORMAL MODE ONLY)

In Normal mode, the ALC has an adjustable hold time which sets a time delay before the ALC begins its decay phase (gain increasing). The hold time is set by the ALCHLD register.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R33 <br> ALC Control 2 | $7: 4$ | ALCHLD | 0000 | ALC hold time before gain is increased. |

Table 20 ALC Hold Time

If the hold time is exceeded this indicates that the signal has reached a new average level and the ALC will increase the gain to adjust for that new average level. If the signal goes above the threshold during the hold period, the hold phase is abandoned and the ALC returns to normal operation.


Figure 14 ALCLVL


Figure 15 ALC Hold Time

| ALCHLD | $t_{\text {HOLD }}(\mathrm{s})$ |
| :---: | :---: |
| 0000 | 0 |
| 0001 | 2.67 ms |
| 0010 | 5.34 ms |
| 0011 | 10.7 ms |
| 0100 | 21.4 ms |
| 0101 | 42.7 ms |
| 0110 | 85.4 ms |
| 0111 | 171 ms |
| 1000 | 342 ms |
| 1001 | 684 ms |
| 1010 | 1.37 s |

Table 21 ALC Hold Time Values

## PEAK LIMITER

To prevent clipping when a large signal occurs just after a period of quiet, the ALC circuit includes a limiter function. If the ADC input signal exceeds $87.5 \%$ of full scale $(-1.16 \mathrm{~dB})$, the PGA gain is ramped down at the maximum attack rate (as when ALCATK $=0000$ ), until the signal level falls below $87.5 \%$ of full scale. This function is automatically enabled whenever the ALC is enabled.

Note: If ALCATK $=0000$, then the limiter makes no difference to the operation of the ALC. It is designed to prevent clipping when long attack times are used.

## NOISE GATE (NORMAL MODE ONLY)

When the signal is very quiet and consists mainly of noise, the ALC function may cause "noise pumping", i.e. loud hissing noise during silence periods. The WM8950 has a noise gate function that prevents noise pumping by comparing the signal level at the input pins against a noise gate threshold, NGTH. The noise gate cuts in when:
Signal level at ADC [dBFS] < NGTH [dBFS] + PGA gain [dB] + Mic Boost gain [dB]

This is equivalent to:
Signal level at input pin [dBFS] < NGTH [dBFS]

The PGA gain is then held constant (preventing it from ramping up as it normally would when the signal is quiet).

The table below summarises the noise gate control register. The NGTH control bits set the noise gate threshold with respect to the ADC full-scale range. The threshold is adjusted in 6 dB steps. Levels at the extremes of the range may cause inappropriate operation, so care should be taken with set-up of the function. The noise gate only operates in conjunction with the ALC and cannot be used in limiter mode.

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R35 (23h) <br> ALC Noise Gate Control | 2:0 | NGTH | 000 | Noise gate threshold: $\begin{aligned} 000 & =-39 \mathrm{~dB} \\ 001 & =-45 \mathrm{~dB} \\ 010 & =-51 \mathrm{db} \\ 011 & =-57 \mathrm{~dB} \\ 100 & =-63 \mathrm{~dB} \\ 101 & =-69 \mathrm{~dB} \\ 110 & =-75 \mathrm{~dB} \\ 111 & =-81 \mathrm{~dB} \end{aligned}$ |
|  | 3 | NGATEN | 0 | Noise gate function enable $\begin{aligned} & 1=\text { enable } \\ & 0=\text { disable } \end{aligned}$ |

Table 22 ALC Noise Gate Control

The diagrams below show the response of the system to the same signal with and without noise gate.

WM8950


Figure 16 ALC Operation above Noise Gate Threshold


Figure 17 Noise Gate Operation

## GRAPHIC EQUALISER

A 5-band graphic EQ is provided, which can be applied to the ADC data under control of the EQMODE register bit.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R18 <br> EQ Control 1 | 8 | EQMODE | 1 | $0=$ Equaliser applied to ADC data <br> $1=$ Equaliser bypassed |

Table 23 EQ Select

The equaliser consists of low and high frequency shelving filters (Band 1 and 5) and three peak filters for the centre bands. Each has adjustable cut-off or centre frequency, and selectable boost (+/-12dB in 1 dB steps). The peak filters have selectable bandwidth.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R18 <br> EQ Band 1 | $4: 0$ | EQ1G | 01100 <br> $(0 \mathrm{~dB})$ | Band 1 Gain Control. See Table 29 for <br> details. |

WM8950

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| Control | $6: 5$ | EQ1C | 01 | Band 1 Cut-off Frequency: |
|  |  |  |  | $00=80 \mathrm{~Hz}$ |
|  |  |  |  | $01=105 \mathrm{~Hz}$ |
|  |  |  |  | $10=135 \mathrm{~Hz}$ |
|  |  |  |  |  |

Table 24 EQ Band 1 Control

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R19 <br> EQ Band 2 <br> Control | 4:0 | EQ2G | $\begin{aligned} & 01100 \\ & (0 \mathrm{~dB}) \end{aligned}$ | Band 2 Gain Control. See Table 29 for details. |
|  | 6:5 | EQ2C | 01 | Band 2 Centre Frequency: $\begin{aligned} & 00=230 \mathrm{~Hz} \\ & 01=300 \mathrm{~Hz} \\ & 10=385 \mathrm{~Hz} \\ & 11=500 \mathrm{~Hz} \end{aligned}$ |
|  | 8 | EQ2BW | 0 | Band 2 Bandwidth Control <br> 0=narrow bandwidth <br> 1=wide bandwidth |

Table 25 EQ Band 2 Control

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R20 <br> EQ Band 3 <br> Control | $4: 0$ | EQ3G | 01100 <br> $(0 \mathrm{~dB})$ | Band 3 Gain Control. See Table 29 for <br> details. |
|  | $6: 5$ | EQ3C | 01 | Band 3 Centre Frequency: <br> $00=650 \mathrm{~Hz}$ <br> $01=850 \mathrm{~Hz}$ |
|  |  |  |  | $10=1.1 \mathrm{kHz}$ |
|  |  |  |  | Band 3 Bandwidth Control |
|  | 8 | EQ3BW | 0 | 0=narrow bandwidth <br> $1=$ wide bandwidth |

Table 26 EQ Band 3 Control

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R21 <br> EQ Band 4 <br> Control | $4: 0$ | EQ4G | 01100 <br> $(0 \mathrm{~dB})$ | Band 4 Gain Control. See Table 29 for <br> details |
|  | $6: 5$ | EQ4C | 01 | Band 4 Centre Frequency: <br> $00=1.8 \mathrm{kHz}$ <br>  |
|  |  |  | $01=2.4 \mathrm{kHz}$ <br> $10=3.2 \mathrm{kHz}$ <br>  |  |
|  |  |  | Band 4 Bandwidth Control <br> $0=$ narrow bandwidth <br> $1=$ wide bandwidth |  |
|  | 8 | EQ4BW | 0 |  |

Table 27 EQ Band 4 Control

WM8950

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R22 <br> EQ Band 5 <br> Gain Control | $4: 0$ | EQ5G | 01100 <br> $(0 \mathrm{~dB})$ | Band 5 Gain Control. See Table 29 for <br> details. |
|  | $6: 5$ | EQ5C | 01 | Band 5 Cut-off Frequency: <br> $00=5.3 \mathrm{kHz}$ |
|  |  |  |  | $01=6.9 \mathrm{kHz}$ <br> $10=9 \mathrm{kHz}$ <br> $11=11.7 \mathrm{kHz}$ |

Table 28 EQ Band 5 Control

| GAIN REGISTER | GAIN |
| :--- | :--- |
| 00000 | +12 dB |
| 00001 | +11 dB |
| 00010 | +10 dB |
| $\ldots$. (1dB steps) |  |
| 01100 | 0 dB |
| 01101 | -1 dB |
| 11000 to 11111 | -12 dB |

Table 29 Gain Register Table

A dedicated buffer is available for tying off unused analogue input pins as shown below Figure 18 This buffer can be enabled using the BUFIOEN register bit.


Figure 18 Unused Input Pin Tie-off Buffers

## THERMAL SHUTDOWN

To protect the WM8950 from overheating a thermal shutdown circuit is included. If the device temperature reaches approximately $125^{\circ} \mathrm{C}$ and the thermal shutdown circuit is enabled (TSDEN=1), an interrupt can be generated. See the GPIO and Interrupt Controller section for details.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R49 <br> Output control | 1 | TSDEN | 1 | Thermal Shutdown Enable <br> $0:$ thermal shutdown disabled <br> $1:$ thermal shutdown enabled |

Table 30 Thermal Shutdown

## DIGITAL AUDIO INTERFACES

The audio interface has three pins:

- ADCDAT: ADC data output
- FRAME: Data alignment clock
- BCLK: Bit clock, for synchronisation

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

Five different audio data formats are supported:

- Left justified
- Right justified
- $\quad I^{2} S$
- DSP mode

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

## MASTER AND SLAVE MODE OPERATION

The WM8950 audio interface may be configured as either master or slave. As a master interface device the WM8950 generates BCLK and FRAME and thus controls sequencing of the data transfer on ADCDAT. To set the device to master mode register bit MS should be set high. In slave mode (MS=0), the WM8950 responds with data to clocks it receives over the digital audio interfaces.

## AUDIO DATA FORMATS

In Left Justified mode, the MSB is available on the first rising edge of BCLK following an FRAME 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 FRAME transition.


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

In Right Justified mode, the LSB is available on the last rising edge of BCLK before a FRAME 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 FRAME transition.

WM8950


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

In I ${ }^{2} S$ mode, the MSB is available on the second rising edge of BCLK following a FRAME 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 $21 \mathrm{I}^{2}$ S Audio Interface (assuming n-bit word length)

In DSP/PCM mode, the left channel MSB is available on the $2^{\text {nd }}$ (mode A) rising edge of BCLK following a rising edge of FRAME. 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 LRC output will resemble the frame pulse shown in Figure 22. In device slave mode, Figure 23 it is possible to use any length of frame pulse less than $1 / \mathrm{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 22 DSP/PCM Mode Audio Interface (mode A, LRP=0, Master)


Figure 23 DSP/PCM Mode Audio Interface (mode A, LRP=0, Slave)

When using ADCLRSWAP = 1 in DSP/PCM mode, the data will appear in the Right Phase of the FRAME, which will be 16/20/24/32 bits after the FRAME pulse.

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R4 <br> Audio interface control | 1 | ADCLRSWAP | 0 | Controls whether ADC data appears in 'right' or 'left' phases of FRAME clock: $0=A D C$ data appear in 'left' phase of FRAME <br> 1=ADC data appears in 'right' phase of FRAME |
|  | 4:3 | FMT | 10 | Audio interface Data Format Select: <br> 00=Right Justified <br> 01=Left Justified <br> $10=I^{2} S$ format <br> 11= DSP/PCM mode |
|  | 6:5 | WL | 10 | Word length <br> $00=16$ bits <br> $01=20$ bits <br> 10=24 bits <br> 11=32 bits (see note) |
|  | 7 | FRAMEP | 0 | Frame clock polarity $0=$ normal 1=inverted |
|  |  |  |  | DSP Mode - reserved |
|  | 8 | BCP | 0 | BCLK polarity <br> $0=$ normal <br> 1=inverted |

Table 31 Audio Interface Control

AUDIO INTERFACE CONTROL
The register bits controlling audio format, word length and master / slave mode are summarised below. Each audio interface can be controlled individually.

Register bit MS selects audio interface operation in master or slave mode. In Master mode BCLK, and FRAME are outputs. The frequency of BCLK and FRAME in master mode are controlled with BCLKDIV. These are divided down versions of master clock. This may result in short BCLK pulses at the end of a frame if there is a non-integer ratio of BCLKs to FRAME clocks.

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R6 <br> Clock <br> generation control | 0 | MS | 0 | Sets the chip to be master over FRAME and BCLK <br> $0=B C L K$ and FRAME clock are inputs $1=$ BCLK and FRAME clock are outputs generated by the WM8950 (MASTER) |
|  | 4:2 | BCLKDIV | 000 | Configures the BCLK and FRAME output frequency, for use when the chip is master over BCLK. <br> $000=$ divide by 1 (BCLK=MCLK) <br> 001=divide by 2 (BCLK=MCLK/2) <br> 010=divide by 4 <br> 011=divide by 8 <br> 100=divide by 16 <br> 101=divide by 32 <br> 110=reserved <br> 111=reserved |
|  | 7:5 | MCLKDIV | 010 | Sets the scaling for either the MCLK or PLL clock output (under control of CLKSEL) <br> $000=$ divide by 1 <br> 001=divide by 1.5 <br> $010=$ divide by 2 <br> 011=divide by 3 <br> 100=divide by 4 <br> 101=divide by 6 <br> 110=divide by 8 <br> 111=divide by 12 |
|  | 8 | CLKSEL | 1 | Controls the source of the clock for all internal operation: $\begin{aligned} & 0=\text { MCLK } \\ & 1=\text { PLL output } \end{aligned}$ |

Table 32 Clock Contro

## COMPANDING

The WM8950 supports A-law and $\mu$-law companding. Companding can be enabled on the ADC audio interface by writing the appropriate value to the ADC_COMP register bit.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :---: | :---: | :---: | :--- |
| R5 | $2: 1$ | ADC_COMP | 0 | ADC companding |
| Companding <br> control |  |  |  | $00=$ off |
|  |  |  |  | $01=$ reserved <br> $10=\mu$-law <br> $11=A-l a w ~$ |

Table 33 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) \quad\}-1 \leq x \leq 1
$$

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

$$
\begin{array}{ll}
F(x)=A|x| /(1+\ln A) & \} \text { for } x \leq 1 / A \\
F(x)=(1+\ln A|x|) /(1+\ln A) & \} \text { for } 1 / A \leq x \leq 1
\end{array}
$$

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 MSB's of data.

Companding converts 13 bits ( $\mu$-law) or 12 bits (A-law) to 8 bits using non-linear quantization. The input data range is separated into 8 levels, allowing low amplitude signals better precision than that of high amplitude signals. This is to exploit the operation of the human auditory system, where louder sounds do not require as much resolution as quieter sounds. The companded signal is an 8 -bit word containing sign (1-bit), exponent (3-bits) and mantissa (4-bits).

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

Table 34 8-bit Companded Word Composition


Figure 24 u-Law Companding

WM8950


Figure 25 A-Law Companding

## AUDIO SAMPLE RATES

The WM8950 sample rate for the ADC is set using the SR register bits. The cut-offs for the digital filters and the ALC attack/decay times stated are determined using these values and assume a 256 fs master clock rate.

If a sample rate that is not explicitly supported by the SR register settings is required then the closest SR value to that sample rate should be chosen, the filter characteristics and the ALC attack, decay and hold times will scale appropriately.

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R7 <br> Additional control | 3:1 | SR | 000 | Approximate sample rate (configures the coefficients for the internal digital filters): $\begin{aligned} & 000=48 \mathrm{kHz} \\ & 001=32 \mathrm{kHz} \\ & 010=24 \mathrm{kHz} \\ & 011=16 \mathrm{kHz} \\ & 100=12 \mathrm{kHz} \\ & 101=8 \mathrm{kHz} \\ & 110-111=\text { reserved } \end{aligned}$ |

Table 35 Sample Rate Control

## MASTER CLOCK AND PHASE LOCKED LOOP (PLL)

The WM8950 has an on-chip phase-locked loop (PLL) circuit that can be used to:
Generate master clocks for the WM8950 audio functions from another external clock, e.g. in telecoms applications.

Generate and output (on pin CSB/GPIO) a clock for another part of the system that is derived from an existing audio master clock.

Figure 26 shows the PLL and internal clocking arrangement on the WM8950.
The PLL can be enabled or disabled by the PLLEN register bit.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R1 <br> Power <br> management 1 5 | PLLEN | 0 | PLL enable <br> $0=$ PLL off <br> $1=P L L$ on |  |

Table 36 PLLEN Control Bit


Figure 26 PLL and Clock Select Circuit

The PLL frequency ratio $R=f_{2} / f_{1}$ (see Figure 26) can be set using the register bits PLLK and PLLN:

$$
\begin{aligned}
& \text { PLLN }=\operatorname{int} \mathrm{R} \\
& \text { PLLK }=\operatorname{int}\left(2^{24}(\mathrm{R}-\mathrm{PLLN})\right)
\end{aligned}
$$

## EXAMPLE:

$\mathrm{MCLK}=12 \mathrm{MHz}$, required clock $=12.288 \mathrm{MHz}$.
$R$ should be chosen to ensure $5<$ PLLN $<13$. There is a fixed divide by 4 in the PLL and a selectable divide by N after the PLL which should be set to divide by 2 to meet this requirement.

Enabling the divide by 2 sets the required $\mathrm{f}_{2}=4 \times 2 \times 12.288 \mathrm{MHz}=98.304 \mathrm{MHz}$.

$$
\begin{aligned}
& \mathrm{R}=98.304 / 12=8.192 \\
& \mathrm{PLLN}=\operatorname{int} \mathrm{R}=8 \\
& \mathrm{k}=\operatorname{int}\left(2^{24} \times(8.192-8)\right)=3221225=3126 \mathrm{E} 9 \mathrm{~h}
\end{aligned}
$$

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R36 <br> PLL N value | 4 | PLLPRESCALE | 0 | $0=$ MCLK input not divided (default) <br> 1 = Divide MCLK by 2 before input to <br> PLL |
|  | $3: 0$ | PLLN | 1000 | Integer (N) part of PLL input/output <br> frequency ratio. Use values greater <br> than 5 and less than 13. |
| R37 <br> PLL K value 1 | $5: 0$ | PLLK [23:18] | 0 0Ch | Fractional (K) part of PLL1 <br> input/output frequency ratio (treat as <br> one 24-digit binary number). |
| R38 <br> PLL K Value 2 | $8: 0$ | PLLK [17:9] | 093 n |  |
| R39 <br> PLL K Value 3 | $8: 0$ | PLLK [8:0] | 0E9h |  |

Table 37 PLL Frequency Ratio Control

The PLL performs best when $f_{2}$ is around 90 MHz . Its stability peaks at $\mathrm{N}=8$. Some example settings are shown in Figure 35.

| MCLK <br> $\mathbf{( M H z )}$ <br> $\mathbf{( F 1 )}$ | DESIRED <br> OUTPUT <br> (MHz) | F2 <br> (MHz) | PRESCALE <br> DIVIDE | POSTSCALE <br> DIVIDE | $\mathbf{R}$ | $\mathbf{N}$ <br> (Hex) | K <br> (Hex) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 12 | 11.2896 | 90.3168 | 1 | 2 | 7.5264 | 7 | 86 C 220 |
| 12 | 12.288 | 98.304 | 1 | 2 | 8.192 | 8 | $3126 E 8$ |
| 13 | 11.2896 | 90.3168 | 1 | 2 | 6.947446 | 6 | F28BD4 |
| 13 | 12.288 | 98.304 | 1 | 2 | 7.561846 | 7 | 8 FD525 |
| 14.4 | 11.2896 | 90.3168 | 1 | 2 | 6.272 | 6 | $45 A 1 C A$ |
| 14.4 | 12.288 | 98.304 | 1 | 2 | 6.826667 | 6 | D3A06E |
| 19.2 | 11.2896 | 90.3168 | 2 | 2 | 9.408 | 9 | $6872 A F$ |
| 19.2 | 12.288 | 98.304 | 2 | 2 | 10.24 | A | 3D70A3 |
| 19.68 | 11.2896 | 90.3168 | 2 | 2 | 9.178537 | 9 | 2 DB492 |
| 19.68 | 12.288 | 98.304 | 2 | 2 | 9.990243 | 9 | FD809F |
| 19.8 | 11.2896 | 90.3168 | 2 | 2 | 9.122909 | 9 | 1F76F7 |
| 19.8 | 12.288 | 98.304 | 2 | 2 | 9.929697 | 9 | EE009E |
| 24 | 11.2896 | 90.3168 | 2 | 2 | 7.5264 | 7 | $86 C 226$ |
| 24 | 12.288 | 98.304 | 2 | 2 | 8.192 | 8 | $3126 E 8$ |
| 26 | 11.2896 | 90.3168 | 2 | 2 | 6.947446 | 6 | F28BD4 |
| 26 | 12.288 | 98.304 | 2 | 2 | 7.561846 | 7 | 8 FD525 |
| 27 | 11.2896 | 90.3168 | 2 | 2 | 6.690133 | 6 | BOAC93 |
| 27 | 12.288 | 98.304 | 2 | 2 | 7.281778 | 7 | 482296 |

Table 38 PLL Frequency Examples

WM8950

## GENERAL PURPOSE INPUT/OUTPUT

The CSB/GPIO pin can be configured to perform a variety of useful tasks by setting the GPIOSEL register bits. The GPIO is only available in 2 wire mode.

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R8 <br> GPIO <br> control | 2:0 | GPIOSEL | 000 | ```CSB/GPIO pin function select: 000=CSB input 001=Reserved 010=Temp ok 011=Automute active 100=PLL clk o/p 101=PLL lock 110=Reserved 111=Reserved``` |
|  | 3 | GPIOPOL | 0 | GPIO Polarity invert <br> $0=$ Non inverted <br> 1=Inverted |
|  | 5:4 | OPCLKDIV | 00 | PLL Output clock division ratio $00=$ divide by 1 <br> 01=divide by 2 <br> 10=divide by 3 <br> 11=divide by 4 |

Table 39 CSB/GPIO Control

## CONTROL INTERFACE

## SELECTION OF CONTROL MODE AND 2-WIRE MODE ADDRESS

The control interface can operate as either a 3-wire or 2 -wire MPU interface. The MODE pin determines the 2 or 3 wire mode as shown in Table 40.

The WM8950 is controlled by writing to registers through a serial control interface. A control word consists of 16 bits. The first 7 bits (B15 to B9) are address bits that select which control register is accessed. The remaining 9 bits ( B 8 to B 0 ) are register bits, corresponding to the 9 bits in each control register.

| MODE | INTERFACE FORMAT |
| :---: | :---: |
| Low | 2 wire |
| High | 3 wire |

Table 40 Control Interface Mode Selection

## 3-WIRE SERIAL CONTROL MODE

In 3-wire mode, every rising edge of SCLK clocks in one data bit from the SDIN pin. A rising edge on CSB/GPIO latches in a complete control word consisting of the last 16 bits.


Figure 27 3-Wire Serial Control Interface

## 2-WIRE SERIAL CONTROL MODE

The WM8950 supports software control via a 2-wire serial bus. Many devices can be controlled by the same bus, and each device has a unique 7 -bit device address (this is not the same as the 7 -bit address of each register in the WM8950).

The WM8950 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 WM8950, then the WM8950 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 WM8950 returns to the idle condition and wait for a new start condition and valid address.

During a write, once the WM8950 has acknowledged a correct address, the controller sends the first byte of control data ( B 15 to B8, i.e. the WM8950 register address plus the first bit of register data). The WM8950 then acknowledges the first data byte by pulling SDIN low for one clock pulse. The controller then sends the second byte of control data ( B 7 to BO , i.e. the remaining 8 bits of register data), and the WM8950 acknowledges again by pulling SDIN low.

Transfers are complete when there is a low to high transition on SDIN while SCLK is high. After a complete sequence the WM8950 returns to the idle state and waits for another start condition. If a start or stop condition is detected out of sequence at any point during data transfer (i.e. SDIN changes while SCLK is high), the device jumps to the idle condition.


Figure 28 2-Wire Serial Control Interface

In 2-wire mode the WM8950 has a fixed device address, 0011010.

## RESETTING THE CHIP

The WM8950 can be reset by performing a write of any value to the software reset register (address 0 hex). This will cause all register values to be reset to their default values. In addition to this there is a Power-On Reset (POR) circuit which ensures that the registers are set to default when the device is powered up.

## POWER SUPPLIES

The WM8950 can use up to three separate power supplies:
AVDD, AVDD2, AGND and AGND2: Analogue supply, powers all analogue functions. AVDD can range from 2.5 V to 3.6 V and has the most significant impact on overall power consumption. A large AVDD slightly improves audio quality.

DCVDD: Digital core supply, powers all digital functions except the audio and control interfaces. DCVDD can range from 1.71 V to 3.6 V , and has no effect on audio quality. The return path for DCVDD is DGND, which is shared with DBVDD.

DBVDD Can range from 1.71 V to 3.6 V . DBVDD return path is through DGND
It is possible to use the same supply voltage for all supplies. However, digital and analogue supplies should be routed and decoupled separately on the PCB to keep digital switching noise out of the analogue signal paths.

ADC POWER UP/DOWN SEQUENCE


Figure 29 ADC Power Up and Down Sequence (not to scale)

| SYMBOL | MIN | TYPICAL | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {midrail_on }}$ |  | 500 |  | ms |
| $\mathrm{t}_{\text {midrail_off }}$ |  | $>10$ |  | s |
| $\mathrm{t}_{\text {adcint }}$ |  | $2 / \mathrm{fs}$ |  | $\mathrm{n} / \mathrm{fs}$ |

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

Notes:

1. The analogue input pin charge time, $\mathrm{t}_{\text {midrail }}$ on, is determined by the VMID pin charge time. This time is dependent upon the value of VMID decoupling capacitor and VMID pin input resistance and AVDD power supply rise time.
2. The analogue input pin discharge time, $\mathrm{t}_{\text {midrail off, }}$ is determined by the analogue input coupling capacitor discharge time. The time, $\mathrm{t}_{\text {midrail off, }}$, is measured using a $1 \mu \mathrm{~F}$ capacitor on the analogue input but will vary dependent upon the value of input coupling capacitor.
3. While the ADC is enabled there will be LSB data bit activity on the ADCDAT pin due to system noise but no significant digital output will be present.
4. The VMIDSEL and BIASEN bits must be set to enable analogue input midrail voltage and for normal ADC operation.
5. ADCDAT data output delay from power up - with power supplies starting from 0 V - is determined primarily by the VMID charge time. ADC initialisation and power management bits may be set immediately after POR is released; VMID charge time will be significantly longer and will dictate when the device is stabilised for analogue input.
6. ADCDAT data output delay at power up from device standby (power supplies already applied) is determined by ADC initialisation time, 2/fs.

## POWER MANAGEMENT

## SAVING POWER BY REDUCING OVERSAMPLING RATE

The default mode of operation of the ADC digital filters is in 64x oversampling mode. Under the control of ADCOSR the oversampling rate may be doubled. 64x oversampling results in a slight decrease in noise performance compared to $128 x$ but lowers the power consumption of the device.

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R14 | 3 | ADCOSR128 | 0 | ADC oversample rate select <br> $0=64 x$ (lowest power) <br> ADC control |
|  |  |  |  | $128 \times$ (best SNR) |

Table 42 ADC Oversampling Rate Selection

## VMID

The analogue circuitry will not work unless VMID is enabled (VMIDSEL $\neq 00$ ). The impedance of the VMID resistor string, together with the decoupling capacitor on the VMID pin will determine the startup time of the VMID circuit

| REGISTER ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| R1 Power management 1 | 1:0 | VMIDSEL | 00 | Reference string impedance to VMID pin (determines start-up time): <br> $00=$ off (open circuit) <br> $01=50 \mathrm{k} \Omega$ <br> $10=500 \mathrm{k} \Omega$ <br> $11=5 \mathrm{k} \Omega$ (for fastest start-up) |

Table 43 VMID Impedance Control

## BIASEN

| REGISTER <br> ADDRESS | BIT | LABEL | DEFAULT | DESCRIPTION |
| :--- | :--- | :--- | :--- | :--- |
| R1 <br> Power <br> management 1 | 3 | BIASEN | 0 | Analogue amplifier bias control |

Table 44 BIASEN Control

## ESTIMATED SUPPLY CURRENTS

When the ADC is enabled it is estimated that approximately 4 mA will be drawn from DCVDD when DCVDD $=1.8 \mathrm{~V}$ and $\mathrm{fs}=48 \mathrm{kHz}$. (This will be lower at lower sample rates). When the PLL is enabled an additional 700 microamps will be drawn from DCVDD.

Table 59 shows the estimated 3.3V AVDD current drawn by various circuits, by register bit.

| REGISTER BIT | AVDD CURRENT (MILLIAMPS) |
| :--- | :--- |
| PLLEN | 1.4 (with clocks applied) |
| MICBEN | 0.5 |
| BIASEN | 0.3 |
| BUFIOEN | 0.1 |
| VMIDSEL | $10 \mathrm{~K}=>0.3$, less than 0.1 for $50 \mathrm{k} / 500 \mathrm{k}$ |
| INPPGAEN | 0.2 |
| ADCEN | x 64 (ADCOSR $=0$ ) $=>2.6, \times 128$ (ADCOSR $=1$ ) $=>4.9$ |

Table 45 AVDD Supply Current

## REGISTER MAP

| $\begin{gathered} \text { ADDR } \\ \text { B[15:9] } \end{gathered}$ |  | REGISTER NAME | B8 | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 | $\begin{aligned} & \text { DEF'T } \\ & \text { VAL } \\ & \hline \text { (HEX) } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DEC | HEX |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 00 | Software Reset | Software reset |  |  |  |  |  |  |  |  |  |
| 1 | 01 | Power manage't 1 | 0 | 0 | AUXEN | PLLEN | MICBEN | BIASEN | BUFIOEN | VMIDSEL |  | 000 |
| 2 | 02 | Power manage't 2 | 0 | 0 | 0 | 0 | BOOSTEN | 0 | INPPGAEN | 0 | ADCEN | 000 |
| 4 | 04 | Audio Interface | BCP | FRAMEP | WL |  | FMT |  | 0 | ALRSWAP | 0 | 050 |
| 5 | 05 | Companding ctrl | 0 | 0 | 0 | 0 | 0 |  | ADC_COMP |  | 0 | 000 |
| 6 | 06 | Clock Gen ctrl | CLKSEL | MCLKDIV |  |  | BCLKDIV |  |  | 0 | MS | 140 |
| 7 | 07 | Additional ctrl | 0 | 0 | 0 | 0 | 0 | SR |  |  | $\begin{array}{\|c\|} \hline \text { SLOWCLK } \\ \text { EN } \end{array}$ | 000 |
| 8 | 08 | GPIO Stuff | 0 | 0 | 0 | OPCLKDIV |  | GPIOPOL | GPIOSEL |  |  | 000 |
| 14 | 0E | ADC Control | HPFEN | HPFAPP | HPFCUT |  |  | $\begin{array}{c\|} \hline \text { ADCOSR } \\ 128 \\ \hline \end{array}$ | 0 | 0 | ADCPOL | 100 |
| 15 | OF | ADC Digital Vol | 0 | ADCVOL |  |  |  |  |  |  |  | OFF |
| 18 | 12 | EQ1 - low shelf | 0 | 0 | EQ1C |  | EQ1G |  |  |  |  | 12C |
| 19 | 13 | EQ2 - peak 1 | EQ2BW | 0 | EQ2C |  | EQ2G |  |  |  |  | 02C |
| 20 | 14 | EQ3 - peak 2 | EQ3BW | 0 | EQ3C |  | EQ3G |  |  |  |  | 02C |
| 21 | 15 | EQ4 - peak 3 | EQ4BW | 0 | EQ4C |  | EQ4G |  |  |  |  | 02C |
| 22 | 16 | $\begin{aligned} & \text { EQ5 - high } \\ & \text { shelf } \end{aligned}$ | 0 | 0 | EQ5C |  | EQ5G |  |  |  |  | 02C |
| 27 | 1B | Notch Filter 1 | NFU | NFEN | NFAO[13:7] |  |  |  |  |  |  | 000 |
| 28 | 1 C | Notch Filter 2 | NFU | 0 | NFAO[6:0] |  |  |  |  |  |  | 000 |
| 29 | 1D | Notch Filter 3 | NFU | 0 | NFA1[13:7] |  |  |  |  |  |  | 000 |
| 30 | 1E | Notch Filter 4 | NFU | 0 | NFA1[6:0] |  |  |  |  |  |  | 000 |
| 32 | 20 | ALC control 1 | ALCSEL | 0 | 0 | ALCMAX |  |  | ALCMIN |  |  | 038 |
| 33 | 21 | ALC control 2 | ALCZC | ALCHLD |  |  |  | ALCLVL |  |  |  | 00B |
| 34 | 22 | ALC control 3 | ALCMODE | ALCDCY |  |  |  | ALCATK |  |  |  | 032 |
| 35 | 23 | Noise Gate | 0 | 0 | 0 | 0 | 0 | NGEN | NGTH |  |  | 000 |
| 36 | 24 | PLL N | 0 | 0 | 0 | 0 | $\begin{aligned} & \text { PLL_PRE } \\ & \text { SCALE } \end{aligned}$ | PLLN[3:0] |  |  |  | 008 |
| 37 | 25 | PLL K 1 | 0 | 0 | 0 | PLLK[23:18] |  |  |  |  |  | 00C |
| 38 | 26 | PLL K 2 | PLLK[17:9] |  |  |  |  |  |  |  |  | 093 |
| 39 | 27 | PLL K 3 | PLLK[8:0] |  |  |  |  |  |  |  |  | 0E9 |
| 44 | 2 C | Input ctrl | MBVSEL | 0 | 0 | 0 | 0 | AUXMODE | $\begin{gathered} \hline \text { AUX2 } \\ \text { INPPGA } \end{gathered}$ | MICN2 <br> INPPGA | $\begin{gathered} \hline \text { MICP2 } \\ \text { INPPGA } \end{gathered}$ | 003 |
| 45 | 2D | INP PGA gain ctrl | 0 | INPPGAZC | INPPGA <br> MUTE |  |  | INPPG | GAVOL |  |  | 010 |
| 47 | 2 F | ADC Boost ctrl | PGABOOST | 0 |  | P2BOOST | VOL | 0 |  | JX2BOOSTV |  | 100 |
| 49 | 31 | Thermal Shutdown | 0 | 0 | 0 | 0 | 0 | 0 | 0 | TSDEN | 0 | 002 |

DIGITAL FILTER CHARACTERISTICS

| PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADC Filter |  |  |  |  |  |
| Passband | +/- 0.025dB | 0 |  | 0.454fs |  |
|  | -6dB |  | 0.5fs |  |  |
| Passband Ripple |  |  |  | +/-0.025 | dB |
| Stopband |  | 0.546fs |  |  |  |
| Stopband Attenuation | $\mathrm{f}>0.546 \mathrm{fs}$ | -60 |  |  | dB |
| Group Delay |  |  | 21/fs |  |  |
| ADC High-Pass Filter |  |  |  |  |  |
| High-Pass Filter Corner Frequency | -3dB |  | 3.7 |  | Hz |
|  | $-0.5 \mathrm{~dB}$ |  | 10.4 |  |  |
|  | -0.1dB |  | 21.6 |  |  |

Table 46 Digital Filter Characteristics

## TERMINOLOGY

1. Stop Band Attenuation (dB) - the degree to which the frequency spectrum is attenuated (outside audio band)
2. Pass-band Ripple - any variation of the frequency response in the pass-band region
3. Note that this delay applies only to the filters and does not include additional delays through other digital circuits. See Table 47 for the total delay.

| PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
| :--- | :---: | :---: | :---: | :---: | :---: |
| ADC Path Group Delay |  |  |  |  |  |
| Total Delay (ADC analogue <br> input to digital audio interface <br> output) | EQ disabled | $26 / \mathrm{fs}$ | $28 / \mathrm{fs}$ | $30 / \mathrm{fs}$ |  |

Table 47 Total Group Delay

Note: Wind noise filter is disabled.

## ADC FILTER RESPONSES



Figure 30 ADC Digital Filter Frequency Response


Figure 31 ADC Digital Filter Ripple

## DE-EMPHASIS FILTER RESPONSES



Figure 32 De-emphasis Frequency Response (32kHz)


Figure 34 De-emphasis Frequency Response ( 44.1 kHz )


Figure 36 De-emphasis Frequency Response (48kHz)


Figure 33 De-emphasis Error (32kHz)


Figure 35 De-emphasis Error (44.1kHz)


Figure 37 De-emphasis Error (48kHz)

## HIGH-PASS FILTER

The WM8950 has a selectable digital high-pass filter in the ADC filter path. This filter has two modes, audio and applications. In audio mode the filter is a $1^{\text {st }}$ order IIR with a cut-off of around 3.7 Hz . In applications mode the filter is a $2^{\text {nd }}$ order high-pass filter with a selectable cut-off frequency.


Figure 38 ADC High-pass Filter Response, HPFAPP=0


Figure 40 ADC High-pass Filter Responses (24kHz), HPFAPP=1, all cut-off settings shown.


Figure 39 ADC High-pass Filter Responses (48kHz), HPFAPP=1, all cut-off settings shown.


Figure 41 ADC High-pass Filter Responses (12kHz), HPFAPP=1, all cut-off settings shown.

WM8950

## 5-BAND EQUALISER

The WM8950 has a 5-band equaliser which can be applied to the ADC path. The plots from Figure 42 to Figure 55 show the frequency responses of each filter with a sampling frequency of 48 kHz , firstly showing the different cut-off/centre frequencies with a gain of $\pm 12 \mathrm{~dB}$, and secondly a sweep of the gain from -12 dB to +12 dB for the lowest cut-off/centre frequency of each filter.



Figure 42 EQ Band 1 - Low Frequency Shelf Filter Cut-offs Figure 43 EQ Band 1 - Gains for Lowest Cut-off Frequency


Figure 44 EQ Band 2 - Peak Filter Centre Frequencies, EQ2BW=0


Figure 45 EQ Band 2 - Peak Filter Gains for Lowest Cut-off Frequency, EQ2BW=0


Figure 46 EQ Band 2 - EQ2BW=0, EQ2BW=1


Figure 47 EQ Band 3 - Peak Filter Centre Frequencies, EQ3BW=0


Figure 49 EQ Band $3-E Q 3 B W=0, E Q 3 B W=1$


Figure 48 EQ Band 3 - Peak Filter Gains for Lowest Cut-off Frequency, EQ3BW=0

WM8950


Figure 50 EQ Band 4 - Peak Filter Centre Frequencies, EQ3BW=0



Figure 51 EQ Band 4 - Peak Filter Gains for Lowest Cut-off Frequency, EQ4BW=0


Figure 53 EQ Band 5-High Frequency Shelf Filter Cut-offs Figure 54 EQ Band 5-Gains for Lowest Cut-off Frequency

Figure 55 shows the result of having the gain set on more than one channel simultaneously. The blue traces show each band (lowest cut-off/centre frequency) with $\pm 12 \mathrm{~dB}$ gain. The red traces show the cumulative effect of all bands with +12 dB gain and all bands -12 dB gain, with $\mathrm{EQxBW}=0$ for the peak filters.


Figure 55 Cumulative Frequency Boost/Cut

WM8950

## APPLICATIONS INFORMATION

## RECOMMENDED EXTERNAL COMPONENTS



Figure 56 Recommended External Components

## PACKAGE DIAGRAM



| Symbols |  | Dimensions (mm) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | NOM | MAX | NOTE |  |  |  |
| A | 0.80 | 0.85 | 0.90 |  |  |  |  |
| A1 | 0 | 0.035 | 0.05 |  |  |  |  |
| A3 |  | 0.203 REF |  |  |  |  |  |
| b | 0.20 | 0.25 | 0.30 | 1 |  |  |  |
| D |  | 4.00 BSC |  |  |  |  |  |
| D2 | 2.40 | 2.50 | 2.60 | 2 |  |  |  |
| E |  | 4.00 BSC |  |  |  |  |  |
| E2 | 2.40 | 2.50 | 2.60 | 2 |  |  |  |
| e |  | 0.50 BSC |  |  |  |  |  |
| G |  | 0.20 |  |  |  |  |  |
| H |  | 0.10 |  |  |  |  |  |
| L | 0.35 | 0.40 | 0.45 |  |  |  |  |
| T |  | 0.103 |  |  |  |  |  |
| W | 0.15 |  |  |  |  |  |  |
| 0.10 |  |  |  |  |  |  |  |
| aaa | 0.10 |  |  |  |  |  |  |
| bbb |  |  |  |  |  |  |  |
| ccc |  |  |  |  |  |  |  |
| REF: | JEDEC, MO-220, VARIATION VGGD-8. |  |  |  |  |  |  |

NOTES

1. DIMENSION b APPLIES TO METALLIZED TERMINAL AND IS MEASURED BETWEEN 0.15 mm AND 0.30 mm FROM TERMINAL TIP
2. FALLS WITHIN JEDEC, MO-220, VARIATION VGGD-8.
3. ALL DIMENSIONS ARE IN MILLIMETRES
. THE TERMINAL \#1 IDENTIFIER AND TERMINAL NUMBERING CONVENTION SHALL CONFORM TO JEDEC 95-1 SPP-002.
4. COPLANARITY APPLIES TO THE EXPOSED HEAT SINK SLUG AS WELL AS THE TERMINALS
5. REFER TO APPLICATIONS NOTE WAN_0118 FOR FURTHER INFORMATION REGARDING PCB FOOTPRINTS AND QFN PACKAGE SOLDERING. 7. THIS DRAWING IS SUBJECT TO CHANGE WITHOUT NOTICE.

## IMPORTANT NOTICE

## Contacting Cirrus Logic Support

For all product questions and inquiries, contact a Cirrus Logic Sales Representative. To find one nearest you, go to www.cirrus.com.

For the purposes of our terms and conditions of sale, "Preliminary" or "Advanced" datasheets are non-final datasheets that include but are not limited to datasheets marked as "Target", "Advance", "Product Preview", "Preliminary Technical Data" and/or "Pre-production." Products provided with any such datasheet are therefore subject to relevant terms and conditions associated with "Preliminary" or "Advanced" designations. The products and services of Cirrus Logic International (UK) Limited; Cirrus Logic, Inc.; and other companies in the Cirrus Logic group (collectively either "Cirrus Logic" or "Cirrus") are sold subject to Cirrus Logic's terms and conditions of sale supplied at the time of order acknowledgment, including those pertaining to warranty, indemnification, and limitation of liability. Software is provided pursuant to applicable license terms. Cirrus Logic reserves the right to make changes to its products and specifications or to discontinue any product or service without notice. Customers should therefore obtain the latest version of relevant information from Cirrus Logic to verify that the information is current and complete. Testing and other quality control techniques are utilized to the extent Cirrus Logic deems necessary. Specific testing of all parameters of each device is not necessarily performed. In order to minimize risks associated with customer applications, the customer must use adequate design and operating safeguards to minimize inherent or procedural hazards. Cirrus Logic is not liable for applications assistance or customer product design. The customer is solely responsible for its selection and use of Cirrus Logic products. Use of Cirrus Logic products may entail a choice between many different modes of operation, some or all of which may require action by the user, and some or all of which may be optional. Nothing in these materials should be interpreted as instructions or suggestions to choose one mode over another. Likewise, description of a single mode should not be interpreted as a suggestion that other modes should not be used or that they would not be suitable for operation. Features and operations described herein are for illustrative purposes only.

## CERTAIN APPLICATIONS USING SEMICONDUCTOR PRODUCTS MAY INVOLVE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). CIRRUS LOGIC PRODUCTS ARE NOT DESIGNED, AUTHORIZED OR WARRANTED FOR USE IN PRODUCTS SURGICALLY IMPLANTED INTO THE BODY, AUTOMOTIVE SAFETY OR SECURITY DEVICES, NUCLEAR SYSTEMS, LIFE SUPPORT PRODUCTS OR OTHER CRITICAL APPLICATIONS. INCLUSION OF CIRRUS LOGIC PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK AND CIRRUS LOGIC DISCLAIMS AND MAKES NO WARRANTY, EXPRESS, STATUTORY OR IMPLIED, INCLUDING THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR PARTICULAR PURPOSE, WITH REGARD TO ANY CIRRUS LOGIC PRODUCT THAT IS USED IN SUCH A MANNER. IF THE CUSTOMER OR CUSTOMER'S CUSTOMER USES OR PERMITS THE USE OF CIRRUS LOGIC PRODUCTS IN CRITICAL APPLICATIONS, CUSTOMER AGREES, BY SUCH USE, TO FULLY INDEMNIFY CIRRUS LOGIC, ITS OFFICERS, DIRECTORS, EMPLOYEES, DISTRIBUTORS AND OTHER AGENTS FROM ANY AND ALL LIABILITY, INCLUDING ATTORNEYS' FEES AND COSTS, THAT MAY RESULT FROM OR ARISE IN CONNECTION WITH THESE USES.

This document is the property of Cirrus Logic and by furnishing this information, Cirrus Logic grants no license, express or implied, under any patents, mask work rights, copyrights, trademarks, trade secrets or other intellectual property rights. Any provision or publication of any third party's products or services does not constitute Cirrus Logic's approval, license, warranty or endorsement thereof. Cirrus Logic gives consent for copies to be made of the information contained herein only for use within your organization with respect to Cirrus Logic integrated circuits or other products of Cirrus Logic, and only if the reproduction is without alteration and is accompanied by all associated copyright, proprietary and other notices and conditions (including this notice). This consent does not extend to other copying such as copying for general distribution, advertising or promotional purposes, or for creating any work for resale. This document and its information is provided "AS IS" without warranty of any kind (express or implied). All statutory warranties and conditions are excluded to the fullest extent possible. No responsibility is assumed by Cirrus Logic for the use of information herein, including use of this information as the basis for manufacture or sale of any items, or for infringement of patents or other rights of third parties. Cirrus Logic, Cirrus, the Cirrus Logic logo design, and SoundClear are among the trademarks of Cirrus Logic. Other brand and product names may be trademarks or service marks of their respective owners.

Copyright © 2005-2016 Cirrus Logic, Inc. All rights reserved.

## REVISION HISTORY

| DATE | REV | ORIGINATOR | CHANGES |
| :---: | :---: | :---: | :--- |
| $26 / 09 / 11$ | 4.4 | JMacD | Order codes changed from WM8950GEFL/V and WM8950GEFL/RV to <br> WM8950CGEFL/V and WM8950CGEFL/RV to reflect change to copper wire <br> bonding. |
| $26 / 09 / 11$ | 4.4 | JMacD | Package diagram changed to DM102.C |
| $12 / 08 / 16$ | 4.5 | PH | MICBIAS voltage (MBVSEL=1) updated to 0.75 x AVDD. <br> System clock timing requirements updated. |

## Mouser Electronics

Authorized Distributor

Click to View Pricing, Inventory, Delivery \& Lifecycle Information:

Cirrus Logic:
WM8950CGEFL/V WM8950CGEFL/RV WM8950GEFL/V

