CS42L92
32-Bit 384-kHz Hi-Fi Audio Codec
• Multichannel asynchronous sample-rate conversion
Features
• Multiline SLIMbus® audio and control interface
• Integrated multichannel 32-bit hi-fi audio hub codec
— 99-dB signal-to-noise ratio (SNR) mic input (48 kHz)
— 127-dB SNR headphone playback (48 kHz)
— –100-dB total harmonic distortion + noise (THD+N)
— Ultrasonic input- and output-path support
• Three multichannel digital-audio interfaces
— Standard data formats up to 384 kHz, 32 bits
• Flexible clocking, derived from MCLKn, AIFn, or SLIMbus
— Low-power frequency-locked loops (FLLs) support
reference clocks down to 32 kHz.
• Up to eight analog or digital microphone (DMIC) inputs
• Advanced accessory detection functions
• Multipurpose headphone/earpiece/line output drivers
— Support for balanced headphone output loads
• Configurable functions on up to 16 general-purpose
input/output (GPIO) pins
— 33 mW into 32- load at 0.1% THD+N
• Integrated regulators and charge pumps
— Hi-fi filters for audiophile-quality playback
• Small W-CSP package, 0.4-mm staggered ball array
MICBIAS1A
MICBIAS1B
MICBIAS1C
MICBIAS1D
MICBIAS2A
MICBIAS2B
SUBGND
CP2VOUT
AVDD
AGND
VREFC
CS42L92
Charge Pumps
LDO and
MICBIAS
Generators
DCVDD
DBVDD
FLLGND
DGND
• Smartphones, tablets, and multimedia handsets
FLLVDD
CPVDD1
CPVDD2
CPGND
• Digital pulse-density modulation (PDM) output interface
CP2CA
CP2CB
CP1C1A
CP1C1B
CP1VOUT1P
CP1VOUT1N
CP1C2A
CP1C2B
CP1VOUT2P
CP1VOUT2N
Applications
MICVDD
• Native audio playback up to 384 kHz sample rate,
concurrent with voice and ultrasonic input signal paths
Reference
Generator
DAC
HPOUTnL
DAC
HPOUTnR
Digital Mixing Core
http://www.cirrus.com
SYSCLK
ASYNCCLK
Accessory
Detect
SLIMbus
Interface
Control Interface (SPI/I2C)
Copyright Cirrus Logic, Inc. 2017
(All Rights Reserved)
GPIO
x4
SPKCLK
SPKDAT
JACKDET1
JACKDET2
JACKDET3
HPDET1
HPDET2
MICDET1/HPOUTFB1
MICDET2/HPOUTFB2
MICDET3/HPOUTFB3
MICDET4/HPOUTFB4
MICDET5/HPOUTFB5
GPSW1P
GPSW1N
GPSW2P
GPSW2N
Digital Audio Interfaces
AIF1, AIF2, AIF3
GPIO1
GPIO2
Clocking
Control
CIFMISO
CIFMOSI/SDA
CIFSCLK
CIFSS
CIFMODE
AIFnBCLK
AIFnLRCLK
SLIMCLK
AIF1TXDAT
AIF1RXDAT
AIF1BCLK
AIF1LRCLK
IRQ
PDM
Driver
AEC (Echo Cancelation)
Loop-Back
SLIMCLK
SLIMDAT1
SLIMDAT2
RESET
4 x ADC
4 x Stereo
Digital Mic
Interface
AIF3TXDAT
AIF3RXDAT
AIF3BCLK
AIF3LRCLK
MCLK1
MCLK2
MCLK3
Programmable DSP
Five-band equalizer (EQ)
Dynamic range control (DRC)
Low-pass/high-pass filter (LHPF)
Asynchronous sample -rate conversion
Automatic sample -rate detection
Data format conversion
Ultrasonic demodulator
PWM signal generator
Haptic control signal generator
Input Select
AIF2TXDAT
AIF2RXDAT
AIF2BCLK
AIF2LRCLK
IN1ALN/DMICCLK1, IN1BLN
IN1ALP/DMICDAT1, IN1BLP
IN1ARN/DMICCLK3
IN1ARP/DMICDAT3, IN1BR
IN2ALN/DMICCLK2
IN2ALP/DMICDAT2, IN2BL
IN2ARN/DMICCLK4
IN2ARP/DMICDAT4, IN2BR
DS1162F1
NOV '17
CS42L92
Description
The CS42L92 is a highly integrated low-power audio system for smartphones, tablets, and other portable audio devices.
Multiple input/output paths are supported by a fully flexible all-digital mixing and routing engine, incorporating sample rate
converters and other signal-processing functions for wide use-case flexibility. The integrated DSP provides a
general-purpose signal processing capability; this is supported by general-purpose timer and event-logger functions.
The digital audio interfaces and hi-fi DACs enable 32-bit playback through the entire signal chain. Native audio playback
at sample rates up to 384 kHz is possible, concurrent with voice and ultrasonic input paths.
The CS42L92 supports up to eight analog inputs and up to eight PDM digital inputs. Low-power input modes are available
for always-on (e.g., voice-trigger) functionality using either analog or digital input. A smart accessory interface, with
multipurpose impedance sensing and measurement capability, supports detection of external headsets and push buttons.
Dual headphone connections (e.g., 3.5-mm and USB-C™) can be detected simultaneously.
Four hi-fi quality stereo headphone drivers are provided, each supporting stereo ground-referenced or mono bridge-tied
load (BTL) configurations. Multiple headphone/earpiece outputs can be supported, including balanced stereo headphone
configurations. The output drivers offer noise levels as low as 0.63 VRMS into line or headphone loads. Selectable hi-fi
filters support playback modes at sample rates up to 384 kHz.
Two channels of PDM output (one stereo interface) are available, and also an IEC-60958-3–compatible S/PDIF
transmitter. A signal generator for controlling haptics devices is included; vibe actuators can connect directly to the PDM
output interface. All inputs, outputs, and system interfaces can function concurrently.
A SLIMbus interface supports multichannel audio paths and host control register access. Three further digital audio
interfaces are provided, each supporting a wide range of standard audio sample rates and serial interface formats.
Automatic sample-rate detection enables seamless wideband/narrowband voice-call handover. Two FLLs are integrated,
providing support for a wide range of system-clock frequencies.
The CS42L92 is configured using the SLIMbus, SPI™, or IC interfaces. The device is powered from 1.8- and 1.2-V
supplies. The power, clocking, and output driver architectures are designed to maximize battery life in voice, music, and
standby modes. Low-power (10 A) Sleep Mode is supported, with configurable wake-up events.
2
DS1162F1
CS42L92
Table of Contents
1 Pin Descriptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
1.1 WLCSP Pinout . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
1.2 Pin Descriptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
2 Typical Connection Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
3 Characteristics and Specifications . . . . . . . . . . . . . . . . . . . . . 10
Table 3-1. Parameter Definitions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Table 3-2. Absolute Maximum Ratings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Table 3-3. Recommended Operating Conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Table 3-4. Analog Input Signal Level—IN1xx, IN2xx . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Table 3-5. Analog Input Pin Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Table 3-6. Analog Input Gain—Programmable Gain Amplifiers (PGAs) . . . . . . . . . . . . 11
Table 3-7. Digital Input Signal Level—DMICDATn . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
Table 3-8. Output Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
Table 3-9. Input/Output Path Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
Table 3-10. Digital Input/Output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Table 3-11. Miscellaneous Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
Table 3-12. Device Reset Thresholds . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Table 3-13. System Clock and Frequency-Locked Loop (FLL) . . . . . . . . . . . . . . . . . . . 17
Table 3-14. Digital Microphone (DMIC) Interface Timing . . . . . . . . . . . . . . . . . . . . . . . . 18
Table 3-15. Digital Speaker (PDM) Interface Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
Table 3-16. Digital Audio Interface—Master Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
Table 3-17. Digital Audio Interface—Slave Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Table 3-18. Digital Audio Interface Timing—TDM Mode . . . . . . . . . . . . . . . . . . . . . . . . 21
Table 3-19. Control Interface Timing—Two-Wire (I2C) Mode . . . . . . . . . . . . . . . . . . . . 22
Table 3-20. Control Interface Timing—Four-Wire (SPI) Mode . . . . . . . . . . . . . . . . . . . . 23
Table 3-21. SLIMbus Interface Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
Table 3-22. JTAG Interface Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
Table 3-23. Typical Power Consumption . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
Table 3-24. Typical Signal Latency . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
4 Functional Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
4.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
4.2 Input Signal Path . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
4.3 Digital Core . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
3
4.4 DSP Firmware Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94
4.5 DSP Peripheral Control . . . . . . . . . . . . . . . . . . . . . . . . . . . 106
4.6 Digital Audio Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123
4.7 Digital Audio Interface Control . . . . . . . . . . . . . . . . . . . . . . 130
4.8 SLIMbus Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140
4.9 SLIMbus Control Sequences . . . . . . . . . . . . . . . . . . . . . . . 142
4.10 SLIMbus Interface Control . . . . . . . . . . . . . . . . . . . . . . . . 144
4.11 Output Signal Path . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152
4.12 External Accessory Detection . . . . . . . . . . . . . . . . . . . . . 169
4.13 Low Power Sleep Configuration . . . . . . . . . . . . . . . . . . . . 189
4.14 General-Purpose I/O . . . . . . . . . . . . . . . . . . . . . . . . . . . . 190
4.15 Interrupts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 200
4.16 Clocking and Sample Rates . . . . . . . . . . . . . . . . . . . . . . . 219
4.17 Control Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244
4.18 Control-Write Sequencer . . . . . . . . . . . . . . . . . . . . . . . . . 249
4.19 Charge Pumps, Regulators, and Voltage Reference . . . . 257
4.20 JTAG Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 263
4.21 Short-Circuit Protection . . . . . . . . . . . . . . . . . . . . . . . . . . 263
4.22 Power-On Reset (POR) . . . . . . . . . . . . . . . . . . . . . . . . . . 264
4.23 Hardware Reset, Software Reset, Wake-Up, and
Device ID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 264
5 Applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 267
5.1 Recommended External Components . . . . . . . . . . . . . . . . 267
5.2 Resets Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 274
5.3 Output-Signal Drive-Strength Control . . . . . . . . . . . . . . . . . 274
5.4 Digital Audio Interface Clocking Configurations . . . . . . . . . 276
5.5 PCB Layout Considerations . . . . . . . . . . . . . . . . . . . . . . . . 280
6 Register Map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 281
7 Thermal Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 332
8 Package Dimensions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 333
9 Ordering Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 333
10 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 334
11 Revision History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 334
DS1162F1
CS42L92
1 Pin Descriptions
1 Pin Descriptions
1.1 WLCSP Pinout
A1
A3
A5
A2
B2
B4
CPVDD1
B3
CP2CA
C2
D1
B5
CPGND
C4
CP1C2A
D3
CP1VOUT2P
CP2CB
E2
CPVDD2
E4
F1
CP1C1A
F3
CP1VOUT1N
CP2VOUT
G2
CP1C1B
G4
H1
MICBIAS1B
H3
MICBIAS1C
MICVDD
J2
MICBIAS1D
J4
K1
IN1BLN
K3
IN1BLP
L2
M1
B8
MICDET4/
HPOUTFB4
HPDET2
D11
MICDET3/
HPOUTFB3
D13
JACKDET1
E10
HPDET1
E12
GPSW1N
GPSW2N
F9
MICDET2/
HPOUTFB2
F11
GPSW1P
F13
TDO
G8
GPSW2P
G10
MICDET1/
HPOUTFB1
G12
JACKDET2
MICBIAS2B
H7
CIFMODE
H9
JACKDET3
H11
AGND2
H13
IN1ALN/
DMICCLK1
J6
GPIO2
J8
GPIO1
J10
IRQ
J12
AVDD2
C10
D5
HPOUT4R
D7
MICDET5/
HPOUTFB5
D9
E6
TRST
E8
MICBIAS2A
F7
MICBIAS1A
G6
H5
IN1ALP/
DMICDAT1
K5
AIF3LRCLK/
GPIO16
K7
AIF3TXDAT/
GPIO13
K9
SPKCLK/
GPIO3
K11
RESET
K13
IN1ARN/
DMICCLK3
L4
AIF1TXDAT/
GPIO5
CIFSS
L10
SPKDAT/
GPIO4
L12
SUBGND
IN1ARP/
DMICDAT3
M3
IN2BR
M5
CIFMISO
M9
MCLK3
M11
FLLGND
M13
IN1BR
N2
IN2ARN/
DMICCLK4
N4
SLIMCLK
N10
MCLK2
N12
FLLVDD
P1
IN2ARP/
DMICDAT4
P3
SLIMDAT1
P11
DGND
P13
IN2BL
R2
R10
MCLK1
R12
DCVDD
T1
AGND1
T11
DGND
D8
J3
G7
J5
J7
L3
L5
L7
L6
M4
L8
M6
M8
VREFC
N6
AIF2BCLK/
GPIO10
N8
IN2ALN/
DMICCLK2
P5
AIF1BCLK/
GPIO6
P7
AIF3BCLK/
GPIO14
P9
IN2ALP/
DMICDAT2
R4
DGND
R6
AIF2RXDAT/
GPIO11
R8
CIFSCLK
T3
SUBGND
P2
N5
N7
P4
R3
T2
P6
R5
T4
AVDD1
P8
R7
T6
T8
Digital I/O
M14
N13
P12
R11
T10
AIF1LRCLK/
AIF3RXDAT/
SLIMDAT2
T7
T9
GPIO8
GPIO15
DCVDD
AIF2TXDAT/
CIFMOSI/SDA
GPIO9
Analog I/O
L13
N11
R9
K14
M12
P10
T5
J13
L11
N9
H14
K12
M10
M7
N3
H12
K10
AIF1RXDAT/
GPIO7
F14
G13
J11
L9
AIF2LRCLK/
GPIO12
F12
H10
K8
D14
E13
G11
J9
K6
D12
F10
H8
C13
E11
G9
H6
K4
D10
F8
G5
C11
E9
F6
F5
H4
M2
C9
E7
CP1VOUT1P
F4
K2
NC
C8
C7
D6
G3
R1
HPOUT3R
E5
H2
S1
HPOUT2R
E3
N1
C6
D4
F2
O1
B11
C5
D2
L1
B9
B14
C12
J1
HPOUT3L
B12
HPOUT1R
G1
CP1C2B
B10
B13
E1
B7
A13
A12
HPOUT2L
C3
HPOUT4L
A11
A10
HPOUT1L
C1
Q1
A9
A8
B6
CP1VOUT2N
B1
I1
A7
A6
A4
P14
R13
T12
DBVDD
T14
T13
DGND
Power
Figure 1-1. Top-Down (Through-Package) View—104-Ball WLCSP Package
4
DS1162F1
CS42L92
1.2 Pin Descriptions
1.2 Pin Descriptions
Table 1-1 describes each pin on the CS42L92. Note that pins that share a common name should be tied together on the
printed circuit board (PCB).
Table 1-1. Pin Descriptions
PU = Pull-up, PD = Pull-down, K = Bus keeper, H = Hysteresis on CMOS input, Z = Hi-Z (High impedance), C = CMOS, OD = Open drain.
Pin Name
Pin #
Power
Supply
I/O
Pin Description
Digital Pad
State at Reset 1
Attributes
Analog I/O
CP1C1A
E2
—
O
Charge Pump 1 fly-back capacitor 1 pin
—
—
CP1C1B
F3
—
O
Charge Pump 1 fly-back capacitor 1 pin
—
—
CP1C2A
C2
—
O
Charge Pump 1 fly-back capacitor 2 pin
—
—
CP1C2B
B5
—
O
Charge Pump 1 fly-back capacitor 2 pin
—
—
CP1VOUT1N
E4
—
O
Charge Pump 1 negative output 1 decoupling pin
—
Output
CP1VOUT1P
D5
—
O
Charge Pump 1 positive output 1 decoupling pin
—
Output
CP1VOUT2N
A4
—
O
Charge Pump 1 negative output 2 decoupling pin
—
Output
CP1VOUT2P
C4
—
O
Charge Pump 1 positive output 2 decoupling pin
—
Output
CP2CA
B1
—
O
Charge Pump 2 fly-back capacitor pin
—
Output
CP2CB
D1
—
O
Charge Pump 2 fly-back capacitor pin
—
Output
CP2VOUT
F1
—
O
Charge Pump 2 output decoupling pin/supply for LDO2
—
Output
GPSW1N
D13
—
I/O
General-purpose bidirectional switch 1 contact
—
—
GPSW1P
E12
—
I/O
General-purpose bidirectional switch 1 contact
—
—
GPSW2N
E8
—
I/O
General-purpose bidirectional switch 2 contact
—
—
GPSW2P
F9
—
I/O
General-purpose bidirectional switch 2 contact
—
—
HPDET1
D11
—
I/O
Headphone sense 1 input
—
Input
HPDET2
C10
—
I/O
Headphone sense 2 input
—
Input
HPOUT1L
A12
—
O
Left headphone 1 output
—
Output
HPOUT1R
B11
—
O
Right headphone 1 output
—
Output
HPOUT2L
A10
—
O
Left headphone 2 output
—
Output
HPOUT2R
B9
—
O
Right headphone 2 output
—
Output
HPOUT3L
A8
—
O
Left headphone 3 output
—
Output
HPOUT3R
B7
—
O
Right headphone 3 output
—
Output
HPOUT4L
A6
—
O
Left headphone 4 output
—
Output
HPOUT4R
C6
—
O
Right headphone 4 output
—
Output
IN1ALN/
DMICCLK1
H5
MICVDD or
MICBIASn [2]
I
Left/right-channel negative differential mic/line input/
DMIC Clock Output 1. Also suitable for connection to
external accessory interfaces.
—
IN1ALN input
IN1ALP/
DMICDAT1
J4
MICVDD or
MICBIASn [2]
I
Left-channel single-ended mic/line input/positive
differential mic/line input/DMIC Data Input 1. Also
suitable for connection to external accessory
interfaces.
PD/H
IN1ALP input
IN1ARN/
DMICCLK3
K3
MICVDD or
MICBIASn [2]
I
Right-channel negative differential mic/line input/DMIC
Clock Output 3. Also suitable for connection to external
accessory interfaces.
—
IN1ARN input
IN1ARP/
DMICDAT3
L2
MICVDD or
MICBIASn [2]
I/O
PD/H
IN1ARP input
IN1BLN
J2
MICVDD
I
Negative differential mic/line input. Also suitable for
connection to external accessory interfaces.
—
Input
IN1BLP
K1
MICVDD
I
Single-ended mic/line input/positive differential mic/line
input. Also suitable for connection to external
accessory interfaces.
—
Input
5
Right-channel single-ended mic/line input/positive
differential mic/line input/DMIC Data Input 3. Also
suitable for connection to external accessory
interfaces.
DS1162F1
CS42L92
1.2 Pin Descriptions
Table 1-1. Pin Descriptions (Cont.)
PU = Pull-up, PD = Pull-down, K = Bus keeper, H = Hysteresis on CMOS input, Z = Hi-Z (High impedance), C = CMOS, OD = Open drain.
Pin #
Power
Supply
I/O
IN1BR
M1
MICVDD
I
Right-channel single-ended mic/line input/positive
differential mic/line input.
—
Input
IN2ALN/
DMICCLK2
N4
MICVDD or
MICBIASn [2]
I
Left-channel negative differential mic/line input/DMIC
Clock Output 2. Also suitable for connection to external
accessory interfaces.
—
IN2ALN input
IN2ALP/
DMICDAT2
P3
MICVDD or
MICBIASn [2]
I/O
PD/H
IN2ALP input
IN2ARN/
DMICCLK4
M3
MICVDD or
MICBIASn [2]
I
—
IN2ARN input
IN2ARP/
DMICDAT4
N2
MICVDD or
MICBIASn [2]
I/O
PD/H
IN2ARP input
IN2BL
P1
MICVDD
I
Left-channel single-ended mic/line input
—
Input
IN2BR
L4
MICVDD
I
Right-channel single-ended mic/line input. Also
suitable for connection to external accessory
interfaces.
—
Input
Pin Name
Pin Description
Left-channel single-ended mic/line input/positive
differential mic/line input/DMIC Data Input 2. Also
suitable for connection to external accessory
interfaces.
Right-channel negative differential mic/line input/DMIC
Clock Output 4. Also suitable for connection to external
accessory interfaces.
Right-channel single-ended mic/line input/positive
differential mic/line input/DMIC Data Input 4. Also
suitable for connection to external accessory
interfaces.
Digital Pad
State at Reset 1
Attributes
JACKDET1
D9
AVDD
I
Jack detect input 1
—
Input
JACKDET2
F13
AVDD
I
Jack detect input 2
—
Input
JACKDET3
G10
AVDD
I
Jack detect input 3
—
Input
MICBIAS1A
F5
MICVDD
O
Microphone bias 1A
—
Output
MICBIAS1B
G2
MICVDD
O
Microphone bias 1B
—
Output
MICBIAS1C
G4
MICVDD
O
Microphone bias 1C
—
Output
MICBIAS1D
H3
MICVDD
O
Microphone bias 1D
—
Output
MICBIAS2A
E6
MICVDD
O
Microphone bias 2A
—
Output
MICBIAS2B
G6
MICVDD
O
Microphone bias 2B
—
Output
MICDET1/
HPOUTFB1
F11
—
I/O
Mic/accessory sense input 1/HPOUT ground feedback
pin 1
—
Input
MICDET2/
HPOUTFB2
E10
—
I/O
Mic/accessory sense input 2/HPOUT ground feedback
pin 2
—
Input
MICDET3/
HPOUTFB3
C12
—
I/O
Mic/accessory sense input 3/HPOUT ground feedback
pin 3
—
Input
MICDET4/
HPOUTFB4
B13
—
I/O
Mic/accessory sense input 4/HPOUT ground feedback
pin 4
—
Input
MICDET5/
HPOUTFB5
C8
—
I/O
Mic/accessory sense input 5/HPOUT ground feedback
pin 5
—
Input
MICVDD
H1
—
O
LDO2 output decoupling pin (generated internally by
CS42L92). (Can also be used as reference/supply for
external microphones.)
—
Output
VREFC
M5
—
O
Band-gap reference external capacitor connection
—
Output
AIF1BCLK/
GPIO6
N6
DBVDD
I/O
Audio interface 1 bit clock/GPIO6
PU/PD/K/H/ GPIO6 input with
Z/C/OD
bus-keeper
AIF1LRCLK/
GPIO8
R6
DBVDD
I/O
Audio interface 1 left/right clock/GPIO8
PU/PD/K/H/ GPIO8 input with
Z/C/OD
bus-keeper
AIF1RXDAT/
GPIO7
L6
DBVDD
I/O
Audio interface 1 RX digital audio data/GPIO7
PU/PD/K/H/ GPIO7 input with
C/OD
bus-keeper
AIF1TXDAT/
GPIO5
K5
DBVDD
I/O
Audio interface 1 TX digital audio data/GPIO5
PU/PD/K/H/ GPIO5 input with
Z/C/OD
bus-keeper
Digital I/O
6
DS1162F1
CS42L92
1.2 Pin Descriptions
Table 1-1. Pin Descriptions (Cont.)
PU = Pull-up, PD = Pull-down, K = Bus keeper, H = Hysteresis on CMOS input, Z = Hi-Z (High impedance), C = CMOS, OD = Open drain.
Pin #
Power
Supply
I/O
AIF2BCLK/
GPIO10
M7
DBVDD
I/O
Audio interface 2 bit clock/GPIO10
PU/PD/K/H/
Z/C/OD
GPIO10 input
with bus-keeper
AIF2LRCLK/
GPIO12
K7
DBVDD
I/O
Audio interface 2 left/right clock/GPIO12
PU/PD/K/H/
Z/C/OD
GPIO12 input
with bus-keeper
AIF2RXDAT/
GPIO11
P7
DBVDD
I/O
Audio interface 2 RX digital audio data/GPIO11
PU/PD/K/H/
C/OD
GPIO11 input
with bus-keeper
AIF2TXDAT/
GPIO9
T7
DBVDD
I/O
Audio interface 2 TX digital audio data/GPIO9
PU/PD/K/H/ GPIO9 input with
Z/C/OD
bus-keeper
AIF3BCLK/
GPIO14
N8
DBVDD
I/O
Audio interface 3 bit clock/GPIO14. If the JTAG
interface is configured, this pin provides the TCK input
connection.
PU/PD/K/H/
Z/C/OD
GPIO14 input
with bus-keeper
AIF3LRCLK/
GPIO16
J6
DBVDD
I/O
Audio interface 3 left/right clock/GPIO16
PU/PD/K/H/
Z/C/OD
GPIO16 input
with bus-keeper
AIF3RXDAT/
GPIO15
R8
DBVDD
I/O
Audio interface 3 RX digital audio data/GPIO15. If the
JTAG interface is configured, this pin provides the TDI
input connection.
PU/PD/K/H/
C/OD
GPIO15 input
with bus-keeper
AIF3TXDAT/
GPIO13
J8
DBVDD
I/O
Audio interface 3 TX digital audio data/GPIO13. If the
JTAG interface is configured, this pin provides the TMS
input connection.
PU/PD/K/H/
Z/C/OD
GPIO13 input
with bus-keeper
CIFMISO
L8
DBVDD
O
Control interface (SPI) Master In Slave Out data. The
CIFMISO is high impedance if CIF1SS is not asserted.
Z/C
Output
CIFMOSI/SDA
T9
DBVDD
I/O
Control interface (SPI) Master Out Slave In data/
Control interface (I2C) data input/output.
H/OD
Input
CIFSCLK
P9
DBVDD
I
Control interface clock input
H
Input
CIFSS
K9
DBVDD
I
Control interface (SPI) slave select (SS)
H
Input
CIFMODE
G8
DBVDD
I
Control interface mode select
H
Input
GPIO1
H9
DBVDD
I/O
GPIO1
PU/PD/K/H/ GPIO1 input with
C/OD
bus-keeper
GPIO2
H7
DBVDD
I/O
GPIO2
PU/PD/K/H/ GPIO2 input with
C/OD
bus-keeper
IRQ
H11
DBVDD
O
Interrupt request (IRQ) output (default is active low)
MCLK1
P11
DBVDD
I
Master clock 1
MCLK2
M11
DBVDD
I
Master clock 2
H
Input
MCLK3
L10
DBVDD
I
Master clock 3
H
Input
RESET
J12
DBVDD
I
Digital reset input (active low)
Pin Name
Pin Description
Digital Pad
State at Reset 1
Attributes
C/OD
Output
H
Input
PU/PD/K/H Input with pull-up
SLIMCLK
M9
DBVDD
I/O
SLIMbus clock I/O
H/C
Input
SLIMDAT1
N10
DBVDD
I/O
SLIMbus data I/O
H/C
Input
SLIMDAT2
R10
DBVDD
I/O
SLIMbus data I/O
H/C
Input
SPKCLK/
GPIO3
J10
DBVDD
I/O
Digital speaker (PDM) clock output/GPIO3
PU/PD/K/H/ GPIO3 input with
C/OD
bus-keeper
SPKDAT/
GPIO4
K11
DBVDD
I/O
Digital speaker (PDM) data output/GPIO4
PU/PD/K/H/ GPIO4 input with
C/OD
bus-keeper
TDO
F7
DBVDD
O
JTAG data output
TRST
D7
DBVDD
I
JTAG test access port reset (active low)
AGND1
R2
—
—
Analog ground (return path for AVDD1)
AGND2
G12
—
—
Analog ground (return path for AVDD2)
—
—
AVDD1
T3
—
—
Analog supply
—
—
AVDD2
H13
—
—
Analog supply
—
—
C
Output
PD/H
Input with
pull-down
—
—
Supply
7
DS1162F1
CS42L92
1.2 Pin Descriptions
Table 1-1. Pin Descriptions (Cont.)
PU = Pull-up, PD = Pull-down, K = Bus keeper, H = Hysteresis on CMOS input, Z = Hi-Z (High impedance), C = CMOS, OD = Open drain.
Pin Name
CPGND
Pin #
Power
Supply
I/O
B3
—
—
Pin Description
Digital Pad
State at Reset 1
Attributes
Charge pump ground (return path for CPVDD1,
CPVDD2)
—
—
CPVDD1
A2
—
—
Supply for Charge Pump 1 and Charge Pump 2
—
—
CPVDD2
D3
—
—
Secondary supply for Charge Pump 1
—
—
DBVDD
T11
—
—
Digital buffer (I/O) supply
—
—
DCVDD
P13, T5
—
—
Digital core supply
—
—
N12, P5,
R12, T13
—
—
Digital ground (return path for DCVDD and DBVDD)
—
—
FLLGND
L12
—
—
Analog ground (return path for FLLVDD)
—
—
FLLVDD
M13
—
—
Analog FLL supply
—
—
SUBGND
K13, R4
—
—
Substrate ground
—
—
—
—
DGND
No Connect
NC
T1
—
—
—
1.Note that the default conditions described are not valid if modified by the boot sequence or by a wake-up control sequence.
2.The analog input functions on these pins are referenced to the MICVDD power domain. The digital input/output functions are referenced to the
MICVDD or MICBIASn power domain, as selected by the applicable INx_DMIC_SUP field.
8
DS1162F1
CS42L92
2 Typical Connection Diagram
2 Typical Connection Diagram
1.2 V
AGND1
AGND2
DGND
CPGND
FLLGND
SUBGND
1.8 V
CPVDD2
120
2.2 F
VREFC
CIF1SS
FLLVDD
DCVDD (pin P13)
DCVDD (pin T5)
CIF1SCLK
Control Interface
CIF1MOSI/SDA
CIF1MISO
CIFMODE
4.7 F
2 x 1.0 F
4.7 F
MCLK1
MCLK2
MCLK3
CPVDD1
AVDD1
AVDD2
DBVDD
CS42L92
Master Clocks
RESET
Reset Control
Interrupt Output
IRQ
4.7 F
0.1 F
2 x 1.0 F
GPIO1
GPIO2
SLIMCLK
SLIMDAT1
SLIMbus Interface
SLIMDAT2
GPSW1P
GPSW1N
GPSW2P
GPSW2N
AIF1BCLK
AIF1LRCLK
Audio Interface 1
AIF1RXDAT
CP1C1A
AIF1TXDAT
4.7 F
CP1VOUT1P
AIF2LRCLK
4.7 F
CP1VOUT1N
AIF2RXDAT
CP1C2A
AIF2TXDAT
2.2 F
CP1C2B
AIF3BCLK
4.7 F
CP1VOUT2P
AIF3LRCLK
Audio Interface 3
2.2 F
CP1C1B
AIF2BCLK
Audio Interface 2
GPIO
4.7 F
CP1VOUT2N
AIF3RXDAT
CP2CA
AIF3TXDAT
470 nF
CP2CB
CP2VOUT
MICBIAS1A
Pseudodifferential
Microphone
Connection
4.7 F
MICDET1/HPOUTFB1
2.2 k
1 F
1 F
IN1BLP
IN1ALP/DMICDAT1
IN1BLN
IN1ALN/DMICCLK1
MICDET2/HPOUTFB2
JACKDET1
JACKDET2
JACKDET3
Jack-Detect Inputs
HPOUT1L
Headphone
HPOUT1R
MICDET2/HPOUTFB2
MICBIAS2A
VDD
CHAN
GND
Stereo Digital
Microphone
Connection
VDD
CHAN
GND
DAT
CLK
DMIC
IN1BR
IN1ARP/DMICDAT3
IN1ARN/DMICCLK3
(Note: HPOUT1 ground
connection close to headset jack )
HPDET1
HPDET2
HPOUT2L
Line Output
HPOUT2R
DAT
CLK
DMIC
MICDET3/HPOUTFB3
(Note: HPOUT2 ground
connection close to headset jack )
MICDET4/HPOUTFB4
HPOUT3L
Line Output
HPOUT3R
1 F
IN2BL
IN2ALP/DMICDAT2
IN2ALN/DMICCLK2
Stereo
Single-Ended
Line
Connection
HPOUT4L
HPOUT4R
IN2BR
MICDET5/HPOUTFB5
IN2ARP/DMICDAT4
IN2ARN/DMICCLK4
1 F
Analog and Digital Inputs
MICBIAS1A
MICBIAS1B
MICBIAS1C
MICBIAS1D
MICBIAS2A
MICBIAS2B
Bias/Supplies for
Microphones and External
Accessory Detection
SPKCLK
SPKDAT
Earpiece
Speaker
Outputs HPOUT1–HPOUT4 can
be configured as stereo pairs or
differential mono.
Digital Speaker
(PDM) interface
MICVDD
4.7 F
TRST
Figure 2-1. Typical Connection Diagram
9
DS1162F1
CS42L92
3 Characteristics and Specifications
3 Characteristics and Specifications
Table 3-1 defines parameters as they are characterized in this section.
Table 3-1. Parameter Definitions
Parameter
Channel separation
Common-mode rejection
ratio (CMRR)
Dynamic range (DR)
Power-supply rejection
ratio (PSRR)
Signal-to-noise ratio
(SNR)
Total harmonic distortion
(THD)
Total harmonic distortion
plus noise (THD+N)
Definition
Left-to-right and right-to-left channel separation is the difference in level between the active channel (driven to
maximum full scale output) and the measured signal level in the idle channel at the test signal frequency. The active
channel is configured and supplied with an appropriate input signal to drive a full scale output, with signal measured
at the output of the associated idle channel.
The ratio of a specified input signal (applied to both sides of a differential input), relative to the output signal that
results from it.
A measure of the difference between the maximum full scale output signal and the sum of all harmonic distortion
products plus noise, with a low-level input signal applied. Typically, an input signal level 60 dB below full scale is
used.
The ratio of a specified power supply variation relative to the output signal that results from it. PSRR is measured
under quiescent signal path conditions.
A measure of the difference in level between the maximum full scale output signal and the output with no input signal
applied.
The ratio of the RMS sum of the harmonic distortion products in the specified bandwidth 1 relative to the RMS
amplitude of the fundamental (i.e., test frequency) output.
The ratio of the RMS sum of the harmonic distortion products plus noise in the specified bandwidth 1 relative to the
RMS amplitude of the fundamental (i.e., test frequency) output.
1.All performance measurements are specified with a 20-kHz, low-pass brick-wall filter and, where noted, an A-weighted filter. The low-pass filter
removes out-of-band noise.
Table 3-2. 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.
Parameter
Symbol
Minimum
Maximum
DCVDD [1], FLLVDD [1]
–0.3 V
1.6 V
AVDD [2], CPVDD1, CPVDD2
–0.3 V
2.5 V
DBVDD, MICVDD
–0.3 V
5.0 V
Voltage range digital inputs
DBVDD domain
—
SUBGND – 0.3 V
DBVDD + 0.3 V
DMICDAT1–DMICDAT2
—
SUBGND – 0.3 V
MICVDD + 0.3 V
SUBGND – 0.3 V
MICVDD + 0.3 V
Voltage range analog inputs
IN1ARx, IN2Axx, IN2Bx
SUBGND – 0.9 V
MICVDD + 0.3 V
IN1ALx, IN1BLx, IN1BR
SUBGND – 0.3 V
MICVDD + 0.3 V
MICDETn 3
HPOUTFBn 3
SUBGND – 0.3 V
SUBGND + 0.3 V
JACKDET1, HPDET1, HPDET2
CP1VOUT2N – 0.3 V [5]
AVDD + 0.3 V
SUBGND – 0.3 V
JACKDET2 [4], JACKDET3 [4]
MICVDD + 0.3 V
GPSWnP, GPSWnN
SUBGND – 0.3 V
MICVDD + 0.3 V
SUBGND – 0.3V
SUBGND + 0.3V
Ground
AGND 6, DGND, CPGND, FLLGND
Operating temperature range
TA
–40ºC
+85ºC
–40ºC
+125ºC
Operating junction temperature
TJ
Storage temperature after soldering
—
–65ºC
+150ºC
ESD-sensitive device. The CS42L92 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. This device is qualified
to current JEDEC ESD standards.
Supply voltages
1.The DCVDD and FLLVDD pins should be tied to a common supply rail. The associated power domain is referred to as DCVDD.
2.The AVDD1 and AVDD2 pins should be tied together. The associated power domain is referred to as AVDD.
3.The MICDETn and HPOUTFBn functions share common pins. The absolute maximum rating varies according to the applicable function of each pin.
The HPOUTFBn ratings are applicable if any of the HPn_GND_SEL bits select the respective pin for HPOUT ground feedback.
4.If AVDD > MICVDD (e.g., if LDO2 is disabled), the maximum JACKDET2/JACKDET3 voltage is AVDD + 0.3 V.
5.CP1VOUT2N is an internal supply, generated by the CS42L92 charge pump (CP1). Its voltage can vary between CPGND and –CPVDD1.
6.The AGND1 and AGND2 pins should be tied together. The associated ground domain is referred to as AGND.
10
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-3. Recommended Operating Conditions
Parameter
Digital supply range 1
Digital supply range
Charge pump supply range
Symbol
Minimum Typical
DCVDD [2], FLLVDD [3]
1.14
1.2
DBVDD
1.71
—
CPVDD1
1.71
1.8
CPVDD2
1.14
1.2
AVDD
1.71
1.8
Analog supply range 5,6
Mic bias supply 7
MICVDD
0.9
2.5
Ground 8
DGND, AGND, CPGND, FLLGND, SUBGND
—
0
Power supply rise time 9,10
DCVDD
10
—
All other supplies
10
—
–40
—
Operating temperature range
TA
Note: There are no power sequencing requirements; the supplies may be enabled and disabled in any order.
Core and FLL
I/O
CPVDD1
CPVDD2
Maximum
1.26
3.6 [4]
1.89
1.26
1.89
3.78
—
2000
—
85
Units
V
V
V
V
V
V
V
s
s
ºC
1.The DCVDD and FLLVDD pins should be tied to a common supply rail. The associated power domain is referred to as DCVDD.
2.Sleep mode is supported for when DCVDD is below the limits noted, provided that AVDD and DBVDD are present.
3.It is recommended to connect a 120- resistor in series with the FLLVDD pin connection. Note that the minimum voltage limit applies at the supply
end of the 120- resistor in this case.
4.If the SLIMbus interface is enabled, the maximum DBVDD voltage is 1.98 V.
5.The AVDD1 and AVDD2 pins should be tied together. The associated power domain is referred to as AVDD.
6.The AGND1 and AGND2 pins should be tied together. The associated ground domain is referred to as AGND.
7.An internal charge pump and LDO (powered by CPVDD1) provide the mic bias supply; the MICVDD pin must not be connected to an external supply.
8.The impedance between DGND, AGND, CPGND, FLLGND, and SUBGND must not exceed 0.1 .
9.If the DCVDD rise time exceeds 2 ms, RESET must be asserted during the rise and held asserted until after DCVDD is within the recommended
operating limits.
10.The specified minimum power supply rise times assume a minimum decoupling capacitance of 100 nF per pin. However, Cirrus Logic strongly
advises that the recommended decoupling capacitors are present on the PCB and that appropriate layout guidelines are observed. The specified
minimum power supply rise times also assume a maximum PCB inductance of 10 nH between decoupling capacitor and pin.
Table 3-4. Analog Input Signal Level—IN1xx, IN2xx
Test conditions (unless specified otherwise): AVDD = 1.8V; with the exception of the condition noted, the following electrical characteristics are valid
across the full range of recommended operating conditions.
Parameter
Minimum Typical
Maximum
Units
Full-scale input signal level (0 dBFS output)
Single-ended PGA input, 0 dB PGA gain
—
0.5
—
VRMS
dBV
—
–6
—
Differential PGA input, 0 dB PGA gain
—
1
—
VRMS
dBV
—
0
—
Notes:
• The full-scale input signal level is also the maximum analog input level, before clipping occurs.
• The maximum input signal level is reduced by 6 dB if mid-power operation is selected (INn_OSR = 100); the maximum signal level
corresponds to –6 dBFS at the respective ADC outputs in this case.
• The full-scale input signal level changes in proportion with AVDD. For differential input, it is calculated as AVDD / 1.8.
• A 1.0VRMS differential signal equates to 0.5VRMS/–6dBV per input.
• A sinusoidal input signal is assumed.
Table 3-5. Analog Input Pin Characteristics
Test conditions (unless specified otherwise): TA = +25ºC; with the exception of the condition noted, the following electrical characteristics are valid across
the full range of recommended operating conditions.
Input resistance
Input capacitance
Parameter
Minimum
Single-ended PGA input, All PGA gain settings
9
Differential PGA input, All PGA gain settings
17
—
Typical
11
22
—
Maximum
—
—
5
Units
k
k
pF
Typical
0
31
1
Maximum
—
—
—
Units
dB
dB
dB
Table 3-6. Analog Input Gain—Programmable Gain Amplifiers (PGAs)
The following electrical characteristics are valid across the full range of recommended operating conditions.
Parameter
Minimum programmable gain
Maximum programmable gain
Programmable gain step size
11
Minimum
—
—
Guaranteed monotonic
—
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-7. Digital Input Signal Level—DMICDATn
The following electrical characteristics are valid across the full range of recommended operating conditions.
Parameter
Full-scale input level 1
0 dBFS digital core input, 0 dB gain
Minimum
—
Typical
–6
Maximum
—
Units
dBFS
1. The digital input signal level is measured in dBFS, where 0 dBFS is a signal level equal to the full-scale range (FSR) of the PDM input. The
FSR is defined as the amplitude of a 1-kHz sine wave whose positive and negative peaks are represented by the maximum and minimum
digital codes respectively—this is the largest 1-kHz sine wave that can fit in the digital output range without clipping.
Table 3-8. Output Characteristics
The following electrical characteristics are valid across the full range of recommended operating conditions.
Parameter
Minimum
Line/headphone/earpiece Load resistance
Normal operation, Single-Ended Mode
6
output driver (HPOUTnL,
Normal operation, Differential (BTL) Mode
15
HPOUTnR)
Device survival with load applied indefinitely
0
Load capacitance
Single-Ended Mode
—
Differential (BTL) Mode
—
0 dBFS digital core output, 0 dB gain
—
Digital speaker output
Full-scale output level 1
(SPKDAT)
Typical
—
—
—
—
—
–6
Maximum
—
—
—
500
200
—
Units
pF
pF
dBFS
1.The digital output signal level is measured in dBFS, where 0 dBFS is a signal level equal to the full-scale range (FSR) of the PDM output.
The FSR is defined as the amplitude of a 1-kHz sine wave whose positive and negative peaks are represented by the maximum and
minimum digital codes respectively—this is the largest 1-kHz sine wave that can fit in the digital output range without clipping.
Table 3-9. Input/Output Path Characteristics
Test conditions (unless specified otherwise): DBVDD = CPVDD1 = AVDD = 1.8 V, DCVDD = FLLVDD = CPVDD2 = 1.2 V; MICVDD = 3.1 V (powered
from internal LDO); TA = +25ºC; 1 kHz sinusoid signal; Fs = 48 kHz; PGA gain = 0 dB, 24-bit audio data.
Parameter
Line/headphone/earpiece output DC offset at Load
Single-ended mode
driver (HPOUTnL, HPOUTnR)
Differential (BTL) mode
Analog input paths (IN1xx,
SNR (A-weighted), defined in Table 3-1
20 Hz to 20 kHz, 48 kHz sample rate
IN2xx) to ADC (Differential Input
20 Hz to 8 kHz, 16 kHz sample rate
Mode)
THD, defined in Table 3-1
–1 dBV input
THD+N, defined in Table 3-1
–1 dBV input
Channel separation (L/R), defined in Table 3-1
100 Hz to 10 kHz
Input-referred noise floor
A-weighted, PGA gain = +20 dB
CMRR, defined in Table 3-1
PGA gain = +30 dB
PGA gain = 0 dB
PSRR (DBVDD, CPVDD1, AVDD), defined
100 mV (peak-peak) 217 Hz
in Table 3-1
100 mV (peak-peak) 10 kHz
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
Analog input paths (IN1xx,
SNR (A-weighted), defined in Table 3-1
20 Hz to 20 kHz, 48 kHz sample rate
IN2xx) to ADC (Single-Ended
20 Hz to 8 kHz, 16 kHz sample rate
Input Mode)
THD, defined in Table 3-1
–7dB V input
THD+N, defined in Table 3-1
–7dB V input
Channel separation (L/R), defined in Table 3-1
100 Hz to 10 kHz
Input-referred noise floor
A-weighted, PGA gain = +20 dB
PSRR (DBVDD, CPVDD1, AVDD), defined
100 mV (peak-peak) 217 Hz
in Table 3-1
100 mV (peak-peak) 10 kHz
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
12
Min
—
—
91
—
—
—
—
—
—
—
—
—
—
—
87
—
—
—
—
—
—
—
—
—
Typ Max Units
50
—
V
75
—
V
99
—
dB
104 —
dB
–87 —
dB
–88 –79
dB
109 —
dB
2.6 — VRMS
83
—
dB
72
—
dB
99
—
dB
84
—
dB
100 —
dB
82
—
dB
98
—
dB
108 —
dB
–84 —
dB
–83 –78
dB
107 —
dB
4
— VRMS
76
—
dB
52
—
dB
96
—
dB
87
—
dB
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-9. Input/Output Path Characteristics (Cont.)
Test conditions (unless specified otherwise): DBVDD = CPVDD1 = AVDD = 1.8 V, DCVDD = FLLVDD = CPVDD2 = 1.2 V; MICVDD = 3.1 V (powered
from internal LDO); TA = +25ºC; 1 kHz sinusoid signal; Fs = 48 kHz; PGA gain = 0 dB, 24-bit audio data.
Analog input paths (IN1xx,
IN2xx) to ADC (Differential
Input, Mid Power Mode)
DAC to line output (HPOUT1x,
HPOUT2x; Load = 10 k,
50 pF)
DAC to headphone output
(HPOUT1x, HPOUT2x;
RL = 32 )
DAC to headphone output
(HPOUT1x, HPOUT2x;
RL = 16 )
DAC to headphone output
(HPOUT1L+HPOUT1R,
HPOUT2L+HPOUT2R; Stereo
differential output, RL = 32
BTL)
13
Parameter
SNR, defined in Table 3-1
THD, defined in Table 3-1
THD+N, defined in Table 3-1
Channel separation (L/R), defined in Table 3-1
Input-referred noise floor
CMRR, defined in Table 3-1
PSRR (DBVDD, CPVDD1, AVDD), defined
in Table 3-1
PSRR (DCVDD, FLLVDD, CPVDD2),
defined in Table 3-1
Full-scale output signal level
A-weighted
–7 dBV input
–7 dBV input
100 Hz to 10 kHz
A-weighted, PGA gain = +20 dB
PGA gain = +30 dB
PGA gain = 0 dB
100 mV (peak-peak) 217 Hz
100 mV (peak-peak) 10 kHz
100 mV (peak-peak) 217 Hz
100 mV (peak-peak) 10 kHz
0 dBFS input
SNR, defined in Table 3-1
A-weighted, output signal = 1 VRMS
Dynamic range, defined in Table 3-1
A-weighted, –60 dBFS input
THD+N, defined in Table 3-1
0 dBFS input
Channel separation (L/R), defined in Table 3-1
100 Hz to 10 kHz
Output noise floor
A-weighted
PSRR (DBVDD, CPVDD1, AVDD),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
Maximum output power
0.1% THD+N
SNR, defined in Table 3-1
A-weighted, output signal = 1 VRMS
Dynamic range, defined in Table 3-1
A-weighted, –60 dBFS input
THD+N, defined in Table 3-1
PO = 20 mW
THD+N, defined in Table 3-1
PO = 2 mW
Channel separation (L/R), defined in Table 3-1
100 Hz to 10 kHz
Output noise floor
A-weighted
PSRR (DBVDD, CPVDD1, AVDD),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
Maximum output power
0.1% THD+N
SNR, defined in Table 3-1
A-weighted, output signal = 1 VRMS
Dynamic range, defined in Table 3-1
A-weighted, –60 dBFS input
THD+N, defined in Table 3-1
PO = 20 mW
THD+N, defined in Table 3-1
PO = 2 mW
Channel separation (L/R), defined in Table 3-1
100 Hz to 10 kHz
Output noise floor
A-weighted
PSRR (DBVDD, CPVDD1, AVDD),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
Maximum output power
0.1% THD+N
SNR, defined in Table 3-1
A-weighted, output signal = 2 VRMS
Dynamic range, defined in Table 3-1
A-weighted, –60 dBFS input
THD+N, defined in Table 3-1
PO = 75 mW
THD+N, defined in Table 3-1
PO = 5 mW
Output noise floor
A-weighted
PSRR (DBVDD, CPVDD1, AVDD),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz
defined in Table 3-1
100 mV (peak-peak) 10 kHz
Min
—
—
—
—
—
—
—
—
—
—
—
—
—
—
108
—
—
—
—
—
—
—
—
—
108
—
—
—
—
—
—
—
—
—
—
108
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
Typ
88
–81
–80
96
4.79
73
81
93
75
97
81
1
0
125
117
–100
95
0.7
105
81
108
81
33
125
117
–100
–96
105
0.6
126
103
128
105
46
125
117
–97
–95
97
0.6
127
107
127
108
109
127
115
–100
–97
0.36
120
90
120
90
Max
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
–90
—
—
—
—
—
—
—
—
—
–90
—
—
—
—
—
—
—
—
—
—
–90
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
Units
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
dB
dB
VRMS
dBV
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
mW
dB
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
mW
dB
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
mW
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-9. Input/Output Path Characteristics (Cont.)
Test conditions (unless specified otherwise): DBVDD = CPVDD1 = AVDD = 1.8 V, DCVDD = FLLVDD = CPVDD2 = 1.2 V; MICVDD = 3.1 V (powered
from internal LDO); TA = +25ºC; 1 kHz sinusoid signal; Fs = 48 kHz; PGA gain = 0 dB, 24-bit audio data.
DAC to line output (HPOUT3x,
HPOUT4x; Load = 10 k,
50 pF)
DAC to headphone output
(HPOUT3x, HPOUT4x;
RL = 32 )
DAC to headphone output
(HPOUT3x, HPOUT4x;
RL = 16 )
DAC to earpiece output
(HPOUT3L+HPOUT3R,
HPOUT4L+HPOUT4R, Mono
Mode, RL = 32 BTL)
14
Parameter
Full-scale output signal level
Min
0 dBFS input —
—
SNR, defined in Table 3-1
A-weighted, output signal = 1 VRMS 115
Dynamic range, defined in Table 3-1
A-weighted, –60 dBFS input 107
THD, defined in Table 3-1
0 dBFS input —
THD+N, defined in Table 3-1
0 dBFS input —
Channel separation (L/R), defined in Table 3-1
100 Hz to 10 kHz —
Output noise floor
A-weighted —
PSRR (DBVDD, CPVDD1, AVDD),
100 mV (peak-peak) 217 Hz —
defined in Table 3-1
100 mV (peak-peak) 10 kHz —
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz —
defined in Table 3-1
100 mV (peak-peak) 10 kHz —
Maximum output power
0.1% THD+N —
SNR, defined in Table 3-1
A-weighted, output signal = 1 VRMS —
Dynamic range, defined in Table 3-1
A-weighted, –60 dBFS input 107
THD, defined in Table 3-1
PO = 20 mW —
THD+N, defined in Table 3-1
PO = 20 mW —
THD, defined in Table 3-1
PO = 2 mW —
THD+N, defined in Table 3-1
PO = 2 mW —
Channel separation (L/R), defined in Table 3-1
100 Hz to 10 kHz —
Output noise floor
A-weighted —
PSRR (DBVDD, CPVDD1, AVDD),
100 mV (peak-peak) 217 Hz —
defined in Table 3-1
100 mV (peak-peak) 10 kHz —
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz —
defined in Table 3-1
100 mV (peak-peak) 10 kHz —
Maximum output power
0.1% THD+N —
SNR, defined in Table 3-1
A-weighted, output signal = 1 VRMS —
Dynamic range, defined in Table 3-1
A-weighted, –60 dBFS input 107
THD, defined in Table 3-1
PO = 20 mW —
THD+N, defined in Table 3-1
PO = 20 mW —
THD, defined in Table 3-1
PO = 2 mW —
THD+N, defined in Table 3-1
PO = 2 mW —
Channel separation (L/R), defined in Table 3-1
100 Hz to 10 kHz —
Output noise floor
A-weighted —
PSRR (DBVDD, CPVDD1, AVDD),
100 mV (peak-peak) 217 Hz —
defined in Table 3-1
100 mV (peak-peak) 10 kHz —
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz —
defined in Table 3-1
100 mV (peak-peak) 10 kHz —
Maximum output power
0.1% THD+N —
SNR, defined in Table 3-1
A-weighted, output signal = 2 VRMS —
Dynamic range, defined in Table 3-1
A-weighted, –60 dBFS input 110
THD, defined in Table 3-1
PO = 75 mW —
THD+N, defined in Table 3-1
PO = 75 mW —
THD, defined in Table 3-1
PO = 5 mW —
THD+N, defined in Table 3-1
PO = 5 mW —
Output noise floor
A-weighted —
PSRR (DBVDD, CPVDD1, AVDD),
100 mV (peak-peak) 217 Hz —
defined in Table 3-1
100 mV (peak-peak) 10 kHz —
PSRR (DCVDD, FLLVDD, CPVDD2),
100 mV (peak-peak) 217 Hz —
defined in Table 3-1
100 mV (peak-peak) 10 kHz —
Typ
1
0
125
115
–92
–91
90
0.63
110
78
99
69
33
124
115
–93
–90
–94
–92
102
0.63
127
100
120
95
46
124
115
–94
–89
–91
–89
100
0.63
128
104
125
97
115
129
120
–99
–97
–98
–94
0.36
127
106
125
101
Max
—
—
—
—
—
–85
—
—
—
—
—
—
—
—
—
—
–85
—
—
—
—
—
—
—
—
—
—
—
—
–80
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
Units
VRMS
dBV
dB
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
mW
dB
dB
dB
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
mW
dB
dB
dB
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
mW
dB
dB
dB
dB
dB
dB
VRMS
dB
dB
dB
dB
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-9. Input/Output Path Characteristics (Cont.)
Test conditions (unless specified otherwise): DBVDD = CPVDD1 = AVDD = 1.8 V, DCVDD = FLLVDD = CPVDD2 = 1.2 V; MICVDD = 3.1 V (powered
from internal LDO); TA = +25ºC; 1 kHz sinusoid signal; Fs = 48 kHz; PGA gain = 0 dB, 24-bit audio data.
DAC to earpiece output
(HPOUT3L+HPOUT3R,
HPOUT4L+HPOUT4R, Mono
Mode, RL = 16 BTL)
Parameter
Maximum output power
SNR, defined in Table 3-1
Dynamic range, defined in Table 3-1
THD, defined in Table 3-1
THD+N, defined in Table 3-1
THD, defined in Table 3-1
THD+N, defined in Table 3-1
Output noise floor
PSRR (DBVDD, CPVDD1, AVDD),
defined in Table 3-1
PSRR (DCVDD, FLLVDD, CPVDD2),
defined in Table 3-1
0.1% THD+N
A-weighted, output signal = 2 VRMS
A-weighted, –60 dBFS input
PO = 75 mW
PO = 75 mW
PO = 5 mW
PO = 5 mW
A-weighted
100 mV (peak-peak) 217 Hz
100 mV (peak-peak) 10 kHz
100 mV (peak-peak) 217 Hz
100 mV (peak-peak) 10 kHz
Min
—
—
110
—
—
—
—
—
—
—
—
—
Typ Max Units
138 —
mW
128 —
dB
120 —
dB
–97 —
dB
–95 —
dB
–96 —
dB
–94 —
dB
0.4 — VRMS
125 —
dB
106 —
dB
125 —
dB
101 —
dB
Table 3-10. Digital Input/Output
The following electrical characteristics are valid across the full range of recommended operating conditions.
Digital I/O (except
DMICDATn and
DMICCLKn) 1,2
DMIC I/O
(DMICDATn and
DMICCLKn) 2,3
GPIOn
Parameter
Input HIGH level
Minimum
VDBVDD = 1.71–1.98 V 0.75 DBVDD
VDBVDD = 2.5 V ±10% 0.8 DBVDD
VDBVDD = 3.3 V ±10% 0.7 DBVDD
—
Input LOW level
VDBVDD = 1.71–1.98 V
VDBVDD = 2.5 V ±10%
—
VDBVDD = 3.3 V ±10%
—
VDBVDD = 1.71–1.98 V 0.75 DBVDD
Output HIGH level
VDBVDD = 2.5 V ±10% 0.65 DBVDD
(IOH = 1 mA)
VDBVDD = 3.3 V ±10% 0.7 DBVDD
VDBVDDn = 1.71–1.98 V
—
Output LOW level
VDBVDDn = 2.5 V ±10%
—
(IOL = 1mA)
VDBVDDn = 3.3 V ±10%
—
Input capacitance
—
Input leakage
–10
Pull-up/pull-down resistance (where applicable)
35
DMICDATn input HIGH level
0.65 VSUP
DMICDATn input LOW level
—
DMICCLKn output HIGH level
IOH = 1 mA
0.8 VSUP
—
DMICCLKn output LOW level
IOL = –1 mA
Input capacitance
—
Input leakage
–1
Clock output frequency
GPIO pin as OPCLK or FLL output
—
Typical
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
25
—
—
Maximum
—
—
—
0.3 DBVDD
0.25 DBVDD
0.2 DBVDD
—
—
—
0.25 DBVDD
0.3 DBVDD
0.15 DBVDD
5
10
55
—
0.35 VSUP
—
0.2 VSUP
1
50
Units
V
V
V
V
V
V
V
V
V
V
V
V
pF
A
k
V
V
V
V
pF
A
MHz
1.Digital I/O is referenced to DBVDD.
2.Note that digital input pins should not be left unconnected or floating.
3.DMICDATn and DMICCLKn are referenced to a selectable supply, VSUP, according to the INn_DMIC_SUP fields.
15
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-11. Miscellaneous Characteristics
Test conditions (unless specified otherwise): DBVDD = CPVDD1 = AVDD = 1.8 V, DCVDD = FLLVDD = CPVDD2 = 1.2 V; MICVDD = 3.1 V (powered
from internal LDO); TA = +25ºC; 1 kHz sinusoid signal; Fs = 48 kHz; PGA gain = 0 dB, 24-bit audio data.
Parameter
Microphone bias Minimum bias voltage 2
Maximum bias voltage
(MICBIASnx) 1
Bias voltage output step size
Bias voltage accuracy
Regulator Mode (MICBn_BYPASS = 0), VMICVDD – VMICBIAS >200 mV
Bias current 3
Bypass Mode (MICBn_BYPASS = 1)
Output noise density
Regulator Mode (MICBn_BYPASS = 0), MICBn_LVL = 0x4,
Load current = 1 mA, Measured at 1 kHz
Integrated noise voltage
Regulator Mode (MICBn_BYPASS = 0), MICBn_LVL = 0x4,
Load current = 1 mA, 100 Hz to 7 kHz, A-weighted
PSRR (DBVDD, CPVDD1, AVDD), defined in Table 3-1
100 mV (peak-peak) 217 Hz
100 mV (peak-peak) 10 kHz
PSRR (DCVDD, FLLVDD, CPVDD2), defined in Table 3-1
100 mV (peak-peak) 217 Hz
100 mV (peak-peak) 10 kHz
Regulator Mode (MICBn_BYPASS = 0), MICBn_EXT_CAP = 0
Load capacitance 3
Regulator Mode (MICBn_BYPASS = 0), MICBn_EXT_CAP = 1
Output discharge resistance
MICBnx_ENA = 0, MICBnx_DISCH = 1
Switch closed, I = 1 mA
General-purpose Switch resistance
Switch open
switch 4
External
Headphone detection load impedance range:
HPD_IMPEDANCE_RANGE = 00
Accessory
Detection via HPDET1 (HPD_SENSE_
HPD_IMPEDANCE_RANGE = 01
Detect
SEL = 0100) or HPDET2 (HPD_SENSE_
HPD_IMPEDANCE_RANGE = 10
SEL = 0101)
HPD_IMPEDANCE_RANGE = 11
Headphone detection load impedance range:
Detection via MICDETn or JACKDETn pins
Headphone detection accuracy:
HPD_IMPEDANCE_RANGE = 01 or 10
(HPD_DACVAL, HPDETn pin)
HPD_IMPEDANCE_RANGE = 00 or 11
Headphone detection accuracy (HPD_LVL, MICDETn or JACKDETn pin)
for MICDn_LVL[0] = 1
Microphone impedance detection range:
for MICDn_LVL[1] = 1
(MICDn_ADC_MODE = 0, 2.2 k ±2% MICBIAS resistor. 5)
for MICDn_LVL[2] = 1
for MICDn_LVL[3] = 1
for MICDn_LVL[8] = 1
Jack-detection input threshold voltage
Detection on JACKDET1, Jack insertion
(JACKDETn)
Detection on JACKDET1, Jack removal
Detection on JACKDET2/3, Jack insertion
Detection on JACKDET2/3, Jack removal
MICVDD Charge Output voltage
Pump and
Programmable output voltage step size
LDO2_VSEL = 0x00–0x14 (0.9–1.4V )
Regulator (CP2
LDO2_VSEL = 0x14 to 0x27 (1.4 V–3.3 V)
and LDO2)
Maximum output current
Start-up time
4.7 F on MICVDD
Frequency-Lock Output frequency
ed Loop (FLL1, Lock Time
FREF = 32 kHz, FFLL = 49.152 MHz
FLL2)
FREF = 12 MHz, FFLL = 49.152 MHz
RESET pin input RESET input pulse width 6
Min
—
—
—
–5%
—
—
—
Typ
1.5
2.8
0.1
—
—
—
50
—
4
Max Units
—
V
—
V
—
V
+5%
V
2.4
mA
5.0
mA
— nV/Hz
—
VRMS
—
105
—
—
95
—
—
99
—
—
92
—
—
—
50
0.1
1.0
10
—
2
—
—
40
—
—
100
—
4
—
30
8
—
100
100
—
1000
1000 — 10000
400
—
6000
dB
dB
dB
dB
pF
F
k
M
–5
—
+5
–10
—
+10
–20
—
+20
0
—
70
110
—
180
210
—
290
360
—
680
1000 — 30000
—
0.9
—
— 1.65
—
— 0.27
—
—
0.9
—
0.9
2.7
3.3
—
25
—
—
100
—
—
8
—
—
1.0
2.5
45
—
50
—
5
—
—
1
—
1
—
—
%
%
%
V
V
V
V
V
mV
mV
mA
ms
MHz
ms
ms
s
1.No capacitor on MICBIASnx. In Regulator Mode, it is required that VMICVDD – VMICBIAS > 200 mV.
2.Regulator Mode (MICBn_BYPASS = 0), Load current 1.0 mA.
3.Bias current and load capacitance specifications are per MICBIAS generator (MICBIAS1 or MICBIAS2).
4.The GPSWnN pin voltage must not exceed GPSWnP + 0.3 V. See Table 3-2 for voltage limits applicable to the GPSWnP and GPSWnN pins.
5.These characteristics assume no other component is connected to MICDETn.
6.To trigger a hardware reset, the RESET input must be asserted for longer than this duration.
16
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-12. Device Reset Thresholds
The following electrical characteristics are valid across the full range of recommended operating conditions.
Parameter
Symbol
Minimum
Typical
Maximum Units
VAVDD
—
—
1.66
V
VAVDD rising
VAVDD falling
1.06
—
1.44
V
VDCVDD
—
—
1.04
V
DCVDD reset threshold
VDCVDD rising
VDCVDD falling
0.49
—
0.70
V
VDBVDD
—
—
1.66
V
DBVDD Reset threshold
VDBVDD rising
VDBVDD falling
1.06
—
1.44
V
Note: The reset thresholds are derived from simulations only, across all operational and process corners. Device performance is not assured
outside the voltage ranges defined in Table 3-3.
AVDD reset threshold
Table 3-13. System Clock and Frequency-Locked Loop (FLL)
The following timing information is valid across the full range of recommended operating conditions.
Parameter
Minimum
MCLK as input to FLL, FLLn_REFCLK_DIV = 00
74
MCLK as input to FLL, FLLn_REFCLK_DIV = 01
37
MCLK as input to FLL, FLLn_REFCLK_DIV = 10
18
MCLK as input to FLL, FLLn_REFCLK_DIV = 11
12.5
MCLK as direct SYSCLK or ASYNCCLK source
40
MCLK duty cycle
MCLK as input to FLL
80:20
MCLK as direct SYSCLK or ASYNCCLK source
60:40
Frequency-locked FLL input frequency
FLLn_REFCLK_DIV = 00
0.032
loop (FLL1, FLL2)
FLLn_REFCLK_DIV = 01
0.064
FLLn_REFCLK_DIV = 11
0.128
FLLn_REFCLK_DIV = 11
0.256
Internal clocking
SYSCLK frequency
SYSCLK_FREQ = 000, SYSCLK_FRAC = 0
–1%
SYSCLK_FREQ = 000, SYSCLK_FRAC = 1
–1%
SYSCLK_FREQ = 001, SYSCLK_FRAC = 0
–1%
SYSCLK_FREQ = 001, SYSCLK_FRAC = 1
–1%
SYSCLK_FREQ = 010, SYSCLK_FRAC = 0
–1%
SYSCLK_FREQ = 010, SYSCLK_FRAC = 1
–1%
SYSCLK_FREQ = 011, SYSCLK_FRAC = 0
–1%
SYSCLK_FREQ = 011, SYSCLK_FRAC = 1
–1%
SYSCLK_FREQ = 100, SYSCLK_FRAC = 0
–1%
SYSCLK_FREQ = 100, SYSCLK_FRAC = 1
–1%
–1%
ASYNCCLK frequency
ASYNC_CLK_FREQ = 000
–1%
ASYNC_CLK_FREQ = 001
–1%
–1%
ASYNC_CLK_FREQ = 010
–1%
–1%
ASYNC_CLK_FREQ = 011
–1%
–1%
ASYNC_CLK_FREQ = 100
–1%
–1%
DSPCLK frequency
5
Master clock
MCLK cycle time
timing (MCLK1,
MCLK2, MCLK3) 1
Typical
—
—
—
—
—
—
—
—
—
—
—
6.144
5.6448
12.288
11.2896
24.576
22.5792
49.152
45.1584
98.304
90.3168
6.144
5.6448
12.288
11.2896
24.576
22.5792
49.152
45.1584
98.304
90.3168
—
Maximum
—
—
—
—
—
20:80
40:60
13
26
52
80
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
+1%
150
Units
ns
ns
ns
ns
ns
%
%
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
MHz
1.If MCLK1, MCLK2, or MCLK3 is selected as a source for SYSCLK or ASYNCCLK (either directly or via one of the FLLs), the frequency must be
within 1% of the applicable SYSCLK_FREQ or ASYNC_CLK_FREQ setting.
17
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-14. Digital Microphone (DMIC) Interface Timing
The following timing information is valid across the full range of recommended operating conditions.
Parameter 1
Symbol
Minimum
Typical
Maximum Units
DMICCLKn cycle time
tCY
160
163
1432
ns
DMICCLKn duty cycle
—
45
—
55
%
DMICCLKn rise/fall time (25-pF load, 1.8-V supply)
tr, tf
5
—
30
ns
DMICDATn (left) setup time to falling DMICCLK edge
tLSU
15
—
—
ns
DMICDATn (left) hold time from falling DMICCLK edge
tLH
0
—
—
ns
DMICDATn (right) setup time to rising DMICCLK edge
tRSU
15
—
—
ns
DMICDATn (right) hold time from rising DMICCLK edge
tRH
0
—
—
ns
Note: The voltage reference for the DMIC interfaces is selectable, using the INn_DMIC_SUP fields—each interface may be referenced to
MICVDD, MICBIAS1, or MICBIAS2.
1.DMIC interface timing
tCY
DMICCLK
(output)
VOH
VOL
tr
tRSU t RH
DMICDAT
(input)
18
(right data)
tf
tLSU
t LH
(left data)
VIH
VIL
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-15. Digital Speaker (PDM) Interface Timing
The following timing information is valid across the full range of recommended operating conditions.
Mode A 1
Mode B 2
Parameter
SPKCLK cycle time
SPKCLK duty cycle
SPKCLK rise/fall time (25-pF load)
SPKDAT set-up time to SPKCLK rising edge (left channel)
SPKDAT hold time from SPKCLK rising edge (left channel)
SPKDAT set-up time to SPKCLK falling edge (right channel)
SPKDAT hold time from SPKCLK falling edge (right channel)
SPKCLK cycle time
SPKCLK duty cycle
SPKCLK rise/fall time (25-pF load)
SPKDAT enable from SPKCLK rising edge (right channel)
SPKDAT disable to SPKCLK falling edge (right channel)
SPKDAT enable from SPKCLK falling edge (left channel)
SPKDAT disable to SPKCLK rising edge (left channel)
Symbol
tCY
—
tr, tf
tLSU
tLH
tRSU
tRH
tCY
—
tr, tf
tREN
tRDIS
tLEN
tLDIS
Minimum
160
45
2
30
30
30
30
160
45
2
—
—
—
—
1.Digital speaker (PDM) interface timing—Mode A
Typical
163
—
—
—
—
—
—
163
—
—
—
—
—
—
Maximum
358
55
8
—
—
—
—
358
55
8
15
5
15
5
t CY
SPKCLK
(output)
VOH
VOL
tr
tf
t LH
SPKDAT
(output)
tRH
(left data)
(right data)
tLSU
tRSU
2.Digital speaker (PDM) interface timing—Mode B
VOH
V OL
tCY
SPKCLK
(output)
V OH
VOL
tr
SPKDAT
(output)
19
Units
ns
%
ns
ns
ns
ns
ns
ns
%
ns
ns
ns
ns
ns
tLEN
tf
t REN
(left data)
t LDIS
V OH
VOL
(right data)
tRDIS
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-16. Digital Audio Interface—Master Mode
Test conditions (unless specified otherwise): CLOAD = 25 pF (output pins); BCLK slew (10% to 90%) = 3.7–5.6 ns; with the exception of the conditions
noted, the following electrical characteristics are valid across the full range of recommended operating conditions.
Parameter 1
AIFnBCLK cycle time
AIFnBCLK pulse width high
AIFnBCLK pulse width low
AIFnLRCLK propagation delay from BCLK falling edge 2
AIFnTXDAT propagation delay from BCLK falling edge
AIFnRXDAT setup time to BCLK rising edge
AIFnRXDAT hold time from BCLK rising edge
Master Mode, AIFnLRCLK setup time to BCLK rising edge
Slave LRCLK
AIFnLRCLK hold time from BCLK rising edge
Notes: The descriptions above assume noninverted polarity of AIFnBCLK.
Master Mode
Symbol
tBCY
tBCH
tBCL
tLRD
tDD
tDSU
tDH
tLRSU
tLRH
Minimum
40
18
18
0
0
11
0
14
0
1.Digital audio interface timing—Master Mode. Note that BCLK and LRCLK outputs
can be inverted if required; the figure shows the default, noninverted polarity.
Typical
—
—
—
—
—
—
—
—
—
Maximum
—
—
—
8.3
5
—
—
—
—
Units
ns
ns
ns
ns
ns
ns
ns
ns
ns
t BCY
BCLK
(output)
tBCH
LRCLK
(output)
TXDAT
(output)
tBCL
t LRD
t DD
RXDAT
(input)
tDH
t DSU
2.The timing of the AIFnLRCLK signal is selectable. If the LRCLK advance option is enabled, the LRCLK transition is timed relative to the preceding
BCLK edge. Under the required condition that BCLK is inverted in this case, the LRCLK transition is still timed relative to the falling BCLK edge.
20
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-17. Digital Audio Interface—Slave Mode
The following timing information is valid across the full range of recommended operating conditions, unless otherwise noted.
Parameter 1,2
AIFnBCLK cycle time
AIFnBCLK pulse width high
BCLK as direct SYSCLK or ASYNCCLK source
All other conditions
AIFnBCLK pulse width low
BCLK as direct SYSCLK or ASYNCCLK source
All other conditions
AIFnLRCLK set-up time to BCLK rising edge
CLOAD = 15 pF (output pins),
BCLK slew (10%–90%) = 3 ns AIFnLRCLK hold time from BCLK rising edge
AIFnTXDAT propagation delay from BCLK falling edge
AIFnRXDAT set-up time to BCLK rising edge
AIFnRXDAT hold time from BCLK rising edge
Master LRCLK, AIFnLRCLK propagation delay from BCLK falling edge
CLOAD = 25 pF (output pins),
AIFnLRCLK set-up time to BCLK rising edge
BCLK slew (10%–90%) = 6 ns AIFnLRCLK hold time from BCLK rising edge
AIFnTXDAT propagation delay from BCLK falling edge
AIFnRXDAT set-up time to BCLK rising edge
AIFnRXDAT hold time from BCLK rising edge
Master LRCLK, AIFnLRCLK propagation delay from BCLK falling edge
Note: The descriptions above assume noninverted polarity of AIFnBCLK.
1.Digital audio interface timing—Slave Mode. Note that BCLK and LRCLK inputs can
be inverted if required; the figure shows the default, noninverted polarity.
Symbol Min Typ Max Units
tBCY
40 — —
ns
16 — —
ns
tBCH
tBCH
14 — —
ns
16 — —
ns
tBCL
tBCL
14 — —
ns
tLRSU
7
— —
ns
tLRH
0
— —
ns
tDD
0
— 12.2 ns
tDSU
2
—
ns
tDH
0
—
ns
tLRD
— — 14.8 ns
tLRSU
7
—
ns
tLRH
0
—
ns
tDD
0
— 14.2 ns
2
—
ns
tDSU
tDH
0
—
ns
tLRD
— — 15.9 ns
tBCY
BCLK
(input)
LRCLK
(input)
TXDAT
(output)
tBCH
t BCL
tLRH
tLRSU
tDD
RXDAT
(input)
tDSU
t DH
2.If AIFnBCLK or AIFnLRCLK is selected as a source for SYSCLK or ASYNCCLK (either directly or via one of the FLLs), the frequency must be within
1% of the applicable SYSCLK_FREQ or ASYNC_CLK_FREQ setting.
Table 3-18. Digital Audio Interface Timing—TDM Mode
The following timing information is valid across the full range of recommended operating conditions, unless otherwise noted.
Parameter 1
Min
Typ
Max
AIFnTXDAT enable time from BCLK falling edge
0
—
—
Master Mode—CLOAD (AIFnTXDAT) = 15 to
25 pF. BCLK slew (10%–90%) = 3.7ns to 5.6 ns. AIFnTXDAT disable time from BCLK falling edge
—
—
6
Slave Mode—CLOAD (AIFnTXDAT) = 15 pF).
AIFnTXDAT enable time from BCLK falling edge
2
—
—
BCLK slew (10%–90%) = 3 ns
AIFnTXDAT disable time from BCLK falling edge
—
—
12.2
Slave Mode—CLOAD (AIFnTXDAT) = 25 pF).
AIFnTXDAT enable time from BCLK falling edge
2
—
—
BCLK slew (10%–90%) = 6 ns
AIFnTXDAT disable time from BCLK falling edge
—
—
14.2
Note: If TDM operation is used on the AIFnTXDAT pins, it is important that two devices do not attempt to drive the AIFnTXDAT pin
simultaneously. To support this requirement, the AIFnTXDAT pins can be configured to be tristated when not outputting data.
1.Digital audio interface timing—
TDM Mode. The timing of the
AIFnTXDAT tristating at the
start and end of the data
transmission is shown.
BCLK
TXDAT
AIFnTXDAT undriven (tristate)
AIFnTXDAT valid (codec output)
AIFnTXDAT enable time
21
Units
ns
ns
ns
ns
ns
ns
AIFnTXDAT valid
AIFnTXDAT undriven (tristate)
AIFnTXDAT disable time
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-19. Control Interface Timing—Two-Wire (I2C) Mode
The following timing information is valid across the full range of recommended operating conditions.
Parameter 1
SCLK frequency
SCLK pulse-width low
SCLK pulse-width high
Hold time (start condition)
Setup time (start condition)
SDA, SCLK rise time (10%–90%)
SCLK frequency > 1.7 MHz
SCLK frequency > 1 MHz
SCLK frequency 1 MHz
SCLK frequency > 1.7 MHz
SCLK frequency > 1 MHz
SCLK frequency 1 MHz
SDA, SCLK fall time (90%–10%)
Setup time (stop condition)
SDA setup time (data input)
SDA hold time (data input)
SDA valid time (data/ACK output)
SCLK slew (90%–10%) = 20ns, CLOAD (SDA) = 15 pF
SCLK slew (90%–10%) = 60ns, CLOAD (SDA) = 100 pF
SCLK slew (90%–10%) = 160ns, CLOAD (SDA) = 400 pF
SCLK slew (90%–10%) = 200ns, CLOAD (SDA) = 550 pF
Pulse width of spikes that are suppressed
1.Control interface
timing—I2C Mode
START
t1
Symbol
—
t1
t2
t3
t4
t6
t6
t6
t7
t7
t7
t8
t5
t9
t10
t10
t10
t10
tps
t2
Min
—
160
100
160
160
—
—
—
—
—
—
160
40
0
—
—
—
—
0
Typ
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
Max
3400
—
—
—
—
80
160
2000
60
160
200
—
—
—
40
130
190
220
25
Units
kHz
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
STOP
t6
SCLK
(input)
t4
t7
t3
t8
SDA
t5
22
t9
t10
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-20. Control Interface Timing—Four-Wire (SPI) Mode
The following timing information is valid across the full range of recommended operating conditions.
Parameter 1, 2
SS falling edge to SCLK rising edge
SCLK falling edge to SS rising edge
SCLK pulse cycle time
SCLK pulse-width low
SCLK pulse-width high
MOSI to SCLK set-up time
MOSI to SCLK hold time
SCLK falling edge to MISO transition
SYSCLK disabled (SYSCLK_ENA = 0)
SYSCLK_ENA = 1, SYSCLK_FREQ = 000
SYSCLK_ENA = 1, SYSCLK_FREQ > 000
SCLK slew (90%–10%) = 5 ns, CLOAD (MISO) = 25 pF
1.Control interface timing—SPI Mode (write
cycle)
tSSU
Symbol
Min
Typ
Max
Units
tSSU
2.6
—
—
ns
tSHO
tSCY
tSCY
tSCY
tSCL
tSCH
tDSU
tDHO
tDL
0
38.4
76.8
38.4
15.3
15.3
1.5
1.7
0
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
—
12.6
ns
ns
ns
ns
ns
ns
ns
ns
ns
t SHO
SS
(input)
tSCY
SCLK
(input)
t SCH
MOSI
(input)
tSCL
tDSU
tDHO
2.Control interface timing—SPI Mode (read
cycle)
SS
(input)
SCLK
(input)
MISO
(output)
tDL
23
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-21. SLIMbus Interface Timing
The following timing information is valid across the full range of recommended operating conditions.
Parameter 1
Symbol
Minimum
Typ
Maximum
Units
SLIMCLK cycle time
35
—
—
—
ns
SLIMCLK pulse width high
12
TCLKH
—
—
ns
TCLKL
SLIMCLK pulse width low
12
—
—
ns
40
—
—
ns
SLIMCLK SLIMCLK cycle time
—
12
—
—
ns
output
SLIMCLK pulse width high
TCLKH
TCLKL
12
—
—
ns
SLIMCLK pulse width low
SLIMCLK slew
CLOAD = 15 pF, SLIMCLK_DRV_STR = 0 SRCLK 0.09 x VDBVDD — 0.22 x VDBVDD V/ns
rate (20%–80%)
CLOAD = 70 pF, SLIMCLK_DRV_STR = 0 SRCLK 0.02 x VDBVDD — 0.05 x VDBVDD V/ns
CLOAD = 70 pF, SLIMCLK_DRV_STR = 1 SRCLK 0.04 x VDBVDD — 0.11 x VDBVDD V/ns
3.5
—
—
ns
SLIMDAT SLIMDAT setup time to SLIMCLK falling edge
TSETUP
input
SLIMDAT hold time from SLIMCLK falling edge
TH
2
—
—
ns
SLIMDAT SLIMDAT time
SLIMDAT_DRV_STR = 0, DBVDD = 1.71 V
TDV
—
4.7
8.1
ns
CLOAD = 15 pF, SLIMDAT_DRV_STR = 1, DBVDD = 1.71 V
TDV
output
for data output
—
4.3
7.3
ns
TDV
CLOAD = 30 pF, SLIMDAT_DRV_STR = 0, DBVDD = 1.71 V
valid (relative to
—
6.8
11.8
ns
TDV
CLOAD = 30 pF, SLIMDAT_DRV_STR = 1, DBVDD = 1.71 V
SLIMCLK rising
—
5.8
10.0
ns
TDV
CLOAD = 50 pF, SLIMDAT_DRV_STR = 0, DBVDD = 1.71 V
edge)
—
9.6
16.6
ns
TDV
CLOAD = 50 pF, SLIMDAT_DRV_STR = 1, DBVDD = 1.71 V
—
7.9
13.7
ns
TDV
CLOAD = 70 pF, SLIMDAT_DRV_STR = 0, DBVDD = 1.71 V
—
12.4
21.5
ns
TDV
CLOAD = 70 pF, SLIMDAT_DRV_STR = 1, DBVDD = 1.71 V
—
10.0
17.4
ns
SLIMDAT slew
CLOAD = 15 pF, SLIMDAT_DRV_STR = 0 SRDATA
—
— 0.64 x VDBVDD V/ns
rate (20%–80%)
CLOAD = 30 pF, SLIMDAT_DRV_STR = 0 SRDATA
—
— 0.35 x VDBVDD V/ns
CLOAD = 30pF, SLIMDAT_DRV_STR = 1 SRDATA
—
— 0.46 x VDBVDD V/ns
CLOAD = 70pF, SLIMDAT_DRV_STR = 0 SRDATA
—
— 0.16 x VDBVDD V/ns
CLOAD = 70pF, SLIMCLK_DRV_STR = 1 SRDATA
—
— 0.21 x VDBVDD V/ns
Other
Driver disable time
TDD
—
—
6
ns
parameters Bus holder output impedance
0.1 x VDBVDD < V < 0.9 x VDBVDD RDATAS
18
—
50
kΩ
Notes:
• The signal timing information describes the timing requirements of the SLIMbus interface as a whole, not just the CS42L92 device.
• TDV is the propagation delay from the rising SLIMCLK edge (at CS42L92 input) to the SLIMDAT output being achieved at the input to all
devices across the bus.
• TSETUP is the set-up time for SLIMDAT input (at CS42L92), relative to the falling SLIMCLK edge (at CS42L92).
• TH is the hold time for SLIMDAT input (at CS42L92) relative to the falling SLIMCLK edge (at CS42L92).
• For more details of the interface timing, refer to the MIPI Alliance Specification for Serial Low-Power Inter-Chip Media Bus (SLIMbus)
SLIMCLK
input
1.SLIMbus interface timing.
VIH , VOH
VIL , VOL
SLIMCLK
TCLKL
TCLKH
VIH
VIL
SLIMDAT
TDV TSETUP
TH
VIL , VIH are the 35%/65% levels of the respective inputs.
VOL , VOH are the 20%/80% levels of the respective outputs.
The SLIMDAT output delay (TDV) is with respect to the input pads of all receiving devices.
24
DS1162F1
CS42L92
3 Characteristics and Specifications
Table 3-22. JTAG Interface Timing
Test conditions (unless specified otherwise): CLOAD = 25 pF (output pins); TCK slew (20%–80%) = 5 ns; with the exception of the conditions noted,
the following electrical characteristics are valid across the full range of recommended operating conditions.
Parameter 1
TCK cycle time
TCK pulse width high
TCK pulse width low
TMS setup time to TCK rising edge
TMS hold time from TCK rising edge
TDI setup time to TCK rising edge
TDI hold time from TCK rising edge
TDO propagation delay from TCK falling edge
TRST setup time to TCK rising edge
TRST hold time from TCK rising edge
TRST pulse-width low
Symbol
TCCY
TCCH
TCCL
TMSU
TMH
TDSU
TDH
TDD
TRSU
TRH
—
1.JTAG Interface timing
Minimum
50
20
20
1
2
1
2
0
3
3
20
Typical
—
—
—
—
—
—
—
—
—
—
—
Maximum
—
—
—
—
—
—
—
17
—
—
—
Units
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
ns
tCCY
TCK
(input)
TRST
(input)
t CCH
t CCL
t RSU
tRH
TMS
(input)
TDI
(input)
TDO
(output)
DS1162F1
tMSU
tMH
tDSU
t DH
t DD
25
CS42L92
3 Characteristics and Specifications
Table 3-23. Typical Power Consumption
Test conditions (unless specified otherwise): DBVDD = CPVDD1 = AVDD = 1.8 V, DCVDD = FLLVDD = CPVDD2 = 1.2 V; MICVDD = Off (CP2 and
LDO2 disabled); TA = +25ºC; Fs = 48 kHz; 24-bit audio data, I2S Slave Mode; SYSCLK = 24.576 MHz (direct MCLK1 input).
Operating Configuration
Headphone playback
Earpiece playback
Stereo line record
Sleep Mode
AIF1 to DAC to HPOUT1 (stereo),
Quiescent
32- load.
1-kHz sine wave, PO = 10 mW
AIF1 to DAC to HPOUT1 (mono),
Quiescent
32- load (BTL).
1-kHz sine wave, PO = 30 mW
Analog line to ADC to AIF1,
1-kHz sine wave, -1 dBFS output
MICVDD = 1.8V (CP2 and LDO2
bypass enabled).
Accessory detect enabled (JD1_ENA = 1)
Typical
I1.2V (mA)
1.8
37.8
1.2
61.7
1.1
Typical
I1.8V (mA)
0.8
1.9
0.85
1.7
2.2
0.000
0.010
PTOT (mW)
3.6
48.78
2.97
77.1
5.28
0.018
Table 3-24. Typical Signal Latency
Test conditions (unless specified otherwise): DBVDD = CPVDD1 = AVDD = 1.8 V, DCVDD = FLLVDD = CPVDD2 = 1.2 V; MICVDD = Off (CP2 and
LDO2 disabled); TA = +25ºC; Fs = 48 kHz; 24-bit audio data, I2S Slave Mode; SYSCLK = 24.576 MHz (direct MCLK1 input).
Operating Configuration
AIF to DAC path—digital input (AIFn) to analog output (HPOUTn)
ADC to AIF path—analog input (INn) to digital output (AIFn) 3
192 kHz input, 192 kHz output, Synchronous
96 kHz input, 96 kHz output, Synchronous
48 kHz input, 48 kHz output, Synchronous
44.1 kHz input, 44.1 kHz output, Synchronous
16 kHz input, 16 kHz output, Synchronous
8 kHz input, 8 kHz output, Synchronous
8 kHz input, 48 kHz output, Isochronous 1
16 kHz input, 48 kHz output, Isochronous 1
8 kHz input, 44.1 kHz output, Asynchronous 2
16 kHz input, 44.1 kHz output, Asynchronous 2
192 kHz input, 192 kHz output, Synchronous
96 kHz input, 96 kHz output, Synchronous
48 kHz input, 48 kHz output, Synchronous
44.1 kHz input, 44.1 kHz output, Synchronous
16 kHz input, 16 kHz output, Synchronous
8 kHz input, 8 kHz output, Synchronous
8 kHz input, 48 kHz output, Isochronous 1
16 kHz input, 48 kHz output, Isochronous 1
44.1 kHz input, 8 kHz output, Asynchronous 2
44.1 kHz input, 16 kHz output, Asynchronous 2
Latency (s)
237
269
358
374
629
1334
1939
993
1880
1084
50
96
193
212
558
1170
1696
861
1364
841
1.Signal is routed via the ISRC function in the isochronous cases only.
2.Signal is routed via the ASRC function in the asynchronous cases only.
3.Digital core high-pass filter is included in the signal path.
26
DS1162F1
CS42L92
4 Functional Description
4 Functional Description
The CS42L92 is a highly integrated, low-power audio hub codec for mobile telephony and portable devices. It provides
flexible, high-performance audio interfacing for handheld devices in a small and cost-effective package. The digital audio
interfaces and hi-fi DACs support 32-bit playback, offering audiophile-quality playback at sample rates up to 384 kHz.
Native audio playback is possible, concurrent with voice and ultrasonic input paths. Multiple analog outputs support a wide
variety of the headphone/accessory configurations, including balanced stereo headphone loads.
4.1 Overview
MICBIAS1A
MICBIAS1B
MICBIAS1C
MICBIAS1D
MICBIAS2A
MICBIAS2B
Charge Pumps
LDO and
MICBIAS
Generators
CS42L92
SUBGND
DCVDD
DBVDD
FLLGND
DGND
FLLVDD
CPVDD1
CPVDD2
CPGND
AVDD
AGND
VREFC
CP2CA
CP2CB
CP1C1A
CP1C1B
CP1VOUT1P
CP1VOUT1N
CP1C2A
CP1C2B
CP1VOUT2P
CP1VOUT2N
CP2VOUT
MICVDD
The CS42L92 block diagram is shown in Fig. 4-1.
Reference
Generator
DAC
HPOUTnL
DAC
HPOUTnR
Digital Mixing Core
SYSCLK
ASYNCCLK
SLIMbus
Interface
Control Interface (SPI/I2C)
GPIO
x4
SPKCLK
SPKDAT
JACKDET1
JACKDET2
JACKDET3
HPDET1
HPDET2
MICDET1/HPOUTFB1
MICDET2/HPOUTFB2
MICDET3/HPOUTFB3
MICDET4/HPOUTFB4
MICDET5/HPOUTFB5
GPSW1P
GPSW1N
GPSW2P
GPSW2N
Digital Audio Interfaces
AIF1, AIF2, AIF3
Accessory
Detect
GPIO1
GPIO2
Clocking
Control
CIFMISO
CIFMOSI/SDA
CIFSCLK
CIFSS
CIFMODE
AIFnBCLK
AIFnLRCLK
SLIMCLK
AIF1TXDAT
AIF1RXDAT
AIF1BCLK
AIF1LRCLK
IRQ
PDM
Driver
AEC (Echo Cancelation)
Loop-Back
SLIMCLK
SLIMDAT1
SLIMDAT2
RESET
4 x ADC
4 x Stereo
Digital Mic
Interface
AIF3TXDAT
AIF3RXDAT
AIF3BCLK
AIF3LRCLK
MCLK1
MCLK2
MCLK3
Programmable DSP
Five-band equalizer (EQ)
Dynamic range control (DRC)
Low-pass/high-pass filter (LHPF)
Asynchronous sample -rate conversion
Automatic sample -rate detection
Data format conversion
Ultrasonic demodulator
PWM signal generator
Haptic control signal generator
Input Select
AIF2TXDAT
AIF2RXDAT
AIF2BCLK
AIF2LRCLK
IN1ALN/DMICCLK1, IN1BLN
IN1ALP/DMICDAT1, IN1BLP
IN1ARN/DMICCLK3
IN1ARP/DMICDAT3, IN1BR
IN2ALN/DMICCLK2
IN2ALP/DMICDAT2, IN2BL
IN2ARN/DMICCLK4
IN2ARP/DMICDAT4, IN2BR
Figure 4-1. CS42L92 Block Diagram
The CS42L92 combines fixed-function signal-processing blocks with a fully-flexible, all-digital audio mixing and routing
engine for extensive use-case flexibility. The signal-processing blocks include high-/low-pass filters, EQ, dynamic range
control, and sample-rate converters.
The CS42L92 provides multiple digital audio interfaces, including SLIMbus, to provide independent and fully
asynchronous connections to different processors (e.g., application processor, baseband processor, and wireless
transceiver).
A flexible clocking arrangement supports a wide variety of external clock references, including clocking derived from the
digital audio interface. Two frequency-locked loop (FLL) circuits provide additional flexibility for system clocking, including
low-power always-on operation. Seamless switching between clock sources is supported, and free-running modes are
also available.
Unused circuitry can be disabled under software control to save power; low leakage currents enable extended standby/off
time in portable battery-powered applications. The CS42L92 always-on circuitry can be used in conjunction with the
applications processor to wake up the device following a headphone jack-detection event.
DS1162F1
27
CS42L92
4.1 Overview
Versatile GPIO functionality is provided, including support for external accessory/push-button detection inputs.
Comprehensive interrupt functions, with status reporting, are also provided. The integrated DSP provides a
general-purpose signal processing capability; this is supported by general-purpose timer and event-logger functions.
4.1.1
Hi-Fi Audio Codec
The CS42L92 is a high-performance, low-power audio codec that uses a simple analog architecture. Four ADCs are
incorporated, with multiplexers to support up to eight analog inputs. Six DACs are incorporated, with two being switchable
between two separate headphone output paths.
The audio codec is controlled directly via register access. The simple analog architecture, combined with the integrated
tone generator, enables straightforward device configuration and testing, minimizing debug time and reducing software
effort.
The CS42L92 input channels support up to eight analog inputs or up to eight digital inputs, multiplexed into four stereo
input signal paths. In differential mode, the analog input path SNR is 104 dB (16-kHz sample rate, i.e., wideband voice
mode). The input paths can be configured for low-power operation, ideal for analog or digital microphone input in
always-on applications. Ultrasonic signal demodulation functions are provided, supporting a variety of presence-detection
applications.
The analog outputs comprise four 33-mW (125 dB SNR) stereo headphone amplifiers with ground-referenced output. The
output drivers are designed to support many different system architectures and are compatible with line or headphone
loads in single-ended or differential (BTL) configurations. Headphone outputs HPOUT1 and HPOUT2 offer 127 dB SNR
and –100 dB THD+N performance with a stereo differential headphone load. Outputs HPOUT3 and HPOUT4 are
multiplexed, with the respective DACs and signal paths common to both pairs of output drivers.
Each output path supports independent mixing, equalization, filtering, gain controls. This allows each signal path to be
individually tailored for the load characteristics. Selectable hi-fi filters support audiophile playback modes at sample rates
up to 384 kHz. All outputs have integrated pop and click suppression features.
The headphone output drivers are ground-referenced, powered from an integrated charge pump, enabling high quality,
power efficient headphone playback without any requirement for DC blocking capacitors. Ground loop feedback is
incorporated, providing rejection of noise on the ground connections.
The CS42L92 is cost optimized for a wide range of mobile phone applications. External speaker amplifiers can be
connected using the stereo PDM outputs; this can ease layout and electromagnetic compatibility by avoiding the need to
run high-power speaker outputs over a long distance and across interconnects.
4.1.2
Digital Audio Core
The CS42L92 uses a core architecture based on all-digital signal routing, making digital audio effects available on all signal
paths, regardless of whether the source data input is analog or digital. The digital mixing desk allows different audio effects
to be applied simultaneously on many independent paths, while supporting a variety of sample rates. Soft mute and
unmute control ensures smooth transitions between use cases without interrupting existing audio streams elsewhere.
Highly flexible digital mixing, including mixing between audio interfaces, is possible. The CS42L92 performs multichannel
full-duplex asynchronous sample-rate conversion, providing use-case flexibility across a broad range of system
architectures. Automatic sample-rate detection is provided, enabling seamless wideband/narrowband voice call handover.
DRC functions are available for optimizing audio signal levels. In playback modes, the DRC can be used to maximize
loudness, while limiting the signal level to avoid distortion, clipping, or battery droop, for high-power output drivers such as
speaker amplifiers. In record modes, the DRC assists in applications where the signal level is unpredictable.
The five-band parametric EQ functions can be used to compensate for the frequency characteristics of the output
transducers. EQ functions can be cascaded to provide additional frequency control. Programmable high-pass and
low-pass filters are also available for general filtering applications, such as removal of wind and other low-frequency noise.
28
DS1162F1
CS42L92
4.1 Overview
4.1.3
Digital Interfaces
Three serial digital audio interfaces (AIFs) each support PCM, TDM, and I2S data formats for compatibility with most
industry-standard chipsets. Each AIF supports eight input/output channels. Bidirectional operation at sample rates up to
384 kHz is supported. Data words of up to 32 bits can be routed through AIF1 and AIF3. Data-format conversion (DFC)
functions are available to support different interface standards on the input and output signal paths.
Eight digital PDM input channels are available (four stereo interfaces); these are typically used for digital microphones,
powered from the integrated MICBIAS power-supply regulators. Two PDM output channels are also available (one stereo
interface); these are typically used for external power amplifiers. Embedded mute codes provide a control mechanism for
external PDM-input devices.
The auxiliary PDM interface can be used to provide an audio path between an analog microphone connected to the
CS42L92 and a digital input to an external audio processor. The auxiliary PDM interface operates in master or slave
modes, and is configured on GPIO pins.
The CS42L92 features a SLIMbus interface, compliant with the MIPI® SLIMbus specification, providing eight channels of
audio input/output. Mixed audio sample rates are supported on the SLIMbus interface. The SLIMbus interface also
supports read/write access to the CS42L92 control registers.
An IEC-60958-3–compatible S/PDIF transmitter is incorporated, enabling stereo S/PDIF output on a GPIO pin. Standard
S/PDIF sample rates of 32–192 kHz are supported.
Control register access is supported by a configurable SPI/I2C control interface. The interface supports SPI slave
operation up to 26 MHz or I2C slave operation up to 3.4 MHz. Full access to the register map is also provided via the
SLIMbus port.
4.1.4
Other Features
The CS42L92 incorporates a tone generator that can be used for beep functions through any of the audio signal paths.
The tone generator provides two 1-kHz outputs, with configurable phase relationship, offering flexibility to create
differential signals or test scenarios.
A white-noise generator is provided that can be routed within the digital core. The noise generator can provide comfort
noise in cases where silence (digital mute) is not desirable.
Two pulse-width modulation (PWM) signal generators are incorporated. The duty cycle of each PWM signal can be
modulated by an audio source or can be set to a fixed value using a control register setting. The PWM signal generators
can be output directly on a GPIO pin.
The CS42L92 supports up to 16 GPIO pins, offering a range of input/output functions for interfacing, for detection of
external hardware, and for providing logic outputs to other devices. The CS42L92 provides two dedicated GPIO pins; a
further 14 GPIOs are multiplexed with other functions. Comprehensive interrupt functionality is also provided for monitoring
internal and external event conditions.
The integrated DSP provides a general-purpose signal processing capability; this is supported by general-purpose timer
and event-logger functions.
A signal generator for controlling haptics devices is included, compatible with both eccentric rotating mass (ERM) and
linear resonant actuator (LRA) haptics devices. The haptics signal generator is highly configurable and can execute
programmable drive event profiles, including reverse drive control. An external vibe actuator can be driven using the PDM
digital output path.
A smart accessory interface is included, supporting a wide variety of system configurations. Jack detection, accessory
sensing, and impedance measurement is provided, for external headset and push-button detection. Dual headphone
connections (e.g., 3.5 mm and USB-C) can be detected simultaneously. Accessory detection can be used as a wake-up
trigger from low-power standby. Microphone activity detection with interrupt is also available.
DS1162F1
29
CS42L92
4.2 Input Signal Path
System clocking can be derived from the MCLK1, MCLK2, or MCLK3 input pins. Alternatively, the SLIMbus interface, or
the audio interfaces (configured in Slave Mode), can be used to provide a clock reference. The CS42L92 also provides
two integrated FLL circuits for clock frequency conversion and stability. The flexible clocking architecture supports
low-power always-on operation, with reference frequencies down to 32 kHz. Seamless switching between clock sources
is supported; free-running FLL modes are also available.
The CS42L92 is powered from 1.8- and 1.2-V external supplies. Integrated charge-pump and LDO-regulator circuits are
used to generate supply rails for internal functions and to support powering or biasing of external microphones. Power
consumption is optimized across a wide variety of voice and multimedia use cases.
4.2 Input Signal Path
The CS42L92 provides flexible input channels, supporting up to eight analog inputs or up to eight digital inputs. Selectable
combinations of analog (mic or line) and digital inputs are multiplexed into four stereo input signal paths. Input paths IN1
and IN2 support analog and digital inputs; input paths IN3 and IN4 support digital inputs only.
The analog input paths support single-ended and differential configurations, programmable gain control, and are digitized
using a high performance sigma-delta ADC. The analog input paths can be configured for low-power operation, ideal for
always-on applications. Analog inputs can be configured as input to the auxiliary PDM interface, providing an audio path
between an analog microphone connected to the CS42L92 and a digital input to an external audio processor.
The digital input paths interface directly with external digital microphones; a separate microphone interface clock is
provided for four separate stereo pairs of digital microphones.
Two microphone bias (MICBIAS) generators provide a low-noise reference for biasing electret condenser microphones
(ECMs) or for use as a low-noise supply for MEMS microphones and digital microphones. Switchable outputs from the
MICBIAS generators allow six separate reference/supply outputs to be independently controlled.
Digital volume control is available on all inputs (analog and digital), with programmable ramp control for smooth, glitch-free
operation. A configurable signal-detect function is available on each input signal path. Ultrasonic signal demodulation
functions are provided on the input signal paths, supporting a variety of presence-detection applications.
The input signal paths and control fields are shown in Fig. 4-2.
30
DS1162F1
CS42L92
4.2 Input Signal Path
IN1BLN
IN1ALN/DMICCLK1
IN1L
ADC
+
IN1ALP/DMICDAT1
IN_VD_RAMP[2:0] p. 40
IN_VI_RAMP[2:0] p. 40
IN1_MODE p. 38
-
IN1BLP
IN_HPF_CUT[2:0] p. 38
IN1L_SRC[1:0] p. 38
IN1L_PGA_VOL[6:0] p. 38
IN1L_LP_MODE p. 38
CLK
IN1L_HPF p. 38
Digital Mic
Interface
DAT
IN1L_VOL[7:0] p. 41
IN1L_MUTE p. 41
IN1L_ENA p. 36
IN3_OSR[2:0] p. 39
IN3_DMIC_SUP[1:0] p. 39
IN1R_SRC[1:0] p. 38
-
IN1BR
IN1ARN/DMICCLK3
+
IN1ARP/DMICDAT3
IN1R
ADC
IN1R_PGA_VOL[6:0] p. 38
IN1R_LP_MODE p. 38
CLK
IN1R_HPF p. 38
IN3L
Digital Mic
Interface
DAT
IN1R_VOL[7:0] p. 41
IN1R_MUTE p. 41
IN1R_ENA p. 36
IN3_OSR[2:0] p. 39
IN3_DMIC_SUP[1:0] p. 39
IN3L_HPF p. 39
IN3L_VOL[7:0] p. 41
IN3L_MUTE p. 41
IN3L_ENA p. 36
IN3R
IN3R_HPF p. 39
IN2BL
IN2L_SRC[1:0] p. 39
IN2ALN/DMICCLK2
-
IN3R_VOL[7:0] p. 42
IN3R_MUTE p. 42
IN3R_ENA p. 36
IN2L
ADC
+
IN2ALP/DMICDAT2
IN2_MODE p. 39
IN2L_PGA_VOL[6:0] p. 39
IN2L_LP_MODE p. 39
CLK
IN2L_HPF p. 39
Digital Mic
Interface
DAT
IN2L_VOL[7:0] p. 41
IN2L_MUTE p. 41
IN2L_ENA p. 36
IN4_OSR[2:0] p. 40
IN4_DMIC_SUP[1:0] p. 40
IN2BR
IN2R_SRC[1:0] p. 39
IN2ARN/DMICCLK4
-
IN2R
ADC
+
IN2ARP/DMICDAT4
IN2R_PGA_VOL[6:0] p. 39
IN2R_LP_MODE p. 39
CLK
DAT
Digital Mic
Interface
IN4_OSR[2:0] p. 40
IN4_DMIC_SUP[1:0] p. 40
IN2R_HPF p. 39
IN2R_VOL[7:0] p. 41
IN2R_MUTE p. 41
IN2R_ENA p. 36
IN4L
IN4L_HPF p. 40
IN4L_VOL[7:0] p. 42
IN4L_MUTE p. 42
IN4L_ENA p. 36
IN4R
IN4R_HPF p. 40
IN4R_VOL[7:0] p. 42
IN4R_MUTE p. 42
IN4R_ENA p. 36
Figure 4-2. Input Signal Paths
DS1162F1
31
CS42L92
4.2 Input Signal Path
4.2.1
Analog Microphone Input
Up to eight analog microphones can be connected to the CS42L92, either in single-ended or differential configuration. The
input configuration and pin selection is controlled using INnx_SRC, as described in Section 4.2.6.
The CS42L92 includes external accessory-detection circuits that can report the presence of a microphone and the status
of a hook switch or other push buttons. When using this function, it is recommended to use the IN1ALx, IN1BLx, or IN1BR
analog microphone input paths to ensure best immunity to electrical transients arising from the push buttons.
For single-ended input, the microphone signal is connected to the noninverting input of the PGAs. The inverting inputs of
the PGAs are connected to an internal reference in this configuration.
For differential input, the noninverted microphone signal is connected to the noninverting input of the PGAs and the
inverted (or noisy ground) signal is connected to the inverting input pins.
The gain of the input PGAs is controlled via register settings, as defined in Section 4.2.6. Note that the input impedance
of the analog input paths is fixed across all PGA gain settings.
The ECM analog input configurations are shown in Fig. 4-3 and Fig. 4-4. The integrated MICBIAS generators provide a
low noise reference for biasing the ECMs.
MICBIAS
MICBIAS
INnAxP,
INnBLP,
INnBx
INnAxP,
INnBLP,
INnBx
INnAxN,
IN1BLN
ECM
+
PGA
–
To ADC
ECM
INnAxN,
IN1BLN
+
PGA
–
To ADC
GND
VREF
VREF
GND
Figure 4-3. Single-Ended ECM Input
Figure 4-4. Differential ECM Input
Pseudodifferential connection is also possible—this is similar to the configuration shown in Fig. 4-4, but the GND
connection is directly to the microphone (and INnxN capacitor), instead of via a resistor. The typical connections for
pseudodifferential input are shown in Fig. 4-5.
Note that pseudodifferential input is the recommended configuration if the accessory-detection functions are used on this
input path. The INnx_SRC field settings are the same for pseudodifferential connection as for differential.
The IN1ALN pin can be used as the inverting input connection for the IN1L and IN1R paths concurrently. This allows two
microphones to be supported, in pseudodifferential configuration, while minimizing the number of pin connections
required—see Fig. 4-6.
32
DS1162F1
CS42L92
4.2 Input Signal Path
MICBIASnx
MICBIAS
INnAxP,
INnBLP,
INnBx
IN1ALP
ECM
+
PGA
–
INnAxN,
IN1BLN
To ADC
IN1BR
ECM
ECM
VREF
IN1ALN
GND
GND
Figure 4-5. Pseudodifferential ECM Input
GND
Figure 4-6. Pseudodifferential IN1L/IN1R Input
Analog MEMS microphones can be connected to the CS42L92 in a similar manner to the ECM configurations. Typical
configurations are shown in Fig. 4-7 and Fig. 4-8. In this configuration, the integrated MICBIAS generators provide a
low-noise power supply for the microphones.
MICBIAS
VDD
MEMS
Mic
OUT
INnAxP,
INnBLP,
INnBx
GND
INnAxN,
IN1BLN
MICBIAS
+
PGA
–
GND
VREF
Figure 4-7. Single-Ended MEMS Input
Note:
4.2.2
To ADC
MEMS
Mic
VDD
OUT-P
OUT-N
GND
GND
INnAxP,
INnBLP,
INnBx
INnAxN,
IN1BLN
+
PGA
–
To ADC
VREF
Figure 4-8. Differential MEMS Input
The MICVDD pin can also be used (instead of MICBIAS) as a reference or power supply for external microphones.
The MICBIAS outputs are recommended, because they offer better noise performance and independent enable/
disable control.
Analog Line Input
Line inputs can be connected to the CS42L92 in a similar manner to the mic inputs. Single-ended and differential
configurations are supported on each analog input path, using the INnx_SRC bits as described in Section 4.2.6.
The analog line input configurations are shown in Fig. 4-9 and Fig. 4-10. Note that the microphone bias (MICBIAS) is not
used for line input connections.
DS1162F1
33
CS42L92
4.2 Input Signal Path
INnAxP,
INnBLP,
INnBx
Line
INnAxP,
INnBLP,
INnBx
Line
INnAxN,
IN1BLN
+
PGA
–
To ADC
INnAxN,
IN1BLN
+
PGA
–
To ADC
GND
VREF
VREF
Figure 4-9. Single-Ended Line Input
4.2.3
Figure 4-10. Differential Line Input
DMIC Input
As many as eight digital microphones can be connected to the CS42L92. DMIC operation on input paths IN1–IN4 is
selected using IN1_MODE and IN2_MODE, as described in Section 4.2.6.
In DMIC mode, two channels of audio data are multiplexed on the associated DMICDATn pin. Each stereo DMIC interface
is clocked using the respective DMICCLKn output.
If DMIC input is enabled, the CS42L92 outputs the DMIC clock on the applicable DMICCLKn pins. The DMICCLKn
frequency is controlled by the respective INn_OSR field, as described in Table 4-1 and Table 4-3.
Note that, if the 384- or 768-kHz DMICCLKn frequency is selected, the maximum valid sample rate for the respective paths
is restricted as described in Table 4-1. If the input sample rates are set globally using IN_RATE (i.e., IN_RATE_
MODE = 0), all input paths are affected similarly.
Note that SYSCLK must be present and enabled when using the DMIC inputs; see Section 4.16 for details of SYSCLK
and the associated registers.
The DMIC clock frequencies in Table 4-1 assume that the SYSCLK frequency is a multiple of 6.144 MHz (SYSCLK_
FRAC = 0). If the SYSCLK frequency is a multiple of 5.6448 MHz (SYSCLK_FRAC = 1), the DMIC clock frequencies are
scaled accordingly.
Table 4-1. DMICCLK Frequency
Condition
INn_OSR = 010
INn_OSR = 011
INn_OSR = 100
INn_OSR = 101
INn_OSR = 110
DMIC Clock Frequency
384 kHz
768 kHz
1.536 MHz
3.072 MHz
6.144 MHz
Valid Sample Rates
Up to 48 kHz
Up to 96 kHz
Up to 192 kHz
Up to 192 kHz
Up to 192 kHz
Signal Passband
Up to 4 kHz
Up to 8 kHz
Up to 20 kHz
Up to 20 kHz
Up to 96 kHz
The voltage reference for the DMIC interfaces is selectable, using INn_DMIC_SUP; each interface may be referenced to
MICVDD, MICBIAS1, or MICBIAS2. The voltage reference for each digital input path should be set equal to the applicable
power supply of the respective microphones.
A pair of digital microphones is connected as shown in Fig. 4-11. The microphones must be configured to ensure that the
left mic transmits a data bit when DMICCLK is high and the right mic transmits a data bit when DMICCLK is low. The
CS42L92 samples the DMIC data at the end of each DMICCLK phase. Each microphone must tristate its data output when
the other microphone is transmitting.
Note that the CS42L92 provides integrated pull-down resistors on the DMICDATn pins. This provides a flexible capability
for interfacing with other devices.
34
DS1162F1
CS42L92
4.2 Input Signal Path
MICVDD or MICBIASnx
DMICCLKn
Digital
Microphone
Interface
DMICDATn
VDD
VDD
CLK DATA
VDD
Digital Mic
The DMIC inputs are referenced to
MICVDD, MICBIAS1, or MICBIAS2.
CLK DATA
Digital Mic
The supply for each digital microphone
should provide the same voltage as the
applicable reference.
CHAN
CHAN
AGND
Figure 4-11. DMIC Input
Two DMIC channels are interleaved on DMICDATn. The DMIC interface timing is shown in Fig. 4-12. Each microphone
must tristate its data output when the other microphone is transmitting.
DMIC clock output
Hi-Z
Left mic output
1
2
Right mic output
DMICDATn pin
(Left and right channels interleaved)
1
1
2
1
2
1
2
2
1
2
Figure 4-12. DMIC Interface Timing
4.2.4
Input Signal Path Enable
The input signal paths are enabled using the bits described in Table 4-2. The respective bits must be enabled for analog
or digital input on the respective input paths.
The input signal paths are muted by default. It is recommended that deselecting the mute should be the final step of the
path enable control sequence. Similarly, the mute should be selected as the first step of the path-disable control sequence.
The input signal path mute functions are controlled using the bits described in Table 4-4.
The MICVDD power domain must be enabled when using the analog input signal paths. This power domain is provided
using an internal charge pump (CP2) and LDO regulator (LDO2). See Section 4.19 for details of these circuits.
The system clock, SYSCLK, must be configured and enabled before any audio path is enabled. The ASYNCCLK and
32-kHz clock may also be required, depending on the path configuration. See Section 4.16 for details of the system clocks.
DS1162F1
35
CS42L92
4.2 Input Signal Path
The CS42L92 performs automatic checks to confirm that the SYSCLK frequency is high enough to support the input signal
paths and associated ADCs. If the frequency is too low, an attempt to enable an input signal path fails. Note that active
signal paths are not affected under such circumstances.
The status bits in Register R769 indicate the status of each input signal path. If an underclocked error condition occurs,
these bits indicate which input signal paths have been enabled.
Table 4-2. Input Signal Path Enable
Register Address
R768 (0x0300)
Input_Enables
R769 (0x0301)
Input_Enables_Status
36
Bit
7
Label
IN4L_ENA
Default
0
6
IN4R_ENA
0
5
IN3L_ENA
0
4
IN3R_ENA
0
3
IN2L_ENA
0
2
IN2R_ENA
0
1
IN1L_ENA
0
0
IN1R_ENA
0
7
IN4L_ENA_STS
0
6
IN4R_ENA_STS
0
5
IN3L_ENA_STS
0
4
IN3R_ENA_STS
0
3
IN2L_ENA_STS
0
2
IN2R_ENA_STS
0
1
IN1L_ENA_STS
0
0
IN1R_ENA_STS
0
Description
Input Path 4 (left) enable
0 = Disabled
1 = Enabled
Input Path 4 (right) enable
0 = Disabled
1 = Enabled
Input Path 3 (left) enable
0 = Disabled
1 = Enabled
Input Path 3 (right) enable
0 = Disabled
1 = Enabled
Input Path 2 (left) enable
0 = Disabled
1 = Enabled
Input Path 2 (right) enable
0 = Disabled
1 = Enabled
Input Path 1 (left) enable
0 = Disabled
1 = Enabled
Input Path 1 (right) enable
0 = Disabled
1 = Enabled
Input Path 4 (left) enable status
0 = Disabled
1 = Enabled
Input Path 4 (right) enable status
0 = Disabled
1 = Enabled
Input Path 3 (left) enable status
0 = Disabled
1 = Enabled
Input Path 3 (right) enable status
0 = Disabled
1 = Enabled
Input Path 2 (left) enable status
0 = Disabled
1 = Enabled
Input Path 2 (right) enable status
0 = Disabled
1 = Enabled
Input Path 1 (left) enable status
0 = Disabled
1 = Enabled
Input Path 1 (right) enable status
0 = Disabled
1 = Enabled
DS1162F1
CS42L92
4.2 Input Signal Path
4.2.5
Input Signal Path Sample-Rate Control
The input signal paths may be selected as input to the digital mixers or signal-processing functions within the CS42L92
digital core. The sample rate for the input signal paths can be set globally, or can be configured independently for each
input channel.
The IN_RATE_MODE bit (defined in Table 4-3) controls whether the input sample rates are set globally using IN_RATE,
or independently for each input channel using the INnx_RATE fields (where n is 1–4 and x is L or R for the left/right
channels respectively). The IN_RATE and INnx_RATE fields are defined in Table 4-26.
Note that sample-rate conversion is required when routing the input signal paths to any signal chain that is asynchronous
or configured for a different sample rate.
4.2.6
Input Signal Path Configuration
The CS42L92 supports up to eight analog inputs or up to eight digital inputs. Selectable combinations of analog (mic or
line) and digital inputs are multiplexed into four stereo input signal paths.
Input paths IN1 and IN2 can be configured for single-ended, differential, or DMIC operation. The analog input configuration
and pin selection is controlled using the INnx_SRC bits; digital input mode is selected by setting INn_MODE.
Input paths IN3 and IN4 support digital inputs only. Note that the external pin connections are shared with the IN1R and
IN2R analog input paths—the following restrictions apply:
•
If IN3L or IN3R input paths are enabled, IN1R analog input is restricted to differential (IN1BR–IN1ALN) or
single-ended (IN1BR) configurations only.
•
If IN4L or IN4R input paths are enabled, IN2R analog input is restricted to single-ended (IN2BR) configuration only.
A configurable high-pass filter (HPF) is provided on the left and right channels of each input path. The applicable cut-off
frequency is selected using IN_HPF_CUT. The filter can be enabled on each path independently using the INnx_HPF bits.
The analog input signal paths (single-ended or differential) each incorporate a PGA to provide gain in the range 0 dB to
+31 dB in 1-dB steps. Note that these PGAs do not provide pop suppression functions; it is recommended that the gain
should not be adjusted while the respective signal path is enabled.
The analog input PGA gain is controlled using INnL_PGA_VOL and INnR_PGA_VOL. Note that separate volume control
is provided for the left and right channels of each stereo pair.
If DMIC input is selected, the respective DMICCLKn frequency is controlled by the respective INn_OSR field.
If a signal path is configured for DMIC input, the voltage reference for the associated input/output pins is selectable using
the INn_DMIC_SUP fields—each interface may be referenced to MICVDD, MICBIAS1, or MICBIAS2. The voltage
reference for each digital input path should be set equal to the applicable power supply of the respective microphones.
The CS42L92 input paths can be configured for power-saving operation, ideal for always-on applications. The low-power
configurations allow the power consumption to be optimized with respect to the required audio performance
characteristics.
•
If a signal path is configured for analog input, low-power operation can be selected by setting the respective INnx_
LP_MODE bit. Mid-power operation can be configured by setting INn_OSR = 100 for the respective signal paths.
(Note that the INnx_LP_MODE bit should be cleared in the mid-power configuration.) Note that the maximum
input-signal level is reduced by 6 dB if mid-power operation is selected—see Table 3-4.
•
If a signal path is configured for digital input, the respective DMICCLKn frequency can be configured using the INn_
OSR bits. Reducing the DMICCLKn frequency reduces power consumption at the expense of audio performance.
The INn_OSR field also supports high performance DMIC mode, when 6.144 MHz DMICCLK is selected.
If 384- or 768-kHz DMICCLKn frequency is selected, the maximum sample rate for the respective paths is restricted
as described in Table 4-1. If the input sample rates are set globally using IN_RATE (i.e., IN_RATE_MODE = 0), all
input paths are affected similarly.
The MICVDD voltage is generated by an internal charge pump and LDO regulator. The MICBIASn outputs are derived
from MICVDD; see Section 4.19.
DS1162F1
37
CS42L92
4.2 Input Signal Path
The input signal paths are configured using the fields described in Table 4-3.
Table 4-3. Input Signal Path Configuration
Register Address
R776 (0x0308)
Input_Rate
R780 (0x030C)
HPF_Control
R784 (0x0310)
IN1L_Control
R785 (0x0311)
ADC_Digital_
Volume_1L
R786 (0x0312)
DMIC1L_Control
R788 (0x0314)
IN1R_Control
R789 (0x0315)
ADC_Digital_
Volume_1R
38
Bit
10
Label
IN_RATE_
MODE
Default
Description
1
Input Path Sample Rate Configuration
0 = Global control (all input paths configured using IN_RATE)
1 = Individual channel control (using the respective INnx_RATE fields)
2:0 IN_HPF_
010 Input Path HPF Select. Controls the cut-off frequency of the input path HPF circuits.
CUT[2:0]
000 = 2.5 Hz
010 = 10 Hz
100 = 40 Hz
001 = 5 Hz
011 = 20 Hz
All other codes are reserved
15 IN1L_HPF
0
Input Path 1 (Left) HPF Enable
0 = Disabled
1 = Enabled
12:11 IN1_DMIC_
00
Input Path 1 DMIC Reference Select (sets the DMICDAT1 and DMICCLK1 logic levels)
SUP[1:0]
00 = MICVDD
10 = MICBIAS2
01 = MICBIAS1
11 = Reserved
10 IN1_MODE
0
Input Path 1 Mode
0 = Analog input
1 = Digital input
7:1 IN1L_PGA_ 0x40 Input Path 1 (Left) PGA Volume (applicable to analog input only)
VOL[6:0]
0x00 to 0x3F = Reserved
0x42 = 2 dB
0x60 to 0x7F = Reserved
0x40 = 0 dB
… (1-dB steps)
0x41 = 1 dB
0x5F = 31 dB
14:13 IN1L_
00
Input Path 1 (Left) Source
SRC[1:0]
00 = Differential (IN1ALP–IN1ALN)
10 = Differential (IN1BLP–IN1BLN)
01 = Single-ended (IN1ALP)
11 = Single-ended (IN1BLP)
11 IN1L_LP_
0
Input Path 1 (Left) Low-Power Mode (applicable to analog input only)
MODE
0 = High Performance Mode
1 = Low Power Mode
10:8 IN1_
101 Input Path 1 Oversample Rate Control
OSR[2:0]
If analog input is selected, this field is used to select Mid-Power Mode.
100 = Mid Power Mode
All other codes are reserved
101 = Normal
If digital input is selected, this field controls the DMICCLK1 frequency.
010 = 384 kHz
101 = 3.072 MHz
011 = 768 kHz
110 = 6.144 MHz
100 = 1.536 MHz
All other codes are reserved
15 IN1R_HPF
0
Input Path 1 (Right) HPF Enable
0 = Disabled
1 = Enabled
7:1 IN1R_PGA_ 0x40 Input Path 1 (Right) PGA Volume (applicable to analog input only)
VOL[6:0]
0x00 to 0x3F = Reserved
0x42 = 2 dB
0x60 to 0x7F = Reserved
0x40 = 0 dB
… (1-dB steps)
0x41 = 1 dB
0x5F = 31 dB
14:13 IN1R_
00
Input Path 1 (Right) Source
SRC[1:0]
00 = Differential (IN1ARP–IN1ARN)
10 = Differential (IN1BR–IN1ALN)
01 = Single-ended (IN1ARP)
11 = Single-ended (IN1BR)
11 IN1R_LP_
0
Input Path 1 (Right) Low-Power Mode (applicable to analog input only)
MODE
0 = High Performance Mode
1 = Low Power Mode
DS1162F1
CS42L92
4.2 Input Signal Path
Table 4-3. Input Signal Path Configuration (Cont.)
Register Address
R792 (0x0318)
IN2L_Control
Bit
15
Label
IN2L_HPF
12:11 IN2_DMIC_
SUP[1:0]
R793 (0x0319)
ADC_Digital_
Volume_2L
10
IN2_MODE
7:1
IN2L_PGA_
VOL[6:0]
14:13 IN2L_
SRC[1:0]
11
R794 (0x031A)
DMIC2L_Control
R796 (0x031C)
IN2R_Control
R797 (0x0319)
ADC_Digital_
Volume_2R
R800 (0x0320)
IN3L_Control
IN2L_LP_
MODE
10:8 IN2_
OSR[2:0]
15
IN2R_HPF
7:1
IN2R_PGA_
VOL[6:0]
14:13 IN2R_
SRC[1:0]
11
IN2R_LP_
MODE
15
IN3L_HPF
12:11 IN3_DMIC_
SUP[1:0]
R802 (0x0322)
DMIC3L_Control
R804 (0x0324)
IN3R_Control
DS1162F1
10:8 IN3_
OSR[2:0]
15
IN3R_HPF
Default
Description
0
Input Path 2 (Left) HPF Enable
0 = Disabled
1 = Enabled
00
Input Path 2 DMIC Reference Select (sets the DMICDAT2 and DMICCLK2 logic levels)
00 = MICVDD
10 = MICBIAS2
01 = MICBIAS1
11 = Reserved
0
Input Path 2 Mode
0 = Analog input
1 = Digital input
0x40 Input Path 2 (Left) PGA Volume (applicable to analog input only)
0x00 to 0x3F = Reserved
0x42 = 2 dB
0x60 to 0x7F = Reserved
0x40 = 0 dB
… (1-dB steps)
0x41 = 1 dB
0x5F = 31 dB
00
Input Path 2 (Left) Source
00 = Differential (IN2ALP–IN2ALN)
10 = Differential (IN2BL–IN2ALN)
01 = Single-ended (IN2ALP)
11 = Single-ended (IN2BL)
0
Input Path 2 (Left) Low-Power Mode (applicable to analog input only)
0 = High Performance Mode
1 = Low Power Mode
101 Input Path 2 Oversample Rate Control
If analog input is selected, this field is used to select Mid-Power Mode.
100 = Mid Power Mode
All other codes are reserved
101 = Normal
If digital input is selected, this field controls the DMICCLK2 frequency.
010 = 384 kHz
101 = 3.072 MHz
011 = 768 kHz
110 = 6.144 MHz
100 = 1.536 MHz
All other codes are reserved
0
Input Path 2 (Right) HPF Enable
0 = Disabled
1 = Enabled
0x40 Input Path 2 (Right) PGA Volume (applicable to analog input only)
0x00 to 0x3F = Reserved
0x42 = 2 dB
0x60 to 0x7F = Reserved
0x40 = 0 dB
… (1-dB steps)
0x41 = 1 dB
0x5F = 31 dB
00
Input Path 2 (Right) Source
00 = Differential (IN2ARP–IN2ARN)
10 = Differential (IN2BR–IN2ARN)
01 = Single-ended (IN2ARP)
11 = Single-ended (IN2BR)
0
Input Path 2 (Right) Low-Power Mode (applicable to analog input only)
0 = High Performance Mode
1 = Low Power Mode
0
Input Path 3 (Left) HPF Enable
0 = Disabled
1 = Enabled
00
Input Path 3 DMIC Reference Select (sets the DMICDAT3 and DMICCLK3 logic levels)
00 = MICVDD
10 = MICBIAS2
01 = MICBIAS1
11 = Reserved
101 Input Path 3 Oversample Rate Control - selects the DMICCLK3 frequency.
010 = 384 kHz
101 = 3.072 MHz
011 = 768 kHz
110 = 6.144 MHz
100 = 1.536 MHz
All other codes are reserved
0
Input Path 3 (Right) HPF Enable
0 = Disabled
1 = Enabled
39
CS42L92
4.2 Input Signal Path
Table 4-3. Input Signal Path Configuration (Cont.)
Register Address
R808 (0x0328)
IN4L_Control
R810 (0x032A)
DMIC4L_Control
R812 (0x032C)
IN4R_Control
4.2.7
Bit
15
Label
IN4L_HPF
Default
Description
0
Input Path 4 (Left) HPF Enable
0 = Disabled
1 = Enabled
12:11 IN4_DMIC_
00
Input Path 4 DMIC Reference Select (sets the DMICDAT4 and DMICCLK4 logic levels)
SUP[1:0]
00 = MICVDD
10 = MICBIAS2
01 = MICBIAS1
11 = Reserved
10:8 IN4_
101 Input Path 4 Oversample Rate Control - selects the DMICCLK4 frequency.
OSR[2:0]
010 = 384 kHz
101 = 3.072 MHz
011 = 768 kHz
110 = 6.144 MHz
100 = 1.536 MHz
All other codes are reserved
15 IN4R_HPF
0
Input Path 4 (Right) HPF Enable
0 = Disabled
1 = Enabled
Input Signal Path Digital Volume Control
A digital volume control is provided on each input signal path, providing –64 dB to +31.5 dB gain control in 0.5-dB steps.
An independent mute control is also provided for each input signal path.
Whenever the gain or mute setting is changed, the signal path gain is ramped up or down to the new settings at a
programmable rate. For increasing gain (or unmute), the rate is controlled by IN_VI_RAMP. For decreasing gain (or mute),
the rate is controlled by IN_VD_RAMP.
Note:
The IN_VI_RAMP and IN_VD_RAMP fields should not be changed while a volume ramp is in progress.
The IN_VU bits control the loading of the input signal path digital volume and mute controls. When IN_VU is cleared, the
digital volume and mute settings are loaded into the respective control register, but do not change the signal path gain.
The digital volume and mute settings on all of the input signal paths are updated when a 1 is written to IN_VU. This makes
it possible to update the gain of multiple signal paths simultaneously.
Note that, although the digital-volume controls provide 0.5-dB steps, the internal circuits provide signal gain adjustment in
0.125-dB steps. This allows a very high degree of gain control and smooth volume ramping under all operating conditions.
Note:
The 0 dBFS level of the IN1–IN4 digital input paths is not equal to the 0 dBFS level of the CS42L92 digital core.
The maximum digital input signal level is –6 dBFS (see Table 3-7). Under 0 dB gain conditions, a –6 dBFS input
signal corresponds to a 0 dBFS input to the CS42L92 digital core functions.
The digital volume control registers are described in Table 4-4 and Table 4-5.
Table 4-4. Input Signal Path Digital Volume Control
Register Address
R777 (0x0309)
Input_Volume_
Ramp
40
Bit
6:4
Label
IN_VD_RAMP[2:0]
Default
010
2:0
IN_VI_RAMP[2:0]
010
Description
Input Volume Decreasing Ramp Rate (seconds/6 dB).
This field should not be changed while a volume ramp is in progress.
000 = 0 ms
011 = 2 ms
110 = 15 ms
001 = 0.5 ms
100 = 4 ms
111 = 30 ms
010 = 1 ms
101 = 8 ms
Input Volume Increasing Ramp Rate (seconds/6 dB).
This field should not be changed while a volume ramp is in progress.
000 = 0 ms
011 = 2 ms
110 = 15 ms
001 = 0.5 ms
100 = 4 ms
111 = 30 ms
010 = 1 ms
101 = 8 ms
DS1162F1
CS42L92
4.2 Input Signal Path
Table 4-4. Input Signal Path Digital Volume Control (Cont.)
Register Address
R785 (0x0311)
ADC_Digital_
Volume_1L
Bit
9
Label
IN_VU
8
IN1L_MUTE
7:0
R789 (0x0315)
ADC_Digital_
Volume_1R
9
IN_VU
8
IN1R_MUTE
7:0
R793 (0x0319)
ADC_Digital_
Volume_2L
IN_VU
8
IN2L_MUTE
IN_VU
8
IN2R_MUTE
IN2R_VOL[7:0]
9
IN_VU
8
IN3L_MUTE
7:0
DS1162F1
IN2L_VOL[7:0]
9
7:0
R801 (0x0321)
ADC_Digital_
Volume_3L
IN1R_VOL[7:0]
9
7:0
R797 (0x031D)
ADC_Digital_
Volume_2R
IN1L_VOL[7:0]
IN3L_VOL[7:0]
Default
Description
See
Input Signal Paths Volume and Mute Update. Writing 1 to this bit causes the Input
Footnote 1 Signal Paths Volume and Mute settings to be updated simultaneously
1
Input Path 1 (Left) Digital Mute
0 = Unmute
1 = Mute
0x80
Input Path 1 (Left) Digital Volume (see Table 4-5 for volume register definition).
–64 dB to +31.5 dB in 0.5-dB steps
0x00 = –64 dB
0x80 = 0 dB
0xC0 to 0xFF = Reserved
0x01 = –63.5 dB
… (0.5-dB steps)
… (0.5-dB steps)
0xBF = +31.5 dB
See
Input Signal Paths Volume and Mute Update
Footnote 1 Writing 1 to this bit causes the Input Signal Paths Volume and Mute settings to be
updated simultaneously
1
Input Path 1 (Right) Digital Mute
0 = Unmute
1 = Mute
0x80
Input Path 1 (Right) Digital Volume (see Table 4-5 for volume register definition).
–64 dB to +31.5 dB in 0.5-dB steps
0x00 = –64 dB
0x80 = 0 dB
0xC0 to 0xFF = Reserved
0x01 = –63.5 dB
… (0.5-dB steps)
… (0.5-dB steps)
0xBF = +31.5 dB
See
Input Signal Paths Volume and Mute Update. Writing 1 to this bit causes the Input
Footnote 1 Signal Paths Volume and Mute settings to be updated simultaneously
1
Input Path 2 (Left) Digital Mute
0 = Unmute
1 = Mute
0x80
Input Path 2 (Left) Digital Volume (see Table 4-5 for volume register definition).
–64 dB to +31.5 dB in 0.5-dB steps
0x00 = –64 dB
0x80 = 0 dB
0xC0 to 0xFF = Reserved
0x01 = –63.5 dB
… (0.5-dB steps)
… (0.5-dB steps)
0xBF = +31.5 dB
See
Input Signal Paths Volume and Mute Update. Writing 1 to this bit causes the Input
Footnote 1 Signal Paths Volume and Mute settings to be updated simultaneously
1
Input Path 2 (Right) Digital Mute
0 = Unmute
1 = Mute
0x80
Input Path 2 (Right) Digital Volume (see Table 4-5 for volume register definition).
–64 dB to +31.5 dB in 0.5-dB steps
0x00 = –64 dB
0x80 = 0 dB
0xC0 to 0xFF = Reserved
0x01 = –63.5 dB
… (0.5-dB steps)
… (0.5-dB steps)
0xBF = +31.5 dB
See
Input Signal Paths Volume and Mute Update. Writing 1 to this bit causes the Input
Footnote 1 Signal Paths Volume and Mute settings to be updated simultaneously
1
Input Path 3 (Left) Digital Mute
0 = Unmute
1 = Mute
0x80
Input Path 3 (Left) Digital Volume (see Table 4-5 for volume register definition).
–64 dB to +31.5 dB in 0.5-dB steps
0x00 = –64 dB
0x80 = 0 dB
0xC0 to 0xFF = Reserved
0x01 = –63.5 dB
… (0.5-dB steps)
… (0.5-dB steps)
0xBF = +31.5 dB
41
CS42L92
4.2 Input Signal Path
Table 4-4. Input Signal Path Digital Volume Control (Cont.)
Register Address
R805 (0x0325)
ADC_Digital_
Volume_3R
Bit
9
Label
IN_VU
Default
Description
See
Input Signal Paths Volume and Mute Update. Writing 1 to this bit causes the Input
Footnote 1 Signal Paths Volume and Mute settings to be updated simultaneously
8
IN3R_MUTE
1
Input Path 3 (Right) Digital Mute
0 = Unmute
1 = Mute
7:0 IN3R_VOL[7:0]
0x80
Input Path 3 (Right) Volume (see Table 4-5 for volume register definition).
–64 dB to +31.5 dB in 0.5-dB steps
0x00 = –64 dB
0x80 = 0 dB
0xC0 to 0xFF = Reserved
0x01 = –63.5 dB
… (0.5-dB steps)
… (0.5-dB steps)
0xBF = +31.5 dB
R809 (0x0329)
9
IN_VU
See
Input Signal Paths Volume and Mute Update. Writing 1 to this bit causes the Input
Footnote 1 Signal Paths Volume and Mute settings to be updated simultaneously
ADC_Digital_
Volume_4L
8
IN4L_MUTE
1
Input Path 4 (Left) Digital Mute
0 = Unmute
1 = Mute
7:0 IN4L_VOL[7:0]
0x80
Input Path 4 (Left) Digital Volume (see Table 4-5 for volume register definition).
–64 dB to +31.5 dB in 0.5-dB steps
0x00 = –64 dB
0x80 = 0 dB
0xC0 to 0xFF = Reserved
0x01 = –63.5 dB
… (0.5-dB steps)
… (0.5-dB steps)
0xBF = +31.5 dB
R813 (0x032D)
9
IN_VU
See
Input Signal Paths Volume and Mute Update. Writing 1 to this bit causes the Input
Footnote 1 Signal Paths Volume and Mute settings to be updated simultaneously
ADC_Digital_
Volume_4R
8
IN4R_MUTE
1
Input Path 4 (Right) Digital Mute
0 = Unmute
1 = Mute
7:0 IN4R_VOL[7:0]
0x80
Input Path 4 (Right) Digital Volume (see Table 4-5 for volume register definition).
–64 dB to +31.5 dB in 0.5-dB steps
0x00 = –64 dB
0x80 = 0 dB
0xC0 to 0xFF = Reserved
0x01 = –63.5 dB
… (0.5-dB steps)
… (0.5-dB steps)
0xBF = +31.5 dB
1. Default is not applicable to these write-only bits
Table 4-5 lists the input signal path digital volume settings.
Table 4-5. Input Signal Path Digital Volume Range
Input Volume
Register
0x00
0x01
0x02
0x03
0x04
0x05
0x06
0x07
0x08
0x09
0x0A
0x0B
0x0C
0x0D
0x0E
0x0F
0x10
0x11
42
Volume (dB)
–64.0
–63.5
–63.0
–62.5
–62.0
–61.5
–61.0
–60.5
–60.0
–59.5
–59.0
–58.5
–58.0
–57.5
–57.0
–56.5
–56.0
–55.5
Input Volume
Register
0x31
0x32
0x33
0x34
0x35
0x36
0x37
0x38
0x39
0x3A
0x3B
0x3C
0x3D
0x3E
0x3F
0x40
0x41
0x42
Volume (dB)
–39.5
–39.0
–38.5
–38.0
–37.5
–37.0
–36.5
–36.0
–35.5
–35.0
–34.5
–34.0
–33.5
–33.0
–32.5
–32.0
–31.5
–31.0
Input Volume
Register
0x62
0x63
0x64
0x65
0x66
0x67
0x68
0x69
0x6A
0x6B
0x6C
0x6D
0x6E
0x6F
0x70
0x71
0x72
0x73
Volume (dB)
–15.0
–14.5
–14.0
–13.5
–13.0
–12.5
–12.0
–11.5
–11.0
–10.5
–10.0
–9.5
–9.0
–8.5
–8.0
–7.5
–7.0
–6.5
Input Volume
Register
0x93
0x94
0x95
0x96
0x97
0x98
0x99
0x9A
0x9B
0x9C
0x9D
0x9E
0x9F
0xA0
0xA1
0xA2
0xA3
0xA4
Volume (dB)
9.5
10.0
10.5
11.0
11.5
12.0
12.5
13.0
13.5
14.0
14.5
15.0
15.5
16.0
16.5
17.0
17.5
18.0
DS1162F1
CS42L92
4.2 Input Signal Path
Table 4-5. Input Signal Path Digital Volume Range (Cont.)
Input Volume
Register
0x12
0x13
0x14
0x15
0x16
0x17
0x18
0x19
0x1A
0x1B
0x1C
0x1D
0x1E
0x1F
0x20
0x21
0x22
0x23
0x24
0x25
0x26
0x27
0x28
0x29
0x2A
0x2B
0x2C
0x2D
0x2E
0x2F
0x30
4.2.8
Volume (dB)
–55.0
–54.5
–54.0
–53.5
–53.0
–52.5
–52.0
–51.5
–51.0
–50.5
–50.0
–49.5
–49.0
–48.5
–48.0
–47.5
–47.0
–46.5
–46.0
–45.5
–45.0
–44.5
–44.0
–43.5
–43.0
–42.5
–42.0
–41.5
–41.0
–40.5
–40.0
Input Volume
Register
0x43
0x44
0x45
0x46
0x47
0x48
0x49
0x4A
0x4B
0x4C
0x4D
0x4E
0x4F
0x50
0x51
0x52
0x53
0x54
0x55
0x56
0x57
0x58
0x59
0x5A
0x5B
0x5C
0x5D
0x5E
0x5F
0x60
0x61
Volume (dB)
–30.5
–30.0
–29.5
–29.0
–28.5
–28.0
–27.5
–27.0
–26.5
–26.0
–25.5
–25.0
–24.5
–24.0
–23.5
–23.0
–22.5
–22.0
–21.5
–21.0
–20.5
–20.0
–19.5
–19.0
–18.5
–18.0
–17.5
–17.0
–16.5
–16.0
–15.5
Input Volume
Register
0x74
0x75
0x76
0x77
0x78
0x79
0x7A
0x7B
0x7C
0x7D
0x7E
0x7F
0x80
0x81
0x82
0x83
0x84
0x85
0x86
0x87
0x88
0x89
0x8A
0x8B
0x8C
0x8D
0x8E
0x8F
0x90
0x91
0x92
Volume (dB)
–6.0
–5.5
–5.0
–4.5
–4.0
–3.5
–3.0
–2.5
–2.0
–1.5
–1.0
–0.5
0.0
0.5
1.0
1.5
2.0
2.5
3.0
3.5
4.0
4.5
5.0
5.5
6.0
6.5
7.0
7.5
8.0
8.5
9.0
Input Volume
Register
0xA5
0xA6
0xA7
0xA8
0xA9
0xAA
0xAB
0xAC
0xAD
0xAE
0xAF
0xB0
0xB1
0xB2
0xB3
0xB4
0xB5
0xB6
0xB7
0xB8
0xB9
0xBA
0xBB
0xBC
0xBD
0xBE
0xBF
0xC0–0xFF
Volume (dB)
18.5
19.0
19.5
20.0
20.5
21.0
21.5
22.0
22.5
23.0
23.5
24.0
24.5
25.0
25.5
26.0
26.5
27.0
27.5
28.0
28.5
29.0
29.5
30.0
30.5
31.0
31.5
Reserved
Input Signal Path Signal-Detect Control
The CS42L92 provides a digital signal-detect function for the input signal path. This enables system actions to be triggered
by signal detection and allows the device to remain in a low-power state until a valid audio signal is detected. A mute
function is integrated with the signal-detect circuit, ensuring the respective digital audio path remains at zero until the
detection threshold level is reached. Signal detection is also indicated via the interrupt controller.
The signal-detect function is supported on input paths IN1–IN4 in analog and digital configurations. (For input paths IN1
and IN2, digital input is selected by setting the respective INn_MODE bit.) Note that the valid operating conditions for this
function vary, depending on the applicable signal-path configuration.
•
The signal-detect function is supported on analog input paths for sample rates up to 16 kHz.
•
The signal-detect function is supported on digital input paths for sample rates up to 16 kHz (if DMICCLKn 768kHz)
and up to 48 kHz (if DMICCLKn 2.8224 MHz).
For each input path, the signal-detect function is enabled by setting the respective INnx_SIG_DET_ENA bit. The detection
threshold level is set using IN_SIG_DET_THR—this applies to all input paths.
If the signal-detect function is enabled, the respective input channel is muted if the signal level is below the configured
threshold. If the input signal exceeds the threshold level, the respective channel is immediately unmuted.
DS1162F1
43
CS42L92
4.2 Input Signal Path
If the input signal falls below the threshold level, the mute is applied. To prevent erroneous behavior, a time delay is applied
before muting the input signal—the channel is only muted if the signal level remains below the threshold level for longer
than the hold time. The hold time is set using IN_SIG_DET_HOLD.
Note that the signal-level detection is performed in the digital domain, after the ADC, PGA, digital mute and digital volume
controls—the respective input channel must be enabled and unmuted when using the signal-detect function.
The signal-detect function is an input to the interrupt control circuit and can be used to trigger an interrupt event; see
Section 4.15. Note that the respective interrupt event represents the logic OR of the signal detection on all input channels
and does not provide indication of which input channel caused the interrupt. To avoid multiple interrupts, the signal-detect
interrupt can be reasserted only after all input channels have fallen below the trigger threshold level.
The input path signal-detection control registers are described in Table 4-6.
Table 4-6. Input Signal Path Signal-Detect Control
Register Address
R786 (0x0312)
DMIC1L_Control
Bit
15
Label
IN1L_SIG_DET_
ENA
R790 (0x0316)
DMIC1R_Control
15
IN1R_SIG_DET_
ENA
R794 (0x031A)
DMIC2L_Control
15
IN2L_SIG_DET_
ENA
R798 (0x031E)
DMIC2R_Control
15
IN2R_SIG_DET_
ENA
R802 (0x0320)
DMIC3L_Control
15
IN3L_SIG_DET_
ENA
R806 (0x0326)
DMIC3R_Control
15
IN3R_SIG_DET_
ENA
R810 (0x032A)
DMIC4L_Control
15
IN4L_SIG_DET_
ENA
R814 (0x032E)
DMIC4R_Control
15
IN4R_SIG_DET_
ENA
R832 (0x0340)
Signal_Detect_Globals
8:4
IN_SIG_DET_
THR[4:0]
3:0
IN_SIG_DET_
HOLD[3:0]
4.2.9
Default
Description
0
Input Path 1 (Left) Signal-Detect Enable
0 = Disabled
1 = Enabled
0
Input Path 1 (Right) Signal-Detect Enable
0 = Disabled
1 = Enabled
0
Input Path 2 (Left) Signal-Detect Enable
0 = Disabled
1 = Enabled
0
Input Path 2 (Right) Signal-Detect Enable
0 = Disabled
1 = Enabled
0
Input Path 3 (Left) Signal-Detect Enable
0 = Disabled
1 = Enabled
0
Input Path 3 (Right) Signal-Detect Enable
0 = Disabled
1 = Enabled
0
Input Path 4 (Left) Signal-Detect Enable
0 = Disabled
1 = Enabled
0
Input Path 4 (Right) Signal-Detect Enable
0 = Disabled
1 = Enabled
0x00 Input Signal Path Signal-Detect Threshold
0x0A = –72.2 dB
0x00 = –30.1 dB
0x05 = –54.2 dB
0x0B = –74.7 dB
0x06 = –56.7 dB
0x01 = –36.1 dB
0x0C = –78.3 dB
0x07 = –60.2 dB
0x02 = –42.1 dB
0x08 = –66.2 dB
0x0D = –80.8 dB
0x03 = –48.2 dB
0x04 = –50.7 dB
0x09 = –68.7 dB
All other codes are reserved
0001 Input Signal Path Signal-Detect Hold Time (delay before signal detect indication
is deasserted)
0000 = Reserved
... (4-ms steps)
1100 = 96–100 ms
0001 = 4–8 ms
1001 = 36–40 ms
1101 = 192–196 ms
1110 = 384–388 ms
0010 = 8–12 ms
1010 = 40–44 ms
1111 = 768–772 ms
1011 = 48–52 ms
0011 = 12–16 ms
Ultrasonic Signal Demodulation
The CS42L92 provides ultrasonic signal-processing functions on the input signal paths. Configurable filters and
demodulator functions enable ultrasonic signals to be translated down to the audio band and routed through the digital
mixer core. Two ultrasonic processing blocks are incorporated, with independent configuration controls for each.
44
DS1162F1
CS42L92
4.2 Input Signal Path
The input source for the ultrasonic blocks is configured using the USn_SRC fields (where n identifies the applicable block
US1 or US2). The input signal gain is set using USn_GAIN. The input frequency range is selected by USn_FREQ.
The ultrasonic functions can be supported on any of the input signal paths (IN1–IN4). The inputs to the ultrasonic functions
are independent of the enable, mute, and digital-volume settings of the respective input signal paths—the ultrasonic
functions do not require the selected input signal paths to be enabled, and the mute/digital-volume settings of the input
signal paths have no effect on the ultrasonic functions.
The system clock, SYSCLK, must be present and enabled when using the ultrasonic functions. The SYSCLK frequency
must be a multiple of 6.144 MHz (SYSCLK_FRAC = 0) in this case. See Section 4.16 for details of SYSCLK and the
associated registers.
The ultrasonic demodulator function is enabled by setting USn_ENA. The frequency band and signal gain are selected
using USn_FREQ and USn_GAIN respectively.
The output from the ultrasonic demodulator is a frequency-modulated image of the selected input frequency range. The
folding frequency that characterizes the frequency modulation is set according to the USn_FREQ setting—see Table 4-7.
The relationship between input and output frequencies is described in Eq. 4-1.
F OUT = F IN – F FOLD
Equation 4-1. Ultrasonic Demodulator Characteristic
Note that, depending on the input frequency range and the folding frequency, FFOLD, the modulated output in respect of
certain input frequencies may overlap others. This effect arises if the folding frequency lies within the input frequency
range, with the result that two different input frequencies will each be modulated to the same output frequency. This effect
is limited to the outer edges of the input frequency range in all cases. Amplitude response across the input frequency range
is flat to within 1.5 dB in all cases.
The demodulated ultrasonic outputs can be selected as input to the digital mixers or signal-processing functions within the
digital core by setting the respective x_SRCn fields as described in Section 4.3.1.
The sample rate for the demodulated ultrasonic output is configured using USn_RATE—see Table 4-26. The selected
sample rate must be one of the SYSCLK-related rates, and must be equal to the output rate set by USn_FREQ (see
Table 4-7). Note that sample-rate conversion is required when routing the ultrasonic signals to any signal chain that is
asynchronous or configured for a different sample rate.
The characteristics associated with the USn_FREQ field setting are shown in Table 4-7.
Table 4-7. Ultrasonic Frequency Control
Condition
Input Frequency Band
Output Sample Rate
USn_FREQ = 000
USn_FREQ = 001
USn_FREQ = 010
USn_FREQ = 011
24.5–40.5 kHz
18–22 kHz
16–24 kHz
20–28 kHz
32 kHz
8 kHz
16 kHz
16 kHz
Demodulator Folding
Frequency (FFOLD)
40.42 kHz
18.29 kHz
16 kHz
20.21 kHz
The ultrasonic demodulation control registers are described in Table 4-8.
DS1162F1
45
CS42L92
4.2 Input Signal Path
Table 4-8. Ultrasonic Signal Demodulation Control
Register Address Bit
Label
R4224 (0x1080)
13:12 US1_GAIN[1:0]
US1_Ctrl_0
11:8
6:4
0
R4226 (0x1082)
US2_Ctrl_0
Default
Description
10
Ultrasonic Demodulator 1 Gain
00 = Disabled (no signal)
10 = 1 dB
01 = –5 dB
11 = 7 dB
0x0
Ultrasonic Demodulator 1 Source
0x0 = IN1L
0x3 = IN2R
0x1 = IN1R
0x4 = IN3L
0x2 = IN2L
0x5 = IN3R
US1_SRC[3:0]
US1_FREQ[2:0]
011
US1_ENA
0
13:12 US2_GAIN[1:0]
11:8
6:4
0
10
US2_SRC[3:0]
0x0
US2_FREQ[2:0]
011
US2_ENA
0
Ultrasonic Demodulator 1 Frequency
000 = 24.5–40.5 kHz
010 = 16–24 kHz
001 = 18–22 kHz
011 = 20–28 kHz
Ultrasonic Demodulator 1 Enable
0 = Disabled
1 = Enabled
Ultrasonic Demodulator 2 Gain
00 = Disabled (no signal)
10 = 1 dB
01 = –5 dB
11 = 7 dB
Ultrasonic Demodulator 2 Source
0x0 = IN1L
0x3 = IN2R
0x1 = IN1R
0x4 = IN3L
0x2 = IN2L
0x5 = IN3R
Ultrasonic Demodulator 2 Frequency
000 = 24.5–40.5 kHz
010 = 16–24 kHz
001 = 18–22 kHz
011 = 20–28 kHz
Ultrasonic Demodulator 2 Enable
0 = Disabled
1 = Enabled
0x6 = IN4L
0x7 = IN4R
All other codes are
reserved
All other codes are
reserved
0x6 = IN4L
0x7 = IN4R
All other codes are
reserved
All other codes are
reserved
4.2.10 Auxiliary PDM Interface
The auxiliary PDM interface supports a one-channel digital output derived from one of the CS42L92 analog input paths.
This can be used to provide an audio path between an analog microphone connected to the CS42L92 and a digital input
to an external audio processor.
The auxiliary PDM interface signal path is shown in Fig. 4-13.
IN1xLN
-
IN1xLP
IN1L
ADC
Auxiliary PDM
interface
+
IN1R
IN2L
IN2R
CLK
DAT
GPIO
configuration
GPIO3/GPIO10
GPIO4/GPIO9
AUXPDM1_SRC[3:0] p. 48
The Auxiliary PDM interface takes one of the analog
input paths as its signal source. The signal path
(e.g., IN1L) does not need to be enabled.
In Master Mode, CLK is output from the CS42L92.
In Slave Mode, CLK is input to the CS42L92.
In Slave Mode, the GPIO9 and GPIO10 pins must be used.
Figure 4-13. Auxiliary PDM Interface
The input source for the auxiliary PDM interface is selected using AUXPDM1_SRC. Note that the selected input path must
be configured for analog input—the auxiliary PDM function is not supported for the DMICDATn inputs.
46
DS1162F1
CS42L92
4.2 Input Signal Path
Note:
The input to the auxiliary PDM interface is independent of the enable, mute, and digital-volume settings of the
respective input signal path—the auxiliary PDM function does not require the selected input signal paths to be
enabled, and the mute/digital-volume settings of the input signal paths have no effect on the auxiliary PDM
function.
The auxiliary PDM interface is enabled by setting AUXPDM1_ENA. Note that the other auxiliary PDM control fields should
be configured before enabling the interface. The external connections (GPIO pins) should also be configured before
enabling the interface; the AUXPDM1_ENA bit should be set as the final step of the enable sequence. The AUXPDM1_
ENA bit should be cleared before changing the interface configuration.
The output signal can be muted and unmuted using AUXPDM1_MUTE.
The interface operates in master or slave modes, selected using the AUXPDM1_MSTR bit. In Master Mode, the clock
(CLK) signal is generated by the CS42L92; in Slave Mode, the CLK signal is an input to the CS42L92.
The CLK frequency is selected using the AUXPDM1_CLK_FREQ field. For each setting of this field, the actual frequency
depends on whether SYSCLK is configured for 48- or 44.1-kHz related sample rates. See Section 4.16 for details of the
system clocks. Note that the CLK frequency must be configured in master and slave modes, using the AUXPDM1_CLK_
FREQ field.
The timing of the data (DAT) output signal can be controlled using AUXPDM1_TXEDGE. This selects whether the DAT
output changes on the rising or falling edge of CLK.
The auxiliary PDM interface timing is shown in Fig. 4-14. In Master Mode, the clock and data outputs are driven
synchronously by the CS42L92. In Slave Mode, the timing of the output data is controlled by the external clock input.
In Slave Mode, the CS42L92 system clock (SYSCLK) must be synchronized to the CLK input. This is achieved by using
one of the FLLs to generate the system clock, with AIF2BCLK configured as the FLL clock reference. (If the auxiliary PDM
interface is configured in Slave Mode, the CLK input is supported on the AIF2BCLK/GPIO10 pin.) Further details of the
FLLs are provided in Section 4.16.8.
Aux PDM clock
Aux PDM data
(AUXPDM1_TXEDGE = 0)
Aux PDM data
(AUXPDM1_TXEDGE = 1)
Figure 4-14. Auxiliary PDM Interface Timing
The external connections associated with the auxiliary PDM interface are implemented on GPIO pins, which must be
configured for the respective CLK and DAT functions. The auxiliary PDM signals are alternative functions available on
specific GPIO pins only. See Section 4.14 to configure the GPIO pins for the auxiliary PDM interface. Note that the output
pins (including the CLK function, if Master Mode is selected) must be configured as outputs using the respective GPn_DIR
fields.
•
In Master Mode, the CLK output can be configured on the GPIO3 or GPIO10 pins. The DAT output can be
configured on GPIO4 or GPIO9.
•
In Slave Mode, the CLK input is supported on GPIO10 only. The DAT output is supported on GPIO9.
The auxiliary PDM interface control registers are described in Table 4-9.
DS1162F1
47
CS42L92
4.2 Input Signal Path
Table 4-9. Auxiliary PDM Interface Control
Register Address
R4288 (0x10C0)
AUXPDM1_Ctrl_0
R4281 (0x10C1)
AUXPDM1_Ctrl_1
Bit
11:8
Label
AUXPDM1_SRC[3:0]
Default
Description
0x0
Auxiliary PDM 1 Source
0x0 = IN1L
0x3 = IN2R
0x1 = IN1R
All other codes are reserved
0x2 = IN2L
Note that the selected input source must be configured for analog input—
digital input paths are not supported. The Auxiliary PDM interface must be
disabled when updating this field.
4
AUXPDM1_TXEDGE
0
Auxiliary PDM 1 Timing
0 = Output data is driven on rising edge of AUXPDM1_CLK
1 = Output data is driven on falling edge of AUXPDM1_CLK
The Auxiliary PDM interface must be disabled when updating this field.
3
AUXPDM1_MSTR
1
Auxiliary PDM 1 Master Mode select
0 = AUXPDM1_CLK Slave Mode (input)
1 = AUXPDM1_CLK Master mode (output)
The Auxiliary PDM interface must be disabled when updating this field.
2
AUXPDM1_MUTE
0
Auxiliary PDM 1 Mute
0 = Unmute
1 = Mute
0
AUXPDM1_ENA
0
Auxiliary PDM 1 Enable
0 = Disabled
1 = Enabled
15:14 AUXPDM1_FREQ[1:0]
01
Auxiliary PDM 1 CLK Rate
00 = 3.072 MHz (2.8824 MHz)
10 = 1.536 MHz (1.4112 MHz)
01 = 2.048 MHz (1.8816 MHz)
11 = 768 kHz (705.6 kHz)
The frequencies in brackets apply for 44.1 kHz–related sample rates only
(i.e., if SYSCLK_FRAC = 1). The Auxiliary PDM interface must be disabled
when updating this field.
4.2.11 DMIC Pin Configuration
DMIC operation on input paths IN1–IN4 is selected using INn_MODE, as described in Table 4-3. If DMIC is selected, the
respective DMICCLKn and DMICDATn pins are configured as digital outputs and inputs, respectively.
The CS42L92 provides integrated pull-down resistors on each DMICDATn pin. This provides a flexible capability for
interfacing with other devices.
The DMICDATn pull-down resistors can be configured independently using the bits described in Table 4-10. Note that, if
the DMICDATn DMIC input paths are disabled, the pull-down is disabled on the respective pin.
Table 4-10. DMIC Interface Pull-Down Control
Register Address
R840 (0x0348)
Dig_Mic_Pad_Ctrl
48
Bit
3
Label
DMICDAT4_PD
Default
0
2
DMICDAT3_PD
0
1
DMICDAT2_PD
0
0
DMICDAT1_PD
0
Description
DMICDAT4 Pull-Down Control
0 = Disabled
1 = Enabled
DMICDAT3 Pull-Down Control
0 = Disabled
1 = Enabled
DMICDAT2 Pull-Down Control
0 = Disabled
1 = Enabled
DMICDAT1 Pull-Down Control
0 = Disabled
1 = Enabled
DS1162F1
CS42L92
4.3 Digital Core
4.3 Digital Core
The CS42L92 digital core provides extensive mixing and processing capabilities for multiple signal paths. The
configuration is highly flexible and supports virtually every conceivable input/output connection between the available
processing blocks.
The digital core provides parametric equalization (EQ) functions, DRC, and low-/high-pass filters (LHPF).
The CS42L92 supports multiple signal paths through the digital core. Stereo full-duplex sample-rate conversion is provided
to allow digital audio to be routed between input (ADC) paths, output (DAC) paths, digital audio interfaces (AIF1–AIF3)
and SLIMbus paths operating at different sample rates or referenced to asynchronous clock domains. Data-format
conversion (DFC) functions are available to support different interface standards on the input and output signal paths.
The integrated DSP provides a general-purpose signal processing capability; this is supported by general-purpose timer
and event-logger functions. Note that the DSP configuration data is lost whenever the DCVDD power domain is removed;
the DSP configuration data must be downloaded to the CS42L92 each time the device is powered up.
The digital core incorporates a S/PDIF transmitter that can provide a stereo S/PDIF output on a GPIO pin. Standard
sample rates of 32–192 kHz can be supported. The CS42L92 incorporates a tone generator that can be used for beep
functions through any of the audio signal paths. A white-noise generator is incorporated, to provide comfort noise in cases
where silence (digital mute) is not desirable.
A haptic signal generator is provided, for use with external haptic devices (e.g., mechanical vibration actuators). Two
pulse-width modulation (PWM) signal generators are also provided; the PWM waveforms can be modulated by an audio
source within the digital core and can be output on a GPIO pin.
An overview of the digital-core mixing and signal-processing functions is provided in Fig. 4-15. The control registers
associated with the digital-core signal paths are shown in Fig. 4-16 through Fig. 4-33. The full list of digital mixer control
registers (R1600–R3576) is provided in Section 6. Generic register field definitions are provided in Table 4-11.
The digital audio core is predominantly a 24-bit architecture, but also provides support for 32-bit signal paths. Audio data
samples of up to 32 bits can be received via the AIF1, AIF3, and SLIMbus input channels and routed to the AIF1, AIF3,
SLIMbus, S/PDIF, and DAC output paths. The respective output mixers provide full support for 32-bit data words.
Note that all other signal paths and signal-processing blocks within the digital core are limited to 24-bit data length; data
samples are truncated to 24-bit length if they are routed through any function that does not support 32-bit data words.
DS1162F1
49
CS42L92
4.3 Digital Core
DSP1
Silence (mute)
IN1L signal path
IN1R signal path
AEC1 Loopback
IN2L signal path
DSP1 Ch 1
+
AEC2 Loopback
DSP1 Ch 2
IN2R signal path
IN3L signal path
DSP1 Ch 3
DSP Core
Ultrasonic 1 path
IN3R signal path
DSP1 Ch 4
IN4L signal path
IN4R signal path
+
Ultrasonic 2 path
DSP1 Ch 5
DSP1 Ch 6
ISRC2
ISRC1
ASRC1
ASRC1 Left
Asynchronous
Sample Rate
Converter (ASRC)
Isochronous
Sample Rate
Converter (ISRC)
ASRC1 Right
ASRC1 Left
ISRCn DEC1
ASRC1 Right
ISRCn DEC2
OUT5
OUT3
OUT2
OUT1
ISRCn INT1
ISRCn INT2
+
Stereo
Output
Paths
DFC8
DFC7
DFC6
DFC5
DFC
DFC4
DFC3
DFC2
DFC1
DFC
DFCn
OUTnL output
+
OUTnR output
DFCn
SLIMbus
SLIMbus = 8 input , 8 output
PWM2
PWM1
+
PWM
LHPF
+
LHPFn
AIFn TX1 output
EQ4
EQ3
EQ2
EQ1
(GPIO pin)
+
Haptic Signal
Generator
AIF1
(GPIO pin)
+
S/PDIF
AIF3
AIF2
LHPF4
LHPF3
LHPF2
LHPF1
EQ
+
AIFn TX2 output
EQn
+
AIFn TX... output
Haptic Output
DRC2
DRC1
White Noise
Generator
+
AIFn TX... output
+
DRCn
Left
Noise Generator
etc...
DRC
+
Tone Generator
Tone Generator 1
AIFn RX1
DRCn
Right
AIF1 = 8 input , 8 output
AIF2 = 8 input , 8 output
AIF3 = 8 input , 8 output
AIFn RX2
AIFn RX...
Tone Generator 2
AIFn RX...
Figure 4-15. Digital Core
50
DS1162F1
CS42L92
4.3 Digital Core
4.3.1
Digital-Core Mixers
The CS42L92 provides an extensive digital mixing capability. The digital-core mixing and signal-processing blocks are
shown in Fig. 4-15. A four-input digital mixer is associated with many of these functions, as shown. The digital mixer circuit
is identical in each instance, providing up to four selectable input sources, with independent volume control on each input.
The control registers associated with the digital-core signal paths are shown in Fig. 4-16–Fig. 4-33. The full list of digital
mixer control registers (R1600–R3576) is provided in Section 6.
Further description of the associated control registers is provided throughout Section 4.3. Generic register field definitions
are provided in Table 4-11.
The digital mixer input sources are selected using the associated x_SRCn fields; the volume control is implemented via
the associated x_VOLn fields.
The ASRC, ISRC, DFC, and DSP auxiliary input functions support selectable input sources, but do not incorporate any
digital mixing. The respective input source (x_SRCn) fields are identical to those of the digital mixers.
The x_SRCn fields select the input sources for the respective mixer or signal-processing block. Note that the selected input
sources must be configured for the same sample rate as the blocks to which they are connected. Sample-rate conversion
functions are available to support flexible interconnectivity; see Section 4.3.15 and Section 4.3.16. The DFCs provide
support for different data types, including floating point formats. Note that, if unsigned or floating point data is present within
the digital core, some restrictions on the valid signal routing options apply—see Section 4.3.13.
A status bit is associated with each configurable input source. If an underclocked error condition occurs, these bits indicate
which signal paths have been enabled.
The generic register field definition for the digital mixers is provided in Table 4-11.
DS1162F1
51
CS42L92
4.3 Digital Core
Table 4-11. Digital-Core Mixer Control Registers
Register Address Bit
Label
R1600 (0x0640)
15 x_STSn
to
R3576 (0x0DF8)
7:1 x_VOLn
7:0 x_SRCn
4.3.2
Default
Description
0
[Digital Core function] input n status
0 = Disabled
1 = Enabled
0x40 [Digital Core mixer] input n volume. (–32 dB to +16 dB in 1-dB steps)
0x00 to 0x20 = –32 dB
... (1-dB steps)
0x50 = +16 dB
0x21 = –31 dB
0x40 = 0 dB
0x51 to 0x7F = +16 dB
0x22 = –30 dB
... (1-dB steps)
0x00 [Digital Core function] input n source select
0x63 = LHPF4
0x2E = AIF2 RX7
0x00 = Silence (mute)
0x68 = DSP1 Channel 1
0x2F = AIF2 RX8
0x04 = Tone generator 1
0x69 = DSP1 Channel 2
0x30 = AIF3 RX1
0x05 = Tone generator 2
0x6A = DSP1 Channel 3
0x31 = AIF3 RX2
0x06 = Haptic generator
0x6B = DSP1 Channel 4
0x08 = AEC Loop-Back 1 0x32 = AIF3 RX3
0x6C = DSP1 Channel 5
0x09 = AEC Loop-Back 2 0x33 = AIF3 RX4
0x6D = DSP1 Channel 6
0x34 = AIF3 RX5
0x0D = Noise generator
0x90 = ASRC1 IN1 Left
0x35 = AIF3 RX6
0x10 = IN1L signal path
0x91 = ASRC1 IN1 Right
0x36 = AIF3 RX7
0x11 = IN1R signal path
0x92 = ASRC1 IN2 Left
0x37 = AIF3 RX8
0x12 = IN2L signal path
0x93 = ASRC1 IN2 Right
0x38 = SLIMbus RX1
0x13 = IN2R signal path
0xA0 = ISRC1 INT1
0x39 = SLIMbus RX2
0x14 = IN3L signal path
0xA1 = ISRC1 INT2
0x3A = SLIMbus RX3
0x15 = IN3R signal path
0xA4 = ISRC1 DEC1
0x3B = SLIMbus RX4
0x16 = IN4L signal path
0xA5 = ISRC1 DEC2
0x3C = SLIMbus RX5
0x17 = IN4R signal path
0xA8 = ISRC2 INT1
0x3D = SLIMbus RX6
0x20 = AIF1 RX1
0xA9 = ISRC2 INT2
0x3E = SLIMbus RX7
0x21 = AIF1 RX2
0xAC = ISRC2 DEC1
0x3F = SLIMbus RX8
0x22 = AIF1 RX3
0xAD = ISRC2 DEC2
0x50 = EQ1
0x23 = AIF1 RX4
0xF0 = US1
0x51 = EQ2
0x24 = AIF1 RX5
0xF1 = US2
0x52 = EQ3
0x25 = AIF1 RX6
0xF8 = DFC1
0x53 = EQ4
0x26 = AIF1 RX7
0xF9 = DFC2
0x58 = DRC1 Left
0x27 = AIF1 RX8
0xFA = DFC3
0x59 = DRC1 Right
0x28 = AIF2 RX1
0xFB = DFC4
0x5A = DRC2 Left
0x29 = AIF2 RX2
0xFC = DFC5
0x5B = DRC2 Right
0x2A = AIF2 RX3
0xFD = DFC6
0x60 = LHPF1
0x2B = AIF2 RX4
0xFE = DFC7
0x61 = LHPF2
0x2C = AIF2 RX5
0xFF = DFC8
0x62 = LHPF3
0x2D = AIF2 RX6
Digital-Core Inputs
The digital core comprises multiple input paths, as shown in Fig. 4-16. Any of these inputs may be selected as a source
to the digital mixers or signal-processing functions within the CS42L92 digital core.
Note that the outputs from other blocks within the digital core may also be selected as input to the digital mixers or
signal-processing functions within the CS42L92 digital core. Those input sources, which are not shown in Fig. 4-16, are
described separately throughout Section 4.3.
The hexadecimal numbers in Fig. 4-16 indicate the corresponding x_SRCn setting for selection of that signal as an input
to another digital-core function.
The sample rate for the input signal paths is configured by using the applicable IN_RATE, AIFn_RATE, SLIMRXn_RATE,
or USn_RATE field; see Table 4-26. Note that sample-rate conversion is required when routing the input signal paths to
any signal chain that is asynchronous or configured for a different sample rate.
52
DS1162F1
CS42L92
4.3 Digital Core
Silence (mute) (0x00)
AEC1 Loopback (0x08)
AEC2 Loopback (0x09)
IN1L signal path (0x10)
IN1R signal path (0x11)
IN2L signal path (0x12)
IN2R signal path (0x13)
IN3L signal path (0x14)
IN3R signal path (0x15)
IN4L signal path (0x16)
IN4R signal path (0x17)
AIF1 RX1 (0x20)
AIF1 RX2 (0x21)
AIF1 RX3 (0x22)
AIF1 RX4 (0x23)
AIF1 RX5 (0x24)
AIF1 RX6 (0x25)
AIF1 RX7 (0x26)
AIF1 RX8 (0x27)
AIF2 RX1 (0x28)
AIF2 RX2 (0x29)
AIF2 RX3 (0x2A)
AIF2 RX4 (0x2B)
AIF2 RX5 (0x2C)
AIF2 RX6 (0x2D)
AIF2 RX7 (0x2E)
AIF2 RX8 (0x2F)
AIF3 RX1 (0x30)
AIF3 RX2 (0x31)
AIF3 RX3 (0x32)
AIF3 RX4 (0x33)
AIF3 RX5 (0x34)
AIF3 RX6 (0x35)
AIF3 RX7 (0x36)
AIF3 RX8 (0x37)
SLIMbus RX1 (0x38)
SLIMbus RX2 (0x39)
SLIMbus RX3 (0x3A)
SLIMbus RX4 (0x3B)
SLIMbus RX5 (0x3C)
SLIMbus RX6 (0x3D)
SLIMbus RX7 (0x3E)
SLIMbus RX8 (0x3F)
Ultrasonic 1 (0xF0)
Ultrasonic 2 (0xF1)
Figure 4-16. Digital-Core Inputs
4.3.3
Digital-Core Output Mixers
The digital core comprises multiple output paths. The output paths associated with AIF1–AIF3 are shown in Fig. 4-17. The
output paths associated with OUT1–OUT5 are shown in Fig. 4-18. The output paths associated with the SLIMbus interface
are shown in Fig. 4-19.
A four-input mixer is associated with each output. The four input sources are selectable in each case, and independent
volume control is provided for each path.
DS1162F1
53
CS42L92
4.3 Digital Core
The AIF1–AIF3 output mixer control fields (see Fig. 4-17) are located at register addresses R1792–R1983
(0x0700–0x07BF). The OUT1–OUT5 output mixer control fields (see Fig. 4-18) are located at addresses R1664–R1743
(0x0680–0x06CF). The SLIMbus output mixer control fields (see Fig. 4-19) are located at addresses R1984–R2047
(0x07C0–0x07FF).
The full list of digital mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the respective mixers. Note that the selected input sources must be
configured for the same sample rate as the mixer to which they are connected. Sample-rate conversion functions are
available to support flexible interconnectivity; see Section 4.3.15 and Section 4.3.16.
The sample rate for the output signal paths is configured using the applicable OUT_RATE, AIFn_RATE, or SLIMTXn_
RATE fields; see Table 4-26. Note that sample-rate conversion is required when routing the output signal paths to any
signal chain that is asynchronous or configured for a different sample rate.
The OUT_RATE, AIFn_RATE, or SLIMTXn_RATE fields must not be changed if any of the respective x_SRCn fields is
nonzero. The associated x_SRCn fields must be cleared before writing new values to OUT_RATE, AIFn_RATE, or
SLIMTXn_RATE. A minimum delay of 125 s must be allowed between clearing the x_SRCn fields and writing to the
associated OUT_RATE, AIFn_RATE, or SLIMTXn_RATE fields. See Table 4-26 for details.
The AIF1, AIF3, SLIMbus, and DAC (OUT1–OUT3) output mixers provide full support for 32-bit data words. Audio data
samples up to 32 bits are supported on the AIF1, AIF3, and SLIMbus input channels, which can be routed to the AIF1,
AIF3, SLIMbus, and DAC (OUT1–OUT3) output paths. Note that other signal paths and signal-processing blocks within
the digital core are limited to 24-bit data length; data samples are truncated to 24-bit length if they are routed through any
function that does not support 32-bit data words.
The CS42L92 performs automatic checks to confirm that the SYSCLK frequency is high enough to support the output
mixer paths. If the frequency is too low, an attempt to enable an output mixer path fails. Note that active signal paths are
not affected under such circumstances.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
54
DS1162F1
CS42L92
4.3 Digital Core
x_SRCn p. 52
x_VOLn p. 52
…
AIF1TXnMIX_SRC1
AIF1TXnMIX_VOL1
…
AIF1TXnMIX_SRC2
AIF1TXnMIX_VOL2
…
AIF1TXnMIX_SRC3
AIF1TXnMIX_VOL3
…
AIF1TXnMIX_SRC4
AIF1TXnMIX_VOL4
+
AIF1 TXn
CS42L92 supports eight AIF1 output mixers, i.e., n = 1–8
…
AIF2TXnMIX_SRC1
AIF2TXnMIX_VOL1
…
AIF2TXnMIX_SRC2
AIF2TXnMIX_VOL2
…
AIF2TXnMIX_SRC3
AIF2TXnMIX_VOL3
…
AIF2TXnMIX_SRC4
AIF2TXnMIX_VOL4
+
AIF2 TXn
CS42L92 supports eight AIF2 output mixers, i.e., n = 1–8
…
AIF3TXnMIX_SRC1
AIF3TXnMIX_VOL1
…
AIF3TXnMIX_SRC2
AIF3TXnMIX_VOL2
…
AIF3TXnMIX_SRC3
AIF3TXnMIX_VOL3
…
AIF3TXnMIX_SRC4
AIF3TXnMIX_VOL4
+
AIF3 TXn
CS42L92 supports eight AIF3 output mixers, i.e., n = 1–8
Figure 4-17. Digital-Core AIF Outputs
DS1162F1
55
CS42L92
4.3 Digital Core
x_SRCn p. 52
x_VOLn p. 52
…
OUTnLMIX_SRC1
OUTnLMIX_VOL1
…
OUTnLMIX_SRC2
OUTnLMIX_VOL2
…
OUTnLMIX_SRC3
OUTnLMIX_VOL3
…
OUTnLMIX_SRC4
OUTnLMIX_VOL4
…
OUTnRMIX_SRC1
OUTnRMIX_VOL1
…
OUTnRMIX_SRC2
OUTnRMIX_VOL2
…
OUTnRMIX_SRC3
OUTnRMIX_VOL3
…
OUTnRMIX_SRC4
OUTnRMIX_VOL4
+
OUTn Left
+
OUTn Right
CS42L92 supports four stereo output mixer pairs, i.e., n = 1, 2, 3, or 5
Figure 4-18. Digital-Core OUTn Outputs
x_SRCn p. 52
x_VOLn p. 52
…
SLIMTXnMIX_SRC1
SLIMTXnMIX_VOL1
…
SLIMTXnMIX_SRC2
SLIMTXnMIX_VOL2
…
SLIMTXnMIX_SRC3
SLIMTXnMIX_VOL3
…
SLIMTXnMIX_SRC4
SLIMTXnMIX_VOL4
+
SLIMbus TXn
CS42L92 supports eight SLIMbus output mixers, i.e., n = 1–8
Figure 4-19. Digital-Core SLIMbus Outputs
4.3.4
Five-Band Parametric Equalizer (EQ)
The digital core provides four EQ processing blocks as shown in Fig. 4-20. A four-input mixer is associated with each EQ.
The four input sources are selectable in each case, and independent volume control is provided for each path. Each EQ
block supports one output.
The EQ provides selective control of five frequency bands as follows:
•
56
The low-frequency band (Band 1) filter can be configured as a peak filter or as a shelving filter. If configured as a
shelving filter, it provides adjustable gain below the Band 1 cut-off frequency. As a peak filter, it provides adjustable
gain within a defined frequency band that is centered on the Band 1 frequency.
DS1162F1
CS42L92
4.3 Digital Core
•
The midfrequency bands (Band 2–Band 4) filters are peak filters that provide adjustable gain around the respective
center frequency.
•
The high-frequency band (Band 5) filter is a shelving filter that provides adjustable gain above the Band 5 cut-off
frequency.
x_SRCn p. 52
x_VOLn p. 52
…
EQnMIX_SRC1
EQnMIX_VOL1
…
EQnMIX_SRC2
EQnMIX_VOL2
…
EQnMIX_SRC3
EQnMIX_VOL3
…
EQnMIX_SRC4
EQnMIX_VOL4
+
EQ
Five-band Equalizer
EQ1 (0x50)
EQ2 (0x51)
EQ3 (0x52)
EQ4 (0x53)
CS42L92 supports four EQ blocks, i.e., n = 1–4
Figure 4-20. Digital-Core EQ Blocks
The EQ1–EQ4 mixer control fields (see Fig. 4-20) are located at register addresses R2176–R2207 (0x0880–0x089F).
The full list of digital-mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the respective EQ processing blocks. Note that the selected input sources
must be configured for the same sample rate as the EQ to which they are connected. Sample-rate conversion functions
are available to support flexible interconnectivity; see Section 4.3.15 and Section 4.3.16.
The hexadecimal numbers in Fig. 4-20 indicate the corresponding x_SRCn setting for selection of that signal as an input
to another digital-core function.
The sample rate for the EQ function is configured using FX_RATE; see Table 4-26. Note that the EQ, DRC, and LHPF
functions must be configured for the same sample rate. Sample-rate conversion is required when routing the EQ signal
paths to any signal chain that is asynchronous or configured for a different sample rate.
The FX_RATE field must not be changed if any of the associated x_SRCn fields is nonzero. The associated x_SRCn fields
must be cleared before writing a new value to FX_RATE. A minimum delay of 125 s must be allowed between clearing
the x_SRCn fields and writing to FX_RATE. See Table 4-26 for details.
The cut-off or center frequencies for the five-band EQ are set by using the coefficients held in the registers identified in
Table 4-12. These coefficients are derived using tools provided in Cirrus Logic’s WISCE™ evaluation-board control
software; please contact your Cirrus Logic representative for details.
Table 4-12. EQ Coefficient Registers
EQ
EQ1
EQ2
EQ3
EQ4
Register Addresses
R3602 (0x0E10) to R3620 (0x0E24)
R3624 (0x0E28) to R3642 (0x0E3A)
R3646 (0x0E3E) to R3664 (0x0E53)
R3668 (0x0E54) to R3686 (0x0E66)
The control registers associated with the EQ functions are described in Table 4-13.
DS1162F1
57
CS42L92
4.3 Digital Core
Table 4-13. EQ Enable and Gain Control
Register Address
R3585 (0x0E01)
FX_Ctrl2
Bit
Label
15:4 FX_STS[11:0]
R3600 (0x0E10)
EQ1_1
15:11
10:6
5:1
0
R3601 (0x0E11)
EQ1_2
15:11 EQ1_B4_GAIN[4:0]
10:6 EQ1_B5_GAIN[4:0]
0
EQ1_B1_MODE
EQ1_B1_GAIN[4:0]
EQ1_B2_GAIN[4:0]
EQ1_B3_GAIN[4:0]
EQ1_ENA
R3602 (0x0E12) to 15:0 EQ1_B1_*
R3620 (0x0E24)
EQ1_B2_*
EQ1_B3_*
EQ1_B4_*
EQ1_B5_*
R3622 (0x0E26)
15:11 EQ2_B1_GAIN[4:0]
EQ2_1
10:6 EQ2_B2_GAIN[4:0]
5:1
0
R3623 (0x0E27)
EQ2_2
EQ2_B3_GAIN[4:0]
EQ2_ENA
15:11 EQ2_B4_GAIN[4:0]
10:6 EQ2_B5_GAIN[4:0]
0
EQ2_B1_MODE
R3624 (0x0E28) to 15:0 EQ2_B1_*
R3642 (0x0E3A)
EQ2_B2_*
EQ2_B3_*
EQ2_B4_*
EQ2_B5_*
R3644 (0x0E3C)
15:11 EQ3_B1_GAIN[4:0]
10:6 EQ3_B2_GAIN[4:0]
EQ3_1
5:1 EQ3_B3_GAIN[4:0]
0
EQ3_ENA
R3645 (0x0E3D)
EQ3_2
58
15:11 EQ3_B4_GAIN[4:0]
10:6 EQ3_B5_GAIN[4:0]
0
EQ3_B1_MODE
Default
Description
0x00 LHPF, DRC, EQ Enable Status. Indicates the status of each respective
signal-processing function. Each bit is coded as follows:
0 = Disabled
1 = Enabled
[11] = EQ4
[7] = DRC2 (Right)
[3] = LHPF4
[10] = EQ3
[6] = DRC2 (Left)
[2] = LHPF3
[9] = EQ2
[5] = DRC1 (Right)
[1] = LHPF2
[8] = EQ1
[4] = DRC1 (Left)
[0] = LHPF1
0x0C EQ1 Band 1 Gain 1 (–12 dB to +12 dB in 1-dB steps)
0x0C EQ1 Band 2 Gain 1 (–12 dB to +12 dB in 1-dB steps)
0x0C EQ1 Band 3 Gain 1 (–12 dB to +12 dB in 1-dB steps)
0
EQ1 Enable
0 = Disabled
1 = Enabled
0x0C EQ1 Band 4 Gain 1 (–12 dB to +12 dB in 1-dB steps)
0x0C EQ1 Band 5 Gain 1 (–12 dB to +12 dB in 1-dB steps)
0
EQ1 Band 1 Mode
0 = Shelving filter
1 = Peak filter
—
EQ1 Frequency Coefficients. Refer to WISCE evaluation board control software for
the derivation of these field values.
0x0C
0x0C
0x0C
0
0x0C
0x0C
0
—
0x0C
0x0C
0x0C
0
0x0C
0x0C
0
EQ2 Band 1 Gain 1
–12 dB to +12 dB in 1-dB steps
EQ2 Band 2 Gain 1
–12 dB to +12 dB in 1-dB steps
EQ2 Band 3 Gain 1
–12 dB to +12 dB in 1-dB steps
EQ2 Enable
0 = Disabled
1 = Enabled
EQ2 Band 4 Gain 1 (–12 dB to +12 dB in 1-dB steps)
EQ2 Band 5 Gain 1 (–12 dB to +12 dB in 1-dB steps)
EQ2 Band 1 Mode
0 = Shelving filter
1 = Peak filter
EQ2 Frequency Coefficients. Refer to WISCE evaluation board control software for
the derivation of these field values.
EQ3 Band 1 Gain 1 (–12 dB to +12 dB in 1-dB steps)
EQ3 Band 2 Gain 1 (–12 dB to +12 dB in 1-dB steps)
EQ3 Band 3 Gain 1 (–12 dB to +12 dB in 1-dB steps)
EQ3 Enable
0 = Disabled
1 = Enabled
EQ3 Band 4 Gain1 (–12 dB to +12 dB in 1-dB steps)
EQ3 Band 5 Gain 1 (–12 dB to +12 dB in 1-dB steps)
EQ3 Band 1 Mode
0 = Shelving filter
1 = Peak filter
DS1162F1
CS42L92
4.3 Digital Core
Table 4-13. EQ Enable and Gain Control (Cont.)
Register Address Bit
Label
Default
Description
R3646 (0x0E3E) to 15:0 EQ3_B1_*
—
EQ3 Frequency Coefficients. Refer to WISCE evaluation board control software for
the derivation of these field values.
R3664 (0x0E50)
EQ3_B2_*
EQ3_B3_*
EQ3_B4_*
EQ3_B5_*
R3666 (0x0E52)
15:11 EQ4_B1_GAIN[4:0] 0x0C EQ4 Band 1 Gain 1 (–12 dB to +12 dB in 1-dB steps)
10:6 EQ4_B2_GAIN[4:0] 0x0C EQ4 Band 2 Gain 1 (–12 dB to +12 dB in 1-dB steps)
EQ4_1
5:1 EQ4_B3_GAIN[4:0] 0x0C EQ4 Band 3 Gain 1 (–12 dB to +12 dB in 1-dB steps)
0
EQ4_ENA
0
EQ4 Enable
0 = Disabled
1 = Enabled
R3667 (0x0E53)
15:11 EQ4_B4_GAIN[4:0] 0x0C EQ4 Band 4 Gain 1 (–12 dB to +12 dB in 1-dB steps)
EQ4_2
10:6 EQ4_B5_GAIN[4:0] 0x0C EQ4 Band 5 Gain 1 (–12 dB to +12 dB in 1-dB steps
0
EQ4_B1_MODE
0
EQ4 Band 1 Mode
0 = Shelving filter
1 = Peak filter
R3668 (0x0E54) to 15:0 EQ4_B1_*
—
EQ4 Frequency Coefficients. Refer to WISCE evaluation board control software for
R3686 (0x0E66)
the derivation of these field values.
EQ4_B2_*
EQ4_B3_*
EQ4_B4_*
EQ4_B5_*
1.See Table 4-14 for gain range.
Table 4-14 lists the EQ gain control settings.
Table 4-14. EQ Gain-Control Range
EQ Gain Setting Gain (dB) EQ Gain Setting Gain (dB)
00000
–12
01101
+1
00001
–11
01110
+2
00010
–10
01111
+3
00011
–9
10000
+4
00100
–8
10001
+5
00101
–7
10010
+6
00110
–6
10011
+7
00111
–5
10100
+8
01000
–4
10101
+9
01001
–3
10110
+10
01010
–2
10111
+11
01011
–1
11000
+12
01100
0
11001–11111 Reserved
The CS42L92 automatically checks to confirm whether the SYSCLK frequency is high enough to support the commanded
EQ and digital mixing functions. If an attempt is made to enable an EQ signal path, and there are insufficient SYSCLK
cycles to support it, the attempt does not succeed. Note that any signal paths that are already active are not affected under
such circumstances.
The FX_STS field in register R3585 indicates the status of each EQ, DRC, and LHPF signal path. If an underclocked error
condition occurs, this field indicates which EQ, DRC, or LHPF signal paths have been enabled.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
DS1162F1
59
CS42L92
4.3 Digital Core
4.3.5
Dynamic Range Control (DRC)
The digital core provides two stereo DRC processing blocks, as shown in Fig. 4-21. A four-input mixer is associated with
each DRC input channel. The input sources are selectable in each case, and independent volume control is provided for
each path. The stereo DRC blocks support two outputs each.
The function of the DRC is to adjust the signal gain in conditions where the input amplitude is unknown or varies over a
wide range, for example, when recording from microphones built into a handheld system or to restrict the dynamic range
of an output signal path.
To improve intelligibility in the presence of loud impulsive noises, the DRC can apply compression and automatic level
control to the signal path. It incorporates anticlip and quick-release features for handling transients.
The DRC also incorporates a noise-gate function that provides additional attenuation of very low-level input signals. This
means that the signal path is quiet when no signal is present, giving an improvement in background noise level under these
conditions.
A signal-detect function is provided within the DRC; this can be used to detect the presence of an audio signal and to
trigger other events. It can also be used as an interrupt event or to trigger the control-write sequencer. Note that DRC
triggering of the control-write sequencer is supported for DRC1 only.
x_SRCn p. 52
x_VOLn p. 52
…
DRCnLMIX_SRC1
DRCnLMIX_VOL1
…
DRCnLMIX_SRC2
DRCnLMIX_VOL2
…
DRCnLMIX_SRC3
DRCnLMIX_VOL3
…
DRCnLMIX_SRC4
DRCnLMIX_VOL4
…
DRCnRMIX_SRC1
DRCnRMIX_VOL1
…
DRCnRMIX_SRC2
DRCnRMIX_VOL2
…
DRCnRMIX_SRC3
DRCnRMIX_VOL3
…
DRCnRMIX_SRC4
DRCnRMIX_VOL4
+
DRC
Dynamic Range
Controller
+
DRC
Dynamic Range
Controller
DRC1 Left (0x58)
DRC2 Left (0x5A)
DRC1 Right (0x59)
DRC2 Right (0x5B)
CS42L92 supports two stereo DRC blocks, i.e., n = 1 or 2
Figure 4-21. Dynamic Range Control (DRC) Block
The DRC1 and DRC2 mixer control fields (see Fig. 4-21) are located at register addresses R2240–R2271
(0x08C0–0x08DF).
The full list of digital mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the respective DRC processing blocks. Note that the selected input sources
must be configured for the same sample rate as the DRC to which they are connected. Sample-rate conversion functions
are available to support flexible interconnectivity; see Section 4.3.15 and Section 4.3.16.
60
DS1162F1
CS42L92
4.3 Digital Core
The hexadecimal numbers in Fig. 4-21 indicate the corresponding x_SRCn setting for selection of that signal as an input
to another digital-core function.
The sample rate for the DRC function is configured using FX_RATE; see Table 4-26. Note that the EQ, DRC, and LHPF
functions must all be configured for the same sample rate. Sample-rate conversion is required when routing the DRC
signal paths to any signal chain that is asynchronous or configured for a different sample rate.
The FX_RATE field must not be changed if any of the associated x_SRCn fields is nonzero. The associated x_SRCn fields
must be cleared before writing a new value to FX_RATE. A minimum delay of 125 s must be allowed between clearing
the x_SRCn fields and writing to FX_RATE. See Table 4-26 for details.
The DRC functions are enabled using the control registers described in Table 4-15.
Table 4-15. DRC Enable
Register Address
R3712 (0x0E80)
DRC1_ctrl1
R3720 (0x0E88)
DRC2_ctrl1
Bit
1
Label
DRC1L_ENA
Default
0
0
DRC1R_ENA
0
1
DRC2L_ENA
0
0
DRC2R_ENA
0
Description
DRC1 (left) enable
0 = Disabled
1 = Enabled
DRC1 (right) enable
0 = Disabled
1 = Enabled
DRC2 (left) enable
0 = Disabled
1 = Enabled
DRC2 (right) enable
0 = Disabled
1 = Enabled
The following description of the DRC is applicable to each DRC. The associated control fields are described in Table 4-17
and Table 4-18 for DRC1 and DRC2 respectively.
4.3.5.1
DRC Compression, Expansion, and Limiting
The DRC supports two different compression regions, separated by a knee at a specific input amplitude. In the region
above the knee, the compression slope DRCn_HI_COMP applies; in the region below the knee, the compression slope
DRCn_LO_COMP applies. Note that n identifies the applicable DRC 1 or 2.
The DRC also supports a noise-gate region, where low-level input signals are heavily attenuated. This function can be
enabled or disabled according to the application requirements. The DRC response in this region is defined by the
expansion slope DRCn_NG_EXP.
For additional attenuation of signals in the noise-gate region, an additional knee can be defined (shown as Knee 2 in
Fig. 4-22). When this knee is enabled, this introduces an infinitely steep drop-off in the DRC response pattern between the
DRCn_LO_COMP and DRCn_NG_EXP regions.
The overall DRC compression characteristic in steady state (i.e., where the input amplitude is near constant) is shown in
Fig. 4-22.
DS1162F1
61
CS42L92
4.3 Digital Core
DRCn Output Amplitude (dB)
(Y0)
Knee 1
DRCn_KNEE_OP
Knee 2
C
DR
P
OM
C
_
LO
n_
OMP
HI_C
_
n
C
DR
DR
Cn
_N
G
_E
XP
DRCn_KNEE2_OP
DRCn_KNEE2_IP
DRCn_KNEE_IP
0dB
DRCn Input Amplitude (dB)
Figure 4-22. DRC Response Characteristic
The slope of the DRC response is determined by DRCn_HI_COMP and DRCn_LO_COMP. A slope of 1 indicates constant
gain in this region. A slope less than 1 represents compression (i.e., a change in input amplitude produces only a smaller
change in output amplitude). A slope of 0 indicates that the target output amplitude is the same across a range of input
amplitudes; this is infinite compression.
When the noise gate is enabled, the DRC response in this region is determined by DRCn_NG_EXP. A slope of 1 indicates
constant gain in this region. A slope greater than 1 represents expansion (i.e., a change in input amplitude produces a
larger change in output amplitude).
When the DRCn_KNEE2_OP knee is enabled (Knee 2 in Fig. 4-22), this introduces the vertical line in the response pattern
shown, resulting in infinitely steep attenuation at this point in the response.
The DRC parameters are listed in Table 4-16.
Table 4-16. DRC Response Parameters
Parameters
1
2
3
4
5
6
7
Parameter
DRCn_KNEE_IP
DRCn_KNEE_OP
DRCn_HI_COMP
DRCn_LO_COMP
DRCn_KNEE2_IP
DRCn_NG_EXP
DRCn_KNEE2_OP
Description
Input level at Knee 1 (dB)
Output level at Knee 2 (dB)
Compression ratio above Knee 1
Compression ratio below Knee 1
Input level at Knee 2 (dB)
Expansion ratio below Knee 2
Output level at Knee 2 (dB)
The noise gate is enabled by setting DRCn_NG_ENA. When the noise gate is not enabled, Parameters 5–7 (see
Table 4-16) are ignored, and the DRCn_LO_COMP slope applies to all input signal levels below Knee 1.
The DRCn_KNEE2_OP knee is enabled by setting DRCn_KNEE2_OP_ENA. If this bit is not set, Parameter 7 is ignored
and the Knee 2 position always coincides with the low end of the DRCn_LO_COMP region.
The Knee 1 point in Fig. 4-22 is determined by DRCn_KNEE_IP and DRCn_KNEE_OP.
62
DS1162F1
CS42L92
4.3 Digital Core
Parameter Y0, the output level for a 0 dB input, is not specified directly but can be calculated from the other parameters
using Eq. 4-2.
Y0
=
DRCn_KNEE_OP
– DRCn_KNEE_IP DRCn_HI_COMP
Equation 4-2. DRC Compression Calculation
4.3.5.2
Gain Limits
The minimum and maximum gain applied by the DRC is set by DRCn_MINGAIN, DRCn_MAXGAIN, and DRCn_NG_
MINGAIN. These limits can be used to alter the DRC response from that shown in Fig. 4-22. If the range between
maximum and minimum gain is reduced, the extent of the dynamic range control is reduced.
The minimum gain in the compression regions of the DRC response is set by DRCn_MINGAIN. The minimum gain in the
noise-gate region is set by DRCn_NG_MINGAIN. The minimum gain limit prevents excessive attenuation of the signal
path.
The maximum gain limit set by DRCn_MAXGAIN prevents quiet signals (or silence) from being excessively amplified.
4.3.5.3
Dynamic Characteristics
The dynamic behavior determines how quickly the DRC responds to changing signal levels. Note that the DRC responds
to the average (RMS) signal amplitude over a period of time.
The DRCn_ATK determines how quickly the DRC gain decreases when the signal amplitude is high. The DRCn_DCY
determines how quickly the DRC gain increases when the signal amplitude is low.
These fields are described in Table 4-17 and Table 4-18. The register defaults are suitable for general-purpose
microphone use.
4.3.5.4
Anticlip Control
The DRC includes an anticlip function to avoid signal clipping when the input amplitude rises very quickly. This function
uses a feed-forward technique for early detection of a rising signal level. Signal clipping is avoided by dynamically
increasing the gain attack rate when required.
The anticlip function is enabled using the DRCn_ANTICLIP bit. Note that the feed-forward processing increases the
latency in the input signal path.
The anticlip feature operates entirely in the digital domain; it cannot be used to prevent signal clipping in the analog domain
nor in the source signal. Analog clipping can only be prevented by reducing the analog signal gain or by adjusting the
source signal.
It is recommended to disable the anticlip function if the quick-release function (see Section 4.3.5.5) is enabled.
4.3.5.5
Quick Release Control
The DRC includes a quick-release function to handle short transient peaks that are not related to the intended source
signal. For example, in handheld microphone recording, transient signal peaks sometimes occur due to user handling, key
presses or accidental tapping against the microphone. The quick-release function ensures that these transients do not
cause the intended signal to be masked by the longer time constant of DRCn_DCY.
The quick-release function is enabled by setting the DRCn_QR bit. When this bit is enabled, the DRC measures the crest
factor (peak to RMS ratio) of the input signal. A high crest factor is indicative of a transient peak that may not be related
to the intended source signal. If the crest factor exceeds the level set by DRCn_QR_THR, the normal decay rate (DRCn_
DCY) is ignored and a faster decay rate (DRCn_QR_DCY) is used instead.
It is recommended to disable the quick-release function if the anticlip function (see Section 4.3.5.4) is enabled.
DS1162F1
63
CS42L92
4.3 Digital Core
4.3.5.6
Signal Activity Detect
The DRC incorporates a configurable signal-detect function, allowing the signal level at the DRC input to be monitored
and to be used to trigger other events. This can be used to detect the presence of a microphone signal on an ADC or DMIC
channel or to detect an audio signal received over the digital audio interface.
The DRC signal-detect function is enabled by setting DRCn_SIG_DET. Note that the respective DRCn must also be
enabled. The detection threshold is either a peak level (crest factor) or an RMS level, depending on DRCn_SIG_DET_
MODE. When peak level is selected, the threshold is determined by DRCn_SIG_DET_PK, which defines the applicable
crest factor (peak-to-RMS ratio) threshold. If RMS level is selected, the threshold is set using DRCn_SIG_DET_RMS.
The DRC signal-detect function is an input to the interrupt control circuit and can be used to trigger an interrupt event; see
Section 4.15.
The control-write sequencer can be triggered by the DRC1 signal-detect function. This is enabled by setting DRC1_
WSEQ_SIG_DET_ENA. See Section 4.18.
Note that signal detection is supported on DRC1 and DRC2, but the triggering of the control-write sequencer is available
on DRC1 only.
4.3.5.7
DRC Register Controls
The DRC1 control registers are described in Table 4-17.
Table 4-17. DRC1 Control Registers
Register Address Bit
Label
R3585 (0x0E01)
15:4 FX_STS[11:0]
FX_Ctrl2
64
Default
Description
0x00 LHPF, DRC, EQ enable status. Indicates the status of each respective
signal-processing function. Each bit is coded as follows:
0 = Disabled
1 = Enabled
[11] = EQ4
[7] = DRC2 (Right)
[3] = LHPF4
[10] = EQ3
[6] = DRC2 (Left)
[2] = LHPF3
[9] = EQ2
[5] = DRC1 (Right)
[1] = LHPF2
[8] = EQ1
[4] = DRC1 (Left)
[0] = LHPF1
DS1162F1
CS42L92
4.3 Digital Core
Table 4-17. DRC1 Control Registers (Cont.)
Register Address Bit
Label
R3712 (0x0E80)
15:11 DRC1_SIG_
DET_RMS[4:0]
DRC1_ctrl1
R3713 (0x0E81)
DRC1_ctrl2
DS1162F1
Default
Description
0x00 DRC1 Signal-Detect RMS Threshold. RMS signal level for signal-detect to be indicated
when DRC1_SIG_DET_MODE = 1.
0x00 = –30 dB
…. (1.5-dB steps)
0x1F = –76.5 dB
0x01 = –31.5 dB
0x1E = –75 dB
10:9 DRC1_SIG_
00
DRC1 Signal-Detect Peak Threshold. This is the Peak/RMS ratio, or Crest Factor, level
DET_PK[1:0]
for signal-detect to be indicated when DRC1_SIG_DET_MODE = 0.
00 = 12 dB
10 = 24 dB
01 = 18 dB
11 = 30 dB
8
DRC1_NG_ENA
0
DRC1 Noise-Gate Enable
0 = Disabled
1 = Enabled
7
DRC1_SIG_
0
DRC1 Signal-Detect Mode
DET_MODE
0 = Peak threshold mode
1 = RMS threshold mode
6
DRC1_SIG_DET
0
DRC1 Signal-Detect Enable
0 = Disabled
1 = Enabled
5
DRC1_KNEE2_
0
DRC1 KNEE2_OP Enable
OP_ENA
0 = Disabled
1 = Enabled
4
DRC1_QR
1
DRC1 Quick-release Enable
0 = Disabled
1 = Enabled
3
DRC1_ANTICLIP
1
DRC1 Anticlip Enable
0 = Disabled
1 = Enabled
2
DRC1_WSEQ_
0
DRC1 Signal-Detect Write Sequencer Select
SIG_DET_ENA
0 = Disabled
1 = Enabled
12:9 DRC1_ATK[3:0]
0100 DRC1 Gain attack rate (seconds/6 dB)
1010 = 92.8 ms
0101 = 2.9 ms
0000 = Reserved
1011 = 185.6 ms
0110 = 5.8 ms
0001 = 181 s
1100 to 1111 = Reserved
0111 = 11.6 ms
0010 = 363 s
1000 = 23.2 ms
0011 = 726 s
1001 = 46.4 ms
0100 = 1.45 ms
8:5 DRC1_DCY[3:0]
1001 DRC1 Gain decay rate (seconds/6 dB)
1010 = 1.49 s
0101 = 46.5 ms
0000 = 1.45 ms
0001 = 2.9 ms
0110 = 93 ms
1011 = 2.97 s
1100 to 1111 = Reserved
0010 = 5.8 ms
0111 = 186 ms
0011 = 11.6 ms
1000 = 372 ms
1001 = 743 ms
0100 = 23.25 ms
4:2 DRC1_
100 DRC1 Minimum gain to attenuate audio signals
MINGAIN[2:0]
000 = 0 dB
011 = –24 dB
11X = Reserved
001 = –12 dB
100 = –36 dB
010 = –18 dB
101 = Reserved
1:0 DRC1_
11
DRC1 Maximum gain to boost audio signals (dB)
MAXGAIN[1:0]
00 = 12 dB
10 = 24 dB
01 = 18 dB
11 = 36 dB
65
CS42L92
4.3 Digital Core
Table 4-17. DRC1 Control Registers (Cont.)
Register Address Bit
Label
R3714 (0x0E82)
15:12 DRC1_NG_
MINGAIN[3:0]
DRC1_ctrl3
11:10 DRC1_NG_
EXP[1:0]
R3715 (0x0E83)
DRC1_ctrl4
R3716 (0x0E84)
DRC1_ctrl5
9:8
DRC1_QR_
THR[1:0]
7:6
DRC1_QR_
DCY[1:0]
5:3
DRC1_HI_
COMP[2:0]
2:0
DRC1_LO_
COMP[2:0]
10:5 DRC1_KNEE_
IP[5:0]
4:0
DRC1_KNEE_
OP[4:0]
9:5
DRC1_KNEE2_
IP[4:0]
4:0
DRC1_KNEE2_
OP[4:0]
Default
Description
0000 DRC1 Minimum gain to attenuate audio signals when the Noise Gate is active.
0000 = –36 dB
0101 = –6 dB
1010 = 24 dB
0110 = 0 dB
1011 = 30 dB
0001 = –30 dB
0010 = –24 dB
0111 = 6 dB
1100 = 36 dB
0011 = –18 dB
1000 = 12 dB
1101 to 1111 = Reserved
0100 = –12 dB
1001 = 18 dB
00
DRC1 Noise-Gate slope
00 = 1 (no expansion)
10 = 4
01 = 2
11 = 8
00
DRC1 Quick-release threshold (crest factor in dB)
00 = 12 dB
10 = 24 dB
01 = 18 dB
11 = 30 dB
00
DRC1 Quick-release decay rate (seconds/6 dB)
00 = 0.725 ms
10 = 5.8 ms
01 = 1.45 ms
11 = Reserved
011 DRC1 Compressor slope (upper region)
000 = 1 (no compression) 011 = 1/8
11X = Reserved
001 = 1/2
100 = 1/16
010 = 1/4
101 = 0
000 DRC1 Compressor slope (lower region)
000 = 1 (no compression) 011 = 1/8
11X = Reserved
001 = 1/2
100 = 0
010 = 1/4
101 = Reserved
0x00 DRC1 Input signal level at the compressor knee.
0x00 = 0 dB
0x02 = –1.5 dB
0x3C = –45 dB
0x01 = –0.75 dB
… (–0.75-dB steps)
0x3D–0x3F = Reserved
0x00 DRC1 Output signal at the compressor knee.
0x00 = 0 dB
0x02 = –1.5 dB
0x1E = –22.5 dB
0x01 = –0.75 dB
… (–0.75 dB steps)
0x1F = Reserved
0x00 DRC1 Input signal level at the noise-gate threshold, Knee 2.
0x00 = –36 dB
0x02 = –39 dB
0x1E = –81 dB
0x01 = –37.5 dB
… (-1.5-dB steps)
0x1F = –82.5 dB
Applicable if DRC1_NG_ENA = 1
0x00 DRC1 Output signal at the noise-gate threshold, Knee 2.
0x00 = –30 dB
0x02 = –33 dB
0x1E = –75 dB
0x01 = –31.5 dB
… (–1.5dB steps)
0x1F = –76.5 dB
Applicable only if DRC1_KNEE2_OP_ENA = 1
The DRC2 control registers are described in Table 4-18.
Table 4-18. DRC2 Control Registers
Register Address Bit
Label
R3585 (0x0E01)
15:4 FX_STS[11:0]
FX_Ctrl2
66
Default
Description
0x00 LHPF, DRC, EQ Enable Status. Indicates the status of each respective
signal-processing function. Each bit is coded as follows:
0 = Disabled
1 = Enabled
[7] = DRC2 (Right)
[3] = LHPF4
[11] = EQ4
[10] = EQ3
[6] = DRC2 (Left)
[2] = LHPF3
[9] = EQ2
[5] = DRC1 (Right)
[1] = LHPF2
[8] = EQ1
[4] = DRC1 (Left)
[0] = LHPF1
DS1162F1
CS42L92
4.3 Digital Core
Table 4-18. DRC2 Control Registers (Cont.)
Register Address Bit
Label
R3720 (0x0E88)
15:11 DRC2_SIG_
DET_RMS[4:0]
DRC2_ctrl1
R3721 (0x0E89)
DRC2_ctrl2
DS1162F1
Default
Description
0x00 DRC2 Signal-Detect RMS Threshold. This is the RMS signal level for signal-detect to
be indicated when DRC2_SIG_DET_MODE = 1.
0x00 = –30 dB
…. (1.5-dB steps)
0x1E = –75 dB
0x01 = –31.5 dB
0x1F = –76.5 dB
10:9 DRC2_SIG_
00
DRC2 Signal-Detect Peak Threshold. Peak/RMS ratio, or Crest Factor, level for
DET_PK[1:0]
signal-detect to be indicated when DRC2_SIG_DET_MODE = 0.
00 = 12 dB
10 = 24 dB
01 = 18 dB
11 = 30 dB
8
DRC2_NG_ENA
0
DRC2 Noise-Gate Enable
0 = Disabled
1 = Enabled
7
DRC2_SIG_
0
DRC2 Signal-Detect Mode
DET_MODE
0 = Peak threshold mode
1 = RMS threshold mode
6
DRC2_SIG_DET
0
DRC2 Signal-Detect Enable
0 = Disabled
1 = Enabled
5
DRC2_KNEE2_
0
DRC2 KNEE2_OP Enable
OP_ENA
0 = Disabled
1 = Enabled
4
DRC2_QR
1
DRC2 Quick-release Enable
0 = Disabled
1 = Enabled
3
DRC2_ANTICLIP
1
DRC2 Anticlip Enable
0 = Disabled
1 = Enabled
12:9 DRC2_ATK[3:0]
0100 DRC2 Gain attack rate (seconds/6 dB)
1010 = 92.8 ms
0101 = 2.9 ms
0000 = Reserved
1011 = 185.6 ms
0110 = 5.8 ms
0001 = 181 s
1100 to 1111 = Reserved
0111 = 11.6 ms
0010 = 363 s
1000 = 23.2 ms
0011 = 726 s
1001 = 46.4 ms
0100 = 1.45 ms
8:5 DRC2_DCY[3:0]
1001 DRC2 Gain decay rate (seconds/6 dB)
1010 = 1.49 s
0101 = 46.5 ms
0000 = 1.45 ms
1011 = 2.97 s
0110 = 93 ms
0001 = 2.9 ms
1100 to 1111 = Reserved
0111 = 186 ms
0010 = 5.8 ms
1000 = 372 ms
0011 = 11.6 ms
0100 = 23.25 ms
1001 = 743 ms
4:2 DRC2_
100 DRC2 Minimum gain to attenuate audio signals
MINGAIN[2:0]
000 = 0 dB
011 = –24 dB
11X = Reserved
001 = –12 dB (default)
100 = –36 dB
010 = –18 dB
101 = Reserved
1:0 DRC2_
11
DRC2 Maximum gain to boost audio signals (dB)
MAXGAIN[1:0]
00 = 12 dB
10 = 24 dB
01 = 18 dB
11 = 36 dB
67
CS42L92
4.3 Digital Core
Table 4-18. DRC2 Control Registers (Cont.)
Register Address Bit
Label
R3722 (0x0E8A) 15:12 DRC2_NG_
MINGAIN[3:0]
DRC2_ctrl3
11:10 DRC2_NG_
EXP[1:0]
R3723 (0x0E8B)
DRC2_ctrl4
R3724 (0x0E8C)
DRC2_ctrl5
9:8
DRC2_QR_
THR[1:0]
7:6
DRC2_QR_
DCY[1:0]
5:3
DRC2_HI_
COMP[2:0]
2:0
DRC2_LO_
COMP[2:0]
10:5 DRC2_KNEE_
IP[5:0]
4:0
DRC2_KNEE_
OP[4:0]
9:5
DRC2_KNEE2_
IP[4:0]
4:0
DRC2_KNEE2_
OP[4:0]
Default
Description
0000 DRC2 Minimum gain to attenuate audio signals when the Noise Gate is active.
0000 = –36 dB
0101 = –6 dB
1010 = 24 dB
0110 = 0 dB
1011 = 30 dB
0001 = –30 dB
0010 = –24 dB
0111 = 6 dB
1100 = 36 dB
0011 = –18 dB
1000 = 12 dB
1101 to 1111 = Reserved
0100 = –12 dB
1001 = 18 dB
00
DRC2 Noise-Gate slope
00 = 1 (no expansion)
10 = 4
01 = 2
11 = 8
00
DRC2 Quick-release threshold (crest factor in dB)
00 = 12 dB
10 = 24 dB
01 = 18 dB
11 = 30 dB
00
DRC2 Quick-release decay rate (seconds/6 dB)
00 = 0.725 ms
10 = 5.8 ms
01 = 1.45 ms
11 = Reserved
011 DRC2 Compressor slope (upper region)
000 = 1 (no compression) 011 = 1/8
11X = Reserved
001 = 1/2
100 = 1/16
010 = 1/4
101 = 0
000 DRC2 Compressor slope (lower region)
000 = 1 (no compression) 011 = 1/8
11X = Reserved
001 = 1/2
100 = 0
010 = 1/4
101 = Reserved
000000 DRC2 Input signal level at the compressor knee.
0x00 = 0 dB
0x02 = –1.5 dB
0x3C = –45 dB
0x01 = –0.75 dB
… (–0.75-dB steps)
0x3D–0x3F = Reserved
00000 DRC2 Output signal at the compressor knee.
0x00 = 0 dB
0x02 = –1.5 dB
0x1E = –22.5 dB
0x01 = –0.75 dB
… (–0.75 dB steps)
0x1F = Reserved
00000 DRC2 Input signal level at the noise-gate threshold, Knee 2.
0x00 = –36 dB
0x02 = –39 dB
0x1E = –81 dB
0x01 = –37.5 dB
… (-1.5-dB steps)
0x1F = –82.5 dB
Applicable only if DRC2_NG_ENA = 1.
00000 DRC2 Output signal at the noise-gate threshold, Knee 2.
0x00 = –30 dB
0x02 = –33 dB
0x1E = –75 dB
0x01 = –31.5 dB
… (–1.5dB steps)
0x1F = –76.5 dB
Applicable only if DRC2_KNEE2_OP_ENA = 1.
The CS42L92 performs automatic checks to confirm that the SYSCLK frequency is high enough to support the
commanded DRC and digital mixing functions. If the frequency is too low, an attempt to enable a DRC signal path fails.
Note that active signal paths are not affected under such circumstances.
The FX_STS field in register R3585 indicates the status of each EQ, DRC, and LHPF signal path. If an underclocked error
condition occurs, this field indicates which EQ, DRC, or LHPF signal paths have been enabled.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
4.3.6
Low-/High-Pass Digital Filter (LHPF)
The digital core provides four LHPF processing blocks as shown in Fig. 4-23. A four-input mixer is associated with each
filter. The four input sources are selectable in each case, and independent volume control is provided for each path. Each
LHPF block supports one output.
The LHPF /HPF can be used to remove unwanted out-of-band noise from a signal path. Each filter can be configured either
as a low-pass filter (LPF) or a high-pass filter (HPF).
68
DS1162F1
CS42L92
4.3 Digital Core
x_SRCn p. 52
x_VOLn p. 52
…
LHPFnMIX_SRC1
LHPFnMIX_VOL1
…
LHPFnMIX_SRC2
LHPFnMIX_VOL2
+
…
LHPFnMIX_SRC3
LHPFnMIX_VOL3
Low-Pass filter (LPF) /
High-Pass filter (HPF)
…
LHPFnMIX_SRC4
LHPFnMIX_VOL4
LHPF
LHPF1 (0x60)
LHPF2 (0x61)
LHPF3 (0x62)
LHPF4 (0x63)
CS42L92 supports four LHPF blocks, i.e., n = 1–4
Figure 4-23. Digital-Core LPF/HPF Blocks
The LHPF1–LHPF4 mixer control fields, shown in Fig. 4-23, are located at register addresses R2304–R2335
(0x0900–0x091F).
The full list of digital mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the respective LHPF processing blocks. Note that the selected input
sources must be configured for the same sample rate as the LHPF to which they are connected. Sample-rate conversion
functions are available to support flexible interconnectivity; see Section 4.3.15 and Section 4.3.16.
The hexadecimal numbers in Fig. 4-23 indicate the corresponding x_SRCn setting for selection of that signal as an input
to another digital-core function.
The sample rate for the LHPF function is configured using FX_RATE; see Table 4-26. Note that the EQ, DRC, and LHPF
functions must all be configured for the same sample rate. Sample-rate conversion is required when routing the LHPF
signal paths to any signal chain that is asynchronous or configured for a different sample rate.
The FX_RATE field must not be changed if any of the associated x_SRCn fields is nonzero. The associated x_SRCn fields
must be cleared before writing a new value to FX_RATE. A minimum delay of 125 s must be allowed between clearing
the x_SRCn fields and writing to FX_RATE. See Table 4-26 for details.
The control registers associated with the LHPF functions are described in Table 4-19.
The cut-off frequencies for the LHPF blocks are set by using the coefficients held in registers R3777, R3781, R3785, and
R3789 for LHPF1, LHPF2, LHPF3 and LHPF4 respectively. These coefficients are derived using tools provided in Cirrus
Logic’s WISCE evaluation board control software; please contact your Cirrus Logic representative for details.
Table 4-19. Low-Pass Filter/High-Pass Filter
Register Address Bit
Label
R3585 (0x0E01)
15:4 FX_STS[11:0]
FX_Ctrl2
DS1162F1
Default
Description
0x00 LHPF, DRC, EQ Enable Status. Indicates the status of the respective
signal-processing functions. Each bit is coded as follows:
0 = Disabled
1 = Enabled
[11] = EQ4
[7] = DRC2 (Right)
[3] = LHPF4
[10] = EQ3
[6] = DRC2 (Left)
[2] = LHPF3
[9] = EQ2
[5] = DRC1 (Right)
[1] = LHPF2
[8] = EQ1
[4] = DRC1 (Left)
[0] = LHPF1
69
CS42L92
4.3 Digital Core
Table 4-19. Low-Pass Filter/High-Pass Filter (Cont.)
Register Address Bit
Label
R3776 (0x0EC0)
1 LHPF1_MODE
HPLPF1_1
0
R3777 (0x0EC1)
HPLPF1_2
R3780 (0x0EC4)
HPLPF2_1
R3781 (0x0EC5)
HPLPF2_2
R3784 (0x0EC8)
HPLPF3_1
R3785 (0x0EC9)
HPLPF3_2
R3788 (0x0ECC)
HPLPF4_1
R3789 (0x0ECD)
HPLPF4_2
LHPF1_ENA
15:0 LHPF1_COEFF[15:0]
1
LHPF2_MODE
0
LHPF2_ENA
15:0 LHPF2_COEFF[15:0]
1
LHPF3_MODE
0
LHPF3_ENA
15:0 LHPF3_COEFF[15:0]
1
LHPF4_MODE
0
LHPF4_ENA
15:0 LHPF4_COEFF[15:0]
Default
Description
0
Low-/High-Pass Filter 1 Mode
0 = Low Pass
1 = High Pass
0
Low-/High-Pass Filter 1 Enable
0 = Disabled
1 = Enabled
0x0000 Low-/High-Pass Filter 1 Frequency Coefficient
Refer to WISCE evaluation board control software for the derivation of this field
value.
0
Low-/High-Pass Filter 2 Mode
0 = Low Pass
1 = High Pass
0
Low-/High-Pass Filter 2 Enable
0 = Disabled
1 = Enabled
0x0000 Low-/High-Pass Filter 2 Frequency Coefficient
Refer to WISCE evaluation board control software for the derivation of this field
value.
0
Low-/High-Pass Filter 3 Mode
0 = Low Pass
1 = High Pass
0
Low-/High-Pass Filter 3 Enable
0 = Disabled
1 = Enabled
0x0000 Low-/High-Pass Filter 3 Frequency Coefficient
Refer to WISCE evaluation board control software for the derivation of this field
value.
0
Low-/High-Pass Filter 4 Mode
0 = Low Pass
1 = High Pass
0
Low-/High-Pass Filter 4 Enable
0 = Disabled
1 = Enabled
0x0000 Low-/High-Pass Filter 4 Frequency Coefficient
Refer to WISCE evaluation board control software for the derivation of this field
value.
The CS42L92 performs automatic checks to confirm whether the SYSCLK frequency is high enough to support the
commanded LHPF and digital mixing functions. If the frequency is too low, an attempt to enable an LHPF signal path fails.
Note that active signal paths are not affected under such circumstances.
The FX_STS field in register R3585 indicates the status of each EQ, DRC, and LHPF signal path. If an underclocked error
condition occurs, this field indicates which EQ, DRC, or LHPF signal paths have been enabled.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
4.3.7
Digital-Core DSP
The digital core provides one programmable DSP processing block as shown in Fig. 4-24. The DSP block supports eight
inputs (Left, Right, Aux1, Aux2, … Aux6). A four-input mixer is associated with the left and right inputs, providing further
expansion of the number of input paths. Each of the input sources is selectable, and independent volume control is
provided for left and right input mixer channels. The DSP block supports six outputs.
The functionality of the DSP processing block is not fixed; application-specific algorithms can be implemented according
to different customer requirements. The procedure for configuring the CS42L92 DSP functions is tailored to each
customer’s application; please contact your Cirrus Logic representative for details.
70
DS1162F1
CS42L92
4.3 Digital Core
For details of the DSP firmware requirements relating to clocking, register access, and code execution, refer to
Section 4.4.3.
x_SRCn p. 52
x_VOLn p. 52
…
DSP1LMIX_SRC1
DSP1LMIX_VOL1
…
DSP1LMIX_SRC2
DSP1LMIX_VOL2
…
DSP1LMIX_SRC3
DSP1LMIX_VOL3
…
DSP1LMIX_SRC4
+
DSP1 Channel 1 (0x68)
DSP1 Channel 2 (0x69)
DSP1LMIX_VOL4
DSP1 Channel 3 (0x6A)
DSP
DSP1 Channel 4 (0x6B)
DSP1RMIX_VOL4
…
DSP1AUX6_SRC
DSP1RMIX_VOL3
…
DSP1RMIX_SRC4
…
DSP1AUX5_SRC
…
DSP1RMIX_SRC3
DSP1 Channel 6 (0x6D)
+
…
DSP1AUX4_SRC
DSP1RMIX_VOL2
…
DSP1AUX3_SRC
…
DSP1RMIX_SRC2
DSP1 Channel 5 (0x6C)
…
DSP1AUX2_SRC
DSP1RMIX_VOL1
…
DSP1AUX1_SRC
…
DSP1RMIX_SRC1
Figure 4-24. Digital-Core DSP Block
The DSP mixer input control fields (see Fig. 4-24) are located at register addresses R2368–R2424 (0x0940–0x0978).
The full list of digital mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the DSP processing block. Note that the selected input sources must be
configured for the same sample rate as the DSP. Sample-rate conversion functions are available to support flexible
interconnectivity; see Section 4.3.16.
The hexadecimal numbers in Fig. 4-24 indicate the corresponding x_SRCn setting for selection of that signal as an input
to another digital-core function.
The sample rate for the DSP functions is configured using the DSP1_RATE field; see Table 4-26. Sample-rate conversion
is required when routing the DSP signal paths to any signal chain that is configured for a different sample rate.
The DSP1_RATE field must not be changed if any of the respective x_SRCn fields is nonzero. The associated x_SRCn
fields must be cleared before writing new values to DSP1_RATE. A minimum delay of 125 s must be allowed between
clearing the x_SRCn fields and writing to the DSP1_RATE field. See Table 4-26 for details.
The CS42L92 performs automatic checks to confirm that the SYSCLK frequency is high enough to support the required
DSP mixing functions. If the frequency is too low, an attempt to enable a DSP mixer path fails. Note that active signal paths
are not affected under such circumstances.
DS1162F1
71
CS42L92
4.3 Digital Core
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
4.3.8
S/PDIF Output Generator
The CS42L92 incorporates an IEC-60958-3–compatible S/PDIF output generator, as shown in Fig. 4-25; this provides a
stereo S/PDIF output on a GPIO pin. The S/PDIF transmitter allows full control over the S/PDIF validity bits and channel
status information.
The input sources to the S/PDIF transmitter are selectable for each channel, and independent volume control is provided
for each path. The *TX1 and *TX2 fields control Channels A and B (respectively) of the S/PDIF output.
The S/PDIF signal can be output directly on a GPIO pin. See Section 4.14 to configure a GPIO pin for this function.
Note that the S/PDIF signal cannot be selected as input to the digital mixers or signal-processing functions within the
CS42L92 digital core.
…
SPDIF1TX1_SRC
Channel A
SPDIF1TX1_VOL
…
SPDIF1TX2_SRC
S/PDIF
Channel B
SPDIF1TX2_VOL
GPIO
(GPn_FN = 0x04C)
SPD1_ENA p. 73
SPD1_RATE[4:0] p. 86
x_SRCn p. 52
x_VOLn p. 52
Figure 4-25. Digital-Core S/PDIF Output Generator
The S/PDIF input control fields (see Fig. 4-25) are located at register addresses R2048–R2057 (0x0800–0x0809).
The full list of digital mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the two S/PDIF channels. Note that the selected input sources must be
synchronized to the SYSCLK clocking domain, and configured for the same sample rate as the S/PDIF generator.
Sample-rate conversion functions are available to support flexible interconnectivity; see Section 4.3.15 and
Section 4.3.16.
The sample rate of the S/PDIF generator is configured using SPD1_RATE; see Table 4-26. The S/PDIF transmitter
supports sample rates in the range 32–192 kHz. Note that sample-rate conversion is required when linking the S/PDIF
generator to any signal chain that is asynchronous or configured for a different sample rate.
The SPD1_RATE field must not be changed if any of the associated x_SRCn fields is nonzero. The associated x_SRCn
fields must be cleared before writing a new value to SPD1_RATE. A minimum delay of 125 s must be allowed between
clearing the x_SRCn fields and writing to SPD1_RATE. See Table 4-26 for details.
The S/PDIF generator is enabled by setting SPD1_ENA, as described in Table 4-20.
The S/PDIF output contains audio data derived from the selected sources. Audio samples up to 24-bit width can be
accommodated. The validity bits and the channel status bits in the S/PDIF data are configured using the corresponding
fields in registers R1474 (0x5C2) to R1477 (0x5C5).
Refer to the S/PDIF specification (IEC60958-3 Digital Audio Interface - Consumer) for full details of the S/PDIF protocol
and configuration parameters.
72
DS1162F1
CS42L92
4.3 Digital Core
Table 4-20. S/PDIF Output Generator Control
Register Address
R1474 (0x05C2)
SPD1_TX_Control
Bit
13
12
0
15:8
7:6
5:3
2
1
0
R1476 (0x05C4)
15:12
SPD1_TX_
11:8
Channel_Status_2 7:4
3:0
R1477 (0x05C5)
11:8
SPD1_TX_
7:5
Channel_Status_3
4
3:2
1:0
R1475 (0x05C3)
SPD1_TX_
Channel_Status_1
Label
SPD1_VAL2
SPD1_VAL1
SPD1_ENA
Default
0
0
0
SPD1_CATCODE[7:0]
SPD1_CHSTMODE[1:0]
SPD1_PREEMPH[2:0]
SPD1_NOCOPY
SPD1_NOAUDIO
SPD1_PRO
SPD1_FREQ[3:0]
SPD1_CHNUM2[3:0]
SPD1_CHNUM1[3:0]
SPD1_SRCNUM[3:0]
SPD1_ORGSAMP[3:0]
SPD1_TXWL[2:0]
SPD1_MAXWL
SPD1_SC31_30[1:0]
SPD1_CLKACU[1:0]
0x00
00
000
0
0
0
0000
1011
0000
0001
0000
000
0
00
00
Description
S/PDIF Validity (Subframe B)
S/PDIF Validity (Subframe A)
S/PDIF Generator Enable
0 = Disabled
1 = Enabled
S/PDIF Category code
S/PDIF Channel Status mode
S/PDIF Preemphasis mode
S/PDIF Copyright status
S/PDIF Audio/nonaudio indication
S/PDIF Consumer Mode/Professional Mode
S/PDIF Indicated sample frequency
S/PDIF Channel number (Subframe B)
S/PDIF Channel number (Subframe A)
S/PDIF Source number
S/PDIF Original sample frequency
S/PDIF Audio sample word length
S/PDIF Maximum audio sample word length
S/PDIF Channel Status [31:30]
Transmitted Clock accuracy
The S/PDIF output generator provides full support for 32-bit data words. Audio data samples up to 32 bits are supported
on the AIF1, AIF3, and SLIMbus input channels, which can be routed to the S/PDIF output. Note that other signal paths
and signal-processing blocks within the digital core are limited to 24-bit data length; data samples are truncated to 24-bit
length if they are routed through any function that does not support 32-bit data words.
The CS42L92 automatically checks to confirm whether the SYSCLK frequency is high enough to support the digital mixer
paths. If an attempt is made to enable the S/PDIF generator, and there are insufficient SYSCLK cycles to support it, the
attempt does not succeed. Note that any active signal paths are unaffected under such circumstances.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
4.3.9
Tone Generator
The CS42L92 incorporates a tone generator that can be used for beep functions through any of the audio signal paths.
The tone generator provides two 1-kHz outputs, with configurable phase relationship, offering flexibility to create
differential signals or test scenarios.
1-kHz
Tone Generator
Tone Generator 1 (0x04)
Tone Generator 2 (0x05)
TONE1_ENA p. 74
TONE2_ENA p. 74
TONE_OFFSET[1:0] p. 74
TONE_RATE[4:0] p. 85
TONE1_OVD p. 74
TONE1_LVL[23:8] p. 74
TONE2_OVD p. 74
TONE2_LVL[23:8] p. 74
Figure 4-26. Digital-Core Tone Generator
The tone generator outputs can be selected as input to any of the digital mixers or signal-processing functions within the
CS42L92 digital core. The hexadecimal numbers in Fig. 4-26 indicate the corresponding x_SRCn setting for selection of
that signal as an input to another digital-core function.
DS1162F1
73
CS42L92
4.3 Digital Core
The sample rate for the tone generator is configured using TONE_RATE. See Table 4-26. Note that sample-rate
conversion is required when routing the tone generator outputs to any signal chain that is asynchronous or configured for
a different sample rate.
The tone generator outputs are enabled by setting the TONE1_ENA and TONE2_ENA bits as described in Table 4-21.
The phase relationship is configured using TONE_OFFSET.
The tone generator outputs can also provide a configurable DC signal level, for use as a test signal. The DC output is
selected using the TONEn_OVD bits, and the DC signal amplitude is configured using the TONEn_LVL fields, as
described in Table 4-21.
Table 4-21. Tone Generator Control
Register Address Bit
Label
Default
Description
R32 (0x0020)
9:8 TONE_
00
Tone Generator Phase Offset. Sets the phase of Tone Generator 2 relative to Tone
OFFSET[1:0]
Generator 1
Tone_Generator_1
00 = 0° (in phase)
01 = 90° ahead
10 = 180° ahead
11 = 270° ahead
5 TONE2_
0
Tone Generator 2 Override
OVD
0 = Disabled (1-kHz tone output)
1 = Enabled (DC signal output)
The DC signal level, when selected, is configured using TONE2_LVL[23:0]
4 TONE1_
0
Tone Generator 1 Override
OVD
0 = Disabled (1-kHz tone output)
1 = Enabled (DC signal output)
The DC signal level, when selected, is configured using TONE1_LVL[23:0]
1 TONE2_ENA
0
Tone Generator 2 Enable
0 = Disabled
1 = Enabled
0 TONE1_ENA
0
Tone Generator 1 Enable
0 = Disabled
1 = Enabled
R33 (0x0021)
15:0 TONE1_
0x1000 Tone Generator 1 DC output level
LVL[23:8]
Tone_Generator_2
TONE1_LVL[23:8] is coded as 2’s complement. Bits [23:20] contain the integer portion; bits
[19:0] contain the fractional portion.
The digital core 0 dBFS level corresponds to 0x10_0000 (+1) or 0xF0_0000 (–1).
R34 (0x0022)
7:0 TONE1_
0x00 Tone Generator 1 DC output level
LVL[7:0]
Tone_Generator_3
TONE1_LVL[23:8] is coded as 2’s complement. Bits [23:20] contain the integer portion; bits
[19:0] contain the fractional portion.
The digital core 0 dBFS level corresponds to 0x10_0000 (+1) or 0xF0_0000 (–1).
R35 (0x0023)
15:0 TONE2_
0x1000 Tone Generator 2 DC output level
LVL[23:8]
Tone_Generator_4
TONE2_LVL[23:8] is coded as 2’s complement. Bits [23:20] contain the integer portion; bits
[19:0] contain the fractional portion.
The digital core 0 dBFS level corresponds to 0x10_0000 (+1) or 0xF0_0000 (–1).
R36 (0x0024)
7:0 TONE2_
0x00 Tone Generator 2 DC output level
LVL[7:0]
Tone_Generator_5
TONE2_LVL[23:8] is coded as 2’s complement. Bits [23:20] contain the integer portion; bits
[19:0] contain the fractional portion.
The digital core 0 dBFS level corresponds to 0x10_0000 (+1) or 0xF0_0000 (–1).
4.3.10 Noise Generator
The CS42L92 incorporates a white-noise generator that can be routed within the digital core. The main purpose of the
noise generator is to provide comfort noise in cases where silence (digital mute) is not desirable.
74
DS1162F1
CS42L92
4.3 Digital Core
White Noise
Generator
Noise Generator (0x0D)
NOISE_GEN_ENA p. 75
NOISE_GEN_GAIN[4:0] p. 75
NOISE_GEN_RATE[4:0] p. 85
Figure 4-27. Digital-Core Noise Generator
The noise generator can be selected as input to any of the digital mixers or signal-processing functions within the CS42L92
digital core. The hexadecimal number (0x0D) in Fig. 4-27 indicates the corresponding x_SRCn setting for selection of the
noise generator as an input to another digital-core function.
The sample rate for the noise generator is configured using NOISE_GEN_RATE. See Table 4-26. Note that sample-rate
conversion is required when routing the noise generator output to any signal chain that is asynchronous or configured for
a different sample rate.
The noise generator is enabled by setting NOISE_GEN_ENA, described in Table 4-22. The signal level is configured using
NOISE_GEN_GAIN.
Table 4-22. Noise Generator Control
Register Address
R160 (0x00A0)
Comfort_Noise_
Generator
Bit
5
Label
NOISE_GEN_
ENA
Default
0
4:0
NOISE_GEN_
GAIN[4:0]
0x00
Description
Noise Generator Enable
0 = Disabled
1 = Enabled
Noise generator signal level
0x00 = –114 dBFS
…(6-dB steps)
All other codes are reserved
0x01 = –108 dBFS
0x11 = –6 dBFS
0x02 = –102 dBFS
0x12 = 0 dBFS
4.3.11 Haptic Signal Generator
The CS42L92 incorporates a signal generator for use with haptic devices (e.g., mechanical vibration actuators). The haptic
signal generator is compatible with both eccentric rotating mass (ERM) and linear resonant actuator (LRA) haptic devices.
The haptic signal generator is highly configurable, and includes the capability to execute a programmable event profile
comprising three distinct operating phases.
The resonant frequency of the haptic signal output (for LRA devices) is selectable, providing support for many different
actuator components.
The haptic signal generator is a digital signal generator, which is incorporated within the digital core of the CS42L92. In a
typical use case the haptic signal may be routed, via one of the digital-core output mixers, to the digital PDM output. An
external amplifier can be used to drive the haptic device, as shown in Fig. 4-28.
DS1162F1
75
CS42L92
4.3 Digital Core
Digital Core Output Mixer
Haptic Signal
Generator
Haptic Output
(06h)
HAP_ACT p. 76
HAP_CTRL[1:0] p. 76
ONESHOT_TRIG p. 76
LRA_FREQ[14:0] p. 77
HAP_RATE[4:0] p. 85
Output
Volume
PDM
Output
+
OUTnxMIX_SRCn
OUTnxMIX_VOLn
External
Amplifier
Haptic
Device
x_SRCn p. 52
x_VOLn p. 52
Figure 4-28. Digital-Core Haptic Signal Generator
The hexadecimal number (0x06) in Fig. 4-28 indicates the corresponding x_SRCn setting for selection of the haptic signal
generator as an input to another digital-core function.
The haptic signal generator is selected as input to one of the digital-core output mixers by setting the x_SRCn field of the
applicable output mixer to 0x06.
The sample rate for the haptic signal generator is configured using the HAP_RATE field. See Table 4-26. Note that
sample-rate conversion is required when routing the haptic signal generator output to any signal chain that is
asynchronous or configured for a different sample rate.
The haptic signal generator is configured for an ERM or LRA actuator using the HAP_ACT bit. The required resonant
frequency is configured using the LRA_FREQ field. Note that the resonant frequency is only applicable to LRA actuators.
The signal generator can be enabled in continuous mode or configured for one-shot mode using the HAP_CTRL field, as
described in Table 4-23. In one-shot mode, the output is triggered by writing to the ONESHOT_TRIG bit.
In one-shot mode, the signal generator profile comprises the distinct phases (1, 2, 3). The duration and intensity of each
output phase is programmable.
In continuous mode, the signal intensity is controlled using the PHASE2_INTENSITY field only.
In the case of an ERM actuator (HAP_ACT = 0), the haptic output is a DC signal level, which may be positive or negative,
as selected by the x_INTENSITY fields.
For an LRA actuator (HAP_ACT = 1), the haptic output is an AC signal; selecting a negative signal level corresponds to a
180° phase inversion. In some applications, phase inversion may be desirable during the final phase, to halt the physical
motion of the haptic device.
Table 4-23. Haptic Signal Generator Control
Register Address Bit
Label
R144 (0x0090)
4 ONESHOT_
TRIG
Haptics_Control_1
3:2 HAP_CTRL[1:0]
1
76
HAP_ACT
Default
Description
0
Haptic One-Shot Trigger. Writing 1 starts the one-shot profile (i.e., Phase 1, Phase 2,
Phase 3)
00
Haptic Signal Generator Control
00 = Disabled
10 = One-Shot
01 = Continuous
11 = Reserved
0
Haptic Actuator Select
0 = Eccentric rotating mass (ERM)
1 = Linear resonant actuator (LRA)
DS1162F1
CS42L92
4.3 Digital Core
Table 4-23. Haptic Signal Generator Control (Cont.)
Register Address Bit
Label
R145 (0x0091)
14:0 LRA_
FREQ[14:0]
Haptics_Control_2
Default
Description
0x7FFF Haptic Resonant Frequency. Selects the haptic signal frequency (LRA actuator only,
HAP_ACT = 1)
Haptic Frequency (Hz) = System Clock/(2 x (LRA_FREQ+1)), where System Clock =
6.144 MHz or 5.6448 MHz, derived by division from SYSCLK or ASYNCCLK.
If HAP_RATE < 1000, SYSCLK is the clock source, and the applicable System Clock
frequency is determined by SYSCLK.
If HAP_RATE 1000, ASYNCCLK is the clock source, and the applicable System Clock
frequency is determined by ASYNCCLK.
Valid for haptic frequency in the range 100–250 Hz
For 6.144-MHz System Clock:
For 5.6448-MHz System Clock:
0x77FF = 100 Hz
0x6E3F = 100 Hz
0x4491 = 175 Hz
0x3EFF = 175 Hz
0x2FFF = 250 Hz
0x2C18 = 250 Hz
R146 (0x0092)
7:0 PHASE1_
0x00 Haptic Output Level (Phase 1). Selects the signal intensity of Phase 1 in one-shot mode.
INTENSITY[7:0]
Haptics_phase_1_
Coded as 2’s complement. Range is ± Full Scale (FS).
intensity
For ERM actuator, this selects the DC signal level for the haptic output.
For LRA actuator, this selects the AC peak amplitude; negative values correspond to a
180° phase shift.
R147 (0x0093)
8:0 PHASE1_
0x000 Haptic Output Duration (Phase 1). Selects the duration of Phase 1 in one-shot mode.
DURATION[8:0]
Haptics_Control_
0x000 = 0 ms
phase_1_duration
0x001 = 0.625 ms
0x002 = 1.25 ms
… (0.625-ms steps)
0x1FF = 319.375 ms
R148 (0x0094)
7:0 PHASE2_
0x00 Haptic Output Level (Phase 2)
INTENSITY[7:0]
Haptics_phase_2_
Selects the signal intensity in Continuous mode or Phase 2 of one-shot mode.
intensity
Coded as 2’s complement. Range is ± Full Scale (FS).
For ERM actuator, this selects the DC signal level for the haptic output.
For LRA actuator, this selects the AC peak amplitude; Negative values correspond to a
180° phase shift.
10:0 PHASE2_
0x000 Haptic Output Duration (Phase 2). Selects the duration of Phase 2 in one-shot mode.
R149 (0x0095)
DURATION[10:0]
0x000 = 0 ms
0x002 = 1.25 ms
0x7FF = 1279.375 ms
Haptics_phase_2_
duration
0x001 = 0.625 ms
… (0.625-ms steps)
7:0 PHASE3_
0x00 Haptic Output Level (Phase 3). Selects the signal intensity of Phase 3 in one-shot mode.
R150 (0x0096)
INTENSITY[7:0]
Coded as 2’s complement.
Haptics_phase_3_
intensity
Range is ± Full Scale (FS).
For ERM actuator, this selects the DC signal level for the haptic output.
For LRA actuator, this selects the AC peak amplitude; Negative values correspond to a
180° phase shift.
R151 (0x0097)
8:0 PHASE3_
0x000 Haptic Output Duration (Phase 3). Selects the duration of Phase 3 in one-shot mode.
DURATION[8:0]
0x1FF = 319.375 ms
Haptics_phase_3_
0x000 = 0 ms
0x002 = 1.25 ms
duration
0x001 = 0.625 ms
… (0.625-ms steps)
R152 (0x0098)
0 ONESHOT_STS
0
Haptic One-Shot status
Haptics_Status
0 = One-Shot event not in progress
1 = One-Shot event in progress
4.3.12 PWM Generator
The CS42L92 incorporates two PWM signal generators as shown in Fig. 4-29. The duty cycle of each PWM signal can be
modulated by an audio source, or can be set to a fixed value using a control register setting.
A four-input mixer is associated with each PWM generator. The four input sources are selectable in each case, and
independent volume control is provided for each path.
PWM signal generators can be output directly on a GPIO pin. See Section 4.14 to configure a GPIO pin for this function.
Note that the PWM signal generators cannot be selected as input to the digital mixers or signal-processing functions within
the CS42L92 digital core.
DS1162F1
77
CS42L92
4.3 Digital Core
When PWMn_OVD = 0, the PWM duty cycle is controlled by the respective digital audio mixer .
When PWMn_OVD = 1, the PWM duty cycle is set by PWMn _LVL.
PWM sample rate and clocking frequency are selected using PWM _RATE and PWM_CLK_SEL.
…
PWM1MIX_SRC1
PWM1MIX_VOL1
…
PWM1MIX_SRC2
PWM1MIX_VOL2
…
PWM1MIX_SRC3
PWM1MIX_VOL3
…
PWM1MIX_SRC4
PWM1MIX_VOL4
+
PWM1
PWM1_ENA p. 79
PWM1_OVD p. 79
PWM1_LVL[9:0] p. 79
GPIO
(GPn_FN = 0x048)
PWM_RATE[4:0] p. 85
PWM_CLK_SEL[2:0] p. 79
…
PWM2MIX_SRC1
PWM2MIX_VOL1
…
PWM2MIX_SRC2
PWM2MIX_VOL2
…
PWM2MIX_SRC3
PWM2MIX_VOL3
…
PWM2MIX_SRC4
PWM2MIX_VOL4
+
PWM2
PWM2_ENA p. 79
PWM2_OVD p. 79
PWM2_LVL[9:0] p. 79
GPIO
(GPn_FN = 0x049)
x_SRCn p. 52
x_VOLn p. 52
Figure 4-29. Digital-Core PWM Generator
The PWM1 and PWM2 mixer control fields (see Fig. 4-29) are located at register addresses R1600–R1615
(0x0640–0x064F).
The full list of digital mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the respective mixers. Note that the selected input sources must be
configured for the same sample rate as the mixer to which they are connected. Sample-rate conversion functions are
available to support flexible interconnectivity; see Section 4.3.15 and Section 4.3.16.
The PWM sample rate (cycle time) is configured using PWM_RATE. See Table 4-26. Note that sample-rate conversion is
required when linking the PWM generators to any signal chain that is asynchronous or configured for a different sample
rate.
The PWM_RATE field must not be changed if any of the associated x_SRCn fields is nonzero. The associated x_SRCn
fields must be cleared before writing a new value to PWM_RATE. A minimum delay of 125 s must be allowed between
clearing the x_SRCn fields and writing to PWM_RATE. See Table 4-26 for details.
The PWM generators are enabled by setting PWM1_ENA and PWM2_ENA, respectively, as described in Table 4-24.
Under default conditions (PWMn_OVD = 0), the duty cycle of the PWM generators is controlled by an audio signal path;
a 4-input mixer is associated with each PWM generator, as shown in Fig. 4-29.
When the PWMn_OVD bit is set, the duty cycle of the respective PWM generator is set to a fixed ratio; in this case, the
duty cycle ratio is configurable using the PWMn_LVL fields.
The PWM generator clock frequency is selected using PWM_CLK_SEL. For best performance, the highest available
setting should be used. Note that the PWM generator clock must not be set to a higher frequency than SYSCLK (if PWM_
RATE < 1000) or ASYNCCLK (if PWM_RATE 1000).
78
DS1162F1
CS42L92
4.3 Digital Core
Table 4-24. PWM Generator Control
Register Address Bit
Label
R48 (0x0030)
10:8 PWM_CLK_
SEL[2:0]
PWM_Drive_1
Default
000
5
PWM2_OVD
0
4
PWM1_OVD
0
1
PWM2_ENA
0
0
PWM1_ENA
0
R49 (0x0031)
PWM_Drive_2
9:0
PWM1_LVL[9:0]
0x100
R50 (0x0032)
PWM_Drive_3
9:0
PWM2_LVL[9:0]
0x100
Description
PWM Clock Select
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
All other codes are reserved.
The frequencies in brackets apply for 44.1 kHz–related sample rates only.
PWM_CLK_SEL controls the resolution of the PWM generator; higher settings
correspond to higher resolution.
The PWM Clock must be less than or equal to SYSCLK (if PWM_RATE < 1000)
or less than or equal to ASYNCCLK (if PWM_RATE 1000).
PWM2 Generator Override
0 = Disabled (PWM duty cycle is controlled by audio source)
1 = Enabled (PWM duty cycle is controlled by PWM2_LVL).
PWM1 Generator Override
0 = Disabled (PWM1 duty cycle is controlled by audio source)
1 = Enabled (PWM1 duty cycle is controlled by PWM1_LVL).
PWM2 Generator Enable
0 = Disabled
1 = Enabled
PWM1 Generator Enable
0 = Disabled
1 = Enabled
PWM1 Override Level. Sets the PWM1 duty cycle when PWM1_OVD = 1.
Coded as 2’s complement.
0x000 = 50% duty cycle
0x200 = 0% duty cycle
PWM2 Override Level. Sets the PWM2 duty cycle when PWM2_OVD = 1.
Coded as 2’s complement.
0x000 = 50% duty cycle
0x200 = 0% duty cycle
The CS42L92 automatically checks to confirm that the SYSCLK frequency is high enough to support the digital mixer
paths. If an attempt is made to enable a PWM signal mixer path, without sufficient SYSCLK cycles to support it, the attempt
fails. Note that any signal paths that are already active are not affected under such circumstances.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
4.3.13 Data Format Conversion
The digital mixing and signal-processing functions on the CS42L92 are designed to route audio data in signed fixed point
format. Data format converter (DFC) blocks are incorporated in the digital core, with the capability to convert audio data
between signed, unsigned, and floating-point formats. The DFCs enable the flexibility to support many different interface
standards on the input and output signal paths. They can also be used to apply dithering to digital audio data.
The digital core provides eight DFC blocks as shown in Fig. 4-30. Each DFC supports one input and one output path only.
DS1162F1
79
CS42L92
4.3 Digital Core
x_SRCn p. 52
…
DFCn_SRC
DFC
Data Format Converter
DFCn_ENA
DFCn_RX_DATA_TYPE
DFCn_RATE
DFCn_RX_DATA_WIDTH
DFCn_DITH_ENA DFCn_TX_DATA_TYPE
DFCn_TX_DATA_WIDTH
DFC1 (0xF8)
DFC2 (0xF9)
DFC3 (0xFA)
DFC4 (0xFB)
DFC5 (0xFC)
DFC6 (0xFD)
DFC7 (0xFE)
DFC8 (0xFF)
CS42L92 supports eight DFC blocks, i.e., n = 1–8
Figure 4-30. Digital-Core DFC Blocks
The DFC1–DFC8 input control fields (see Fig. 4-30) are located at register addresses R3520–R3576 (0x0DC0–0x0DF8).
The full list of digital-mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the respective DFCs. Note that the selected input sources must be
configured for the same sample rate as the DFC to which they are connected. Sample-rate conversion functions are
available to support flexible interconnectivity; see Section 4.3.15 and Section 4.3.16.
The hexadecimal numbers in Fig. 4-30 indicate the corresponding x_SRCn setting for selection of that signal as an input
to another digital-core function.
The sample rate for each converter DFCn is configured using the respective DFCn_RATE field; see Table 4-26. Note that
sample-rate conversion is required when routing the DFC paths to any signal chain that is asynchronous or configured for
a different sample rate.
The DFCn_RATE fields must not be changed if the associated x_SRCn field is nonzero. The associated x_SRCn field
must be cleared before writing a new value to DFCn_RATE. A minimum delay of 125 s must be allowed between clearing
the x_SRCn field and writing to the associated DFCn_RATE field. See Table 4-26 for details.
The DFC is enabled by setting DFCn_ENA.
The input data format is configured using the DFCn_RX_DATA_TYPE and DFCn_RX_DATA_WIDTH fields. Valid data
types are signed fixed point, unsigned fixed point, and three different floating point configurations. If a fixed point data type
is selected, the data width (number of data bits) is selected using DFCn_RX_DATA_WIDTH.
The DFC input can be any of the digital core inputs or signal processing blocks. If the input data type is unsigned or floating
point format, one of the AIF or SLIMbus RX channels must be selected as the DFC input source—unsigned and floating
point data types are not valid selections with any other source within the digital core.
The output data format is configured using the DFCn_TX_DATA_TYPE and DFCn_TX_DATA_WIDTH fields. Valid data
types are signed fixed point, unsigned fixed point, and floating point formats. If a fixed point data type is selected, the data
width (number of data bits) is selected using DFCn_TX_DATA_WIDTH.
The DFC output can be selected as input to any of the digital mixers or signal-processing functions within the CS42L92
digital core. If the DFC output data type is unsigned fixed point or floating point format, it must be routed directly to the AIF
or SLIMbus TX channels using the respective digital-core output mixers—unsigned fixed point or floating point data is not
valid as input to any other digital core functions.
Note:
80
If unsigned fixed point or floating point data is routed from a DFC output to an AIF or SLIMbus TX channel, the
DFC must be the only enabled signal path in the respective output mixer, and the associated volume selection
must be 0 dB.
DS1162F1
CS42L92
4.3 Digital Core
The DFC can apply dithering to its output data; this is enabled by setting DFCn_DITH_ENA. Note that dithering is only
valid if the output data is in fixed point format (signed or unsigned). If the output data type is floating point, the DFCn_
DITH_ENA bit must be cleared.
The dither function can be used to improve the noise characteristics of signals routed in the digital core. Dithering is
particularly recommended if truncating audio data (e.g., from 32- to 24-bit format) as it converts the truncation/quantization
errors into benign background noise.
The DFCs provide input to the interrupt control circuit and can be used to trigger an interrupt event if saturation (arithmetic
error) is detected; see Section 4.15.
The control registers associated with the DFCs are described in Table 4-25.
Table 4-25. Digital-Core DFC Control
Register Address
R5248 (0x1480)
DFC1_CTRL_W0
R5254 (0x1486)
DFC2_CTRL_W0
R5260 (0x148C)
DFC3_CTRL_W0
R5266 (0x1492)
DFC4_CTRL_W0
R5272 (0x1498)
DFC5_CTRL_W0
R5278 (0x149E)
DFC6_CTRL_W0
R5284 (0x14A4)
DFC7_CTRL_W0
R5290 (0x14AA)
DFC8_CTRL_W0
R5250 (0x1482)
DFC1_RX_W0
R5256 (0x1488)
DFC2_RX_W0
R5262 (0x148E)
DFC3_RX_W0
R5268 (0x1494)
DFC4_RX_W0
R5274 (0x149A)
DFC5_RX_W0
R5280 (0x14A0)
DFC6_RX_W0
R5286 (0x14A6)
DFC7_RX_W0
R5292 (0x14AC)
DFC8_RX_W0
R5252 (0x1488)
DFC1_TX_W0
R5258 (0x148A)
DFC2_TX_W0
R5264 (0x1490)
DFC3_TX_W0
R5270 (0x1494)
DFC4_TX_W0
R5276 (0x149C)
DFC5_TX_W0
R5282 (0x14A2)
DFC6_TX_W0
R5288 (0x14A8)
DFC7_TX_W0
R5294 (0x14AE)
DFC8_TX_W0
DS1162F1
Bit
1
0
Label
DFCn_DITH_ENA
DFCn_ENA
Default
Description
0
DFCn dither enable (valid for fixed point output data only)
0 = Disabled
1 = Enabled
0
DFCn enable
0 = Disabled
1 = Enabled
12:8 DFCn_RX_DATA_
WIDTH[4:0]
0x1F
2:0
DFCn_RX_DATA_
TYPE[2:0]
000
12:8 DFCn_TX_DATA_
WIDTH[4:0]
0x1F
2:0
000
DFCn_TX_DATA_
TYPE[2:0]
DFCn input data width (valid for fixed point data types only)
0x00 to 0x06 = Reserved
0x09 = 10 bits
0x07 = 8 bits
...
0x08 = 9 bits
0x1F = 32 bits
DFCn input data type
000 = Signed, fixed point
001 = Unsigned, fixed point
010 = Single-precision floating point (binary32)
100 = Half-precision floating point (binary16)
101 = ARM-alternative half-precision floating point
All other codes are reserved.
DFCn output data width (valid for fixed point data types only)
0x00 to 0x06 = Reserved
0x09 = 10 bits
0x07 = 8 bits
...
0x08 = 9 bits
0x1F = 32 bits
DFCn output data type
000 = Signed, fixed point
001 = Unsigned, fixed point
010 = Single-precision floating point (binary32)
100 = Half-precision floating point (binary16)
101 = ARM-alternative half-precision floating point
All other codes are reserved.
81
CS42L92
4.3 Digital Core
The CS42L92 automatically checks to confirm whether the SYSCLK frequency is high enough to support the commanded
DFC and digital mixing functions. If an attempt is made to enable DFC signal path, and there are insufficient SYSCLK
cycles to support it, the attempt does not succeed. Note that any signal paths that are already active are not affected under
such circumstances.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
4.3.14 Sample-Rate Control
The CS42L92 supports multiple signal paths through the digital core. Stereo full-duplex sample-rate conversion is provided
to allow digital audio to be routed between interfaces operating at different sample rates and/or referenced to
asynchronous clock domains.
Two independent clock domains are supported for the audio signal paths, referenced to SYSCLK and ASYNCCLK
respectively, as described in Section 4.16. Every digital signal path must be synchronized either to SYSCLK or to
ASYNCCLK.
Up to five different sample rates may be in use at any time on the CS42L92. Three of these sample rates must be
synchronized to SYSCLK; the remaining two, where required, must be synchronized to ASYNCCLK.
Sample-rate conversion is required when routing any audio path between digital functions that are asynchronous or
configured for different sample rates.
The asynchronous sample-rate converter (ASRC) supports two-way stereo conversion paths between the SYSCLK and
ASYNCCLK domains. The ASRC is described in Section 4.3.15.
There are two isochronous sample-rate converters (ISRCs). Each ISRC supports two-way, two-channel conversion paths
between sample rates on the SYSCLK domain, or between sample rates on the ASYNCCLK domain. The ISRCs are
described in Section 4.3.16.
The sample rate of different blocks within the CS42L92 digital core are controlled as shown in Fig. 4-31. The x_RATE fields
select the applicable sample rate for each respective group of digital functions.
The x_RATE fields must not be changed if any of the x_SRCn fields associated with the respective functions is nonzero.
The associated x_SRCn fields must be cleared before writing new values to the x_RATE fields. A minimum delay of 125 s
must be allowed between clearing the x_SRCn fields and writing to the associated x_RATE fields. See Table 4-26 for
details.
82
DS1162F1
CS42L92
4.3 Digital Core
DSP1 – DSP1_RATE
Silence (mute)
IN1L signal path
IN1R signal path
AEC1 Loopback
IN2L signal path
IN2R signal path
DSP1 Ch 1
+
AEC2 Loopback
DSP1 Ch 2
OUT_RATE
IN3L signal path
DSP1 Ch 3
DSP Core
Ultrasonic 1 path
IN3R signal path
DSP1 Ch 4
US1_RATE
IN4L signal path
IN4R signal path
+
Ultrasonic 2 path
DSP1 Ch 5
US2_RATE
IN_RATE, or INnx_RATE
DSP1 Ch 6
ISRC2
ISRC1
ASRC1
ASRC1 Left
Asynchronous
Sample Rate
Converter (ASRC)
Isochronous
Sample Rate
Converter (ISRC)
ASRC1 Right
ASRC1 Left
ISRCn DEC1
ASRC1 Right
ISRCn DEC2
ASRC1_RATE1
ASRC1_RATE2
DFC8 – DFC8_RATE
DFC7 – DFC7_RATE
DFC6 – DFC6_RATE
DFC5 – DFC5_RATE
DFC
OUT5
OUT3
OUT2
OUT1
ISRCn INT1
ISRCn INT2
OUT_RATE
+
ISRCn_FSL
Stereo
Output
Paths
ISRCn_FSH
DFC4 – DFC4_RATE
DFC3 – DFC3_RATE
DFC2 – DFC2_RATE
DFC1 – DFC1_RATE
DFC
DFCn
OUTnL output
+
OUTnR output
DFCn
SLIMbus
SLIMRXn_RATE (n = 1..8)
SLIMTXn_RATE (n = 1..8)
SLIMbus = 8 input , 8 output
PWM_RATE
FX_RATE
PWM2
PWM1
+
PWM
AIF3 – AIF3_RATE
AIF2 – AIF2_RATE
LHPF4
LHPF3
LHPF2
LHPF1
AIF1 – AIF1_RATE
(GPIO pin)
+
LHPF
+
LHPFn
AIFn TX1 output
SPD1_RATE
S/PDIF
HAP_RATE
Haptic Signal
Generator
EQ4
EQ3
EQ2
EQ1
(GPIO pin)
+
AIFn TX2 output
EQn
AIFn TX... output
DRC2
DRC1
+
AIFn TX... output
+
DRCn
Left
Noise Generator
etc...
DRC
AIFn RX1
TONE_RATE
+
Tone Generator
+
Haptic Output
NOISE_GEN_RATE
White Noise
Generator
EQ
+
Tone Generator 1
DRCn
Right
AIF1 = 8 input , 8 output
AIF2 = 8 input , 8 output
AIF3 = 8 input , 8 output
AIFn RX2
AIFn RX...
Tone Generator 2
AIFn RX...
Figure 4-31. Digital-Core Sample-Rate Control
The input signal paths may be selected as input to the digital mixers or signal-processing functions. The sample rate for
the input signal paths can either be set globally (using IN_RATE), or can be configured independently for each input
channel (using the respective INnx_RATE fields). The applicable mode depends on IN_RATE_MODE, as described in
DS1162F1
83
CS42L92
4.3 Digital Core
Table 4-3.
The ultrasonic demodulator circuits can be selected as input to the digital mixers or signal-processing functions. The
sample rate for these signals are configured using US1_RATE and US2_RATE. The selected sample rate must be equal
to the output rate of the demodulator function, set by the respective USn_FREQ field—see Section 4.2.9.
The output signal paths are derived from the respective output mixers. The sample rate for the output signal paths is
configured using OUT_RATE. The sample rate of the AEC loop-back path is also set by OUT_RATE. Clocking for the
DACs and output signal path circuits must also be configured using the OUT_CLK_SRC field—see Section 4.11.2.
The AIFn RX inputs may be selected as input to the digital mixers or signal-processing functions. The AIFn TX outputs are
derived from the respective output mixers. The sample rates for digital audio interfaces (AIF1–AIF3) are configured using
the AIFn_RATE fields (where n identifies the applicable AIF 1, 2, or 3) respectively.
The SLIMbus interface supports up to eight input channels and eight output channels. The sample rate of each channel
can be configured independently, using SLIMTXn_RATE and SLIMRXn_RATE.
Note that the SLIMbus interface provides simultaneous support for SYSCLK-referenced and ASYNCCLK-referenced
sample rates on different channels. For example, 48-kHz and 44.1-kHz SLIMbus audio paths can be simultaneously
supported.
The EQ, DRC, and LHPF functions can be enabled in any signal path within the digital core. The sample rate for these
functions is configured using FX_RATE. Note that the EQ, DRC, and LHPF functions must all be configured for the same
sample rate.
The DSP functions can be enabled in any signal path within the digital core. The applicable sample rate is configured using
the DSP1_RATE field.
The S/PDIF transmitter can be enabled on a GPIO pin. Stereo inputs to this function can be configured from any of the
digital-core inputs, mixers, or signal-processing functions. The sample rate of the S/PDIF transmitter is configured using
SPD1_RATE.
The tone generator and noise generator can be selected as input to any of the digital mixers or signal-processing functions.
The sample rates for these sources are configured using the TONE_RATE and NOISE_GEN_RATE fields, respectively.
The haptic signal generator can be used to control an external vibe actuator. In a typical use case the haptic signal may
be routed, via one of the digital-core output mixers, to the digital PDM output (OUT5). The sample rate for the haptic signal
generator is configured using HAP_RATE.
The PWM signal generators can be modulated by an audio source, derived from the associated signal mixers. The sample
rate (cycle time) for the PWM signal generators is configured using PWM_RATE.
The DFCn blocks can be enabled in signal paths within the digital core. The applicable sample rates are configured using
the DFCn_RATE fields (where n identifies the applicable DFC block).
The sample-rate control registers are described in Table 4-26. Refer to the field descriptions for details of the valid
selections in each case—note that the input (ADC) and output (DAC) signal paths must always be associated with the
SYSCLK clocking domain; different sample rates may be selected concurrently, but both these rates must be synchronized
to SYSCLK.
The control registers associated with the ASRC and ISRCs are described in Table 4-27 and Table 4-28.
Note that 32-bit register addressing is used from R12888 (0x3000) upwards; 16-bit format is used otherwise. The registers
noted in Table 4-26 contain a mixture of 16-bit and 32-bit register addresses.
84
DS1162F1
CS42L92
4.3 Digital Core
Table 4-26. Digital-Core Sample-Rate Control
Register Address Bit
Label
Default
Description
R32 (0x0020)
15:11 TONE_RATE[4:0]
0x00 Tone Generator Sample Rate
Tone_Generator_1
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
R48 (0x0030)
15:11 PWM_RATE[4:0]
0x00 PWM Frequency (sample rate)
PWM_Drive_1
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
All PWMnMIX_SRCm fields must be cleared before changing PWM_RATE.
R144 (0x0090)
15:11 HAP_RATE[4:0]
0x00 Haptic Signal Generator Sample Rate
Haptics_Control_1
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
R160 (0x00A0)
15:11 NOISE_GEN_
0x00 Noise Generator Sample Rate
RATE[4:0]
Comfort_Noise_
0x00 = SAMPLE_RATE_1
Generator
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
R776 (0x0308)
15:11 IN_RATE[4:0]
0x00 Input Signal Paths Sample Rate (only valid if IN_RATE_MODE = 0)
Input_Rate
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
If 384 kHz/768 kHz DMIC rate is selected on any of the input paths (INn_
OSR = 01X), the input paths sample rate is valid up to 48 kHz/96 kHz respectively.
DS1162F1
85
CS42L92
4.3 Digital Core
Table 4-26. Digital-Core Sample-Rate Control (Cont.)
Register Address
R787 (0x0313)
IN1L_Rate_
Control
R791 (0x0317)
IN1R_Rate_
Control
R795 (0x031B)
IN2L_Rate_
Control
R799 (0x031F)
IN2R_Rate_
Control
R803 (0x0323)
IN3L_Rate_
Control
R807 (0x0327)
IN3R_Rate_
Control
R811 (0x032B)
IN4L_Rate_
Control
R815 (0x032F)
IN4R_Rate_
Control
R1032 (0x0408)
Output_Rate_1
Bit
Label
15:11 IN1L_RATE[4:0]
R1283 (0x0503)
AIF1_Rate_Ctrl
R1347 (0x0543)
AIF2_Rate_Ctrl
R1411 (0x0583)
AIF3_Rate_Ctrl
R1474 (0x05C2)
SPD1_TX_Control
86
15:11 IN1R_RATE[4:0]
15:11 IN2L_RATE[4:0]
Default
Description
0x00 Input Path n (Left/Right) Sample Rate (only valid if IN_RATE_MODE = 1)
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x00 0x02 = SAMPLE_RATE_3
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
0x00 If 384 kHz/768 kHz DMIC rate is selected (INn_OSR = 01X), the INnL/INnR sample
rate is valid up to 48 kHz/96 kHz respectively.
15:11 IN2R_RATE[4:0]
0x00
15:11 IN3L_RATE[4:0]
0x00
15:11 IN3R_RATE[4:0]
0x00
15:11 IN4L_RATE[4:0]
0x00
15:11 IN4R_RATE[4:0]
0x00
15:11 OUT_RATE[4:0]
0x00
15:11 AIF1_RATE[4:0]
0x00
15:11 AIF2_RATE[4:0]
0x00
15:11 AIF3_RATE[4:0]
0x00
8:4
SPD1_RATE[4:0]
0x00
Output Signal Paths Sample Rate
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–384 kHz.
All OUTnxMIX_SRCm fields must be cleared before changing OUT_RATE.
AIFn Audio Interface Sample Rate
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–384 kHz.
All AIFnTXMIX_SRCm fields must be cleared before changing AIFn_RATE.
S/PDIF Transmitter Sample Rate
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 32–192 kHz.
All SPDIF1TXn_SRC fields must be cleared before changing SPD1_RATE.
DS1162F1
CS42L92
4.3 Digital Core
Table 4-26. Digital-Core Sample-Rate Control (Cont.)
Register Address Bit
Label
R1509 (0x05E5)
15:11 SLIMRX2_
RATE[4:0]
SLIMbus_Rates_1
7:3 SLIMRX1_
RATE[4:0]
R1510 (0x05E6)
15:11 SLIMRX4_
RATE[4:0]
SLIMbus_Rates_2
7:3 SLIMRX3_
RATE[4:0]
R1511 (0x05E7)
15:11 SLIMRX6_
RATE[4:0]
SLIMbus_Rates_3
7:3 SLIMRX5_
RATE[4:0]
R1512 (0x05E8)
14:15 SLIMRX8_
RATE[4:0]
SLIMbus_Rates_4
7:3 SLIMRX7_
RATE[4:0]
R1513 (0x05E9)
15:11 SLIMTX2_
RATE[4:0]
SLIMbus_Rates_5
7:3 SLIMTX1_
RATE[4:0]
R1514 (0x05EA)
15:11 SLIMTX4_
RATE[4:0]
SLIMbus_Rates_6
7:3 SLIMTX3_
RATE[4:0]
R1515 (0x05EB)
15:11 SLIMTX6_
RATE[4:0]
SLIMbus_Rates_7
7:3 SLIMTX5_
RATE[4:0]
R1516 (0x05EC)
15:11 SLIMTX8_
RATE[4:0]
SLIMbus_Rates_8
7:3 SLIMTX7_
RATE[4:0]
R3584 (0x0E00)
15:11 FX_RATE[4:0]
FX_Ctrl1
Default
Description
0x00 SLIMbus RX Channel n Sample Rate
0x00 = SAMPLE_RATE_1
0x00 0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x00 0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
0x00
All other codes are reserved.
0x00 The selected sample rate is valid in the range 8–384 kHz.
0x00
0x00
0x00
0x00
0x00
0x00
0x00
0x00
0x00
0x00
0x00
0x00
R4225 (0x1081)
US1_Ctrl_1
15:11 US1_RATE[4:0]
0x00
R4227 (0x1083)
US2_Ctrl_1
15:11 US2_RATE[4:0]
0x00
DS1162F1
SLIMbus TX Channel n Sample Rate
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–384 kHz.
All SLIMTXnMIX_SRCm fields must be cleared before changing SLIMTXn_RATE.
FX Sample Rate (EQ, LHPF, DRC)
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
All EQnMIX_SRCm, DRCnxMIX_SRCm, and LHPFnMIX_SRCm fields must be
cleared before changing FX_RATE.
Ultrasonic Demodulator 1 Sample Rate
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
All other codes are reserved. The selected sample rate must be the same as the
output rate set by US1_FREQ (i.e., 8, 16, or 32 kHz).
Ultrasonic Demodulator 2 Sample Rate
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
All other codes are reserved. The selected sample rate must be the same as the
output rate set by US2_FREQ (i.e., 8, 16, or 32 kHz).
87
CS42L92
4.3 Digital Core
Table 4-26. Digital-Core Sample-Rate Control (Cont.)
Register Address Bit
R5248 (0x1480)
6:2
DFC1_CTRL_W0
R5254 (0x1486)
6:2
DFC2_CTRL_W0
R5260 (0x148C)
6:2
DFC3_CTRL_W0
R5266 (0x1492)
6:2
DFC4_CTRL_W0
R5272 (0x1498)
6:2
DFC5_CTRL_W0
R5278 (0x149E)
6:2
DFC6_CTRL_W0
R5284 (0x14A4)
6:2
DFC7_CTRL_W0
R5290 (0x14AA)
6:2
DFC8_CTRL_W0
R1048064 (0xF_
15:11
FE00)
DSP1_Config_1
Label
DFC1_RATE[4:0]
DFC2_RATE[4:0]
DFC3_RATE[4:0]
DFC4_RATE[4:0]
DFC5_RATE[4:0]
Default
Description
0x00 DFCn Sample Rate
0x00 = SAMPLE_RATE_1
0x00 0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x00 0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
0x00
All other codes are reserved.
0x00 The selected sample rate is valid in the range 8–192 kHz.
The DFCn_SRC field must be cleared before changing DFCn_RATE.
DFC6_RATE[4:0]
0x00
DFC7_RATE[4:0]
0x00
DFC8_RATE[4:0]
0x00
DSP1_RATE[4:0]
0x00
DSP1 Sample Rate
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–384 kHz.
All DSP1xMIX_SRCm fields must be cleared before changing DSP1_RATE.
4.3.15 Asynchronous Sample-Rate Converter (ASRC)
The CS42L92 supports multiple signal paths through the digital core. Two independent clock domains are supported for
the audio signal paths, referenced to SYSCLK and ASYNCCLK respectively, as described in Section 4.16. Every digital
signal path must be synchronized either to SYSCLK or to ASYNCCLK.
The ASRC provides stereo, two-way signal paths between two sample rates, as shown in Fig. 4-32. Each of the sample
rates may be referenced to the SYSCLK or ASYNCCLK domain. The clock domains and sample rates associated with the
ASRC signal paths are selected using the ASRC1_RATE1 and ASRC1_RATE2 fields.
•
ASRC1_RATE1 selects the clock domain and sample rate of the inputs to the ASRC1 IN1x paths, and the outputs
from the ASRC1 IN2x paths.
•
ASRC1_RATE2 selects the clock domain and sample rate of the inputs to the ASRC1 IN2x paths, and the outputs
from the ASRC1 IN1x paths.
Note that it is possible to select two sample rates for the ASRC that are each referenced to the same clock domain. This
provides flexibility to switch between synchronous and asynchronous use cases without changing the signal routing
configuration of the affected audio paths.
See Section 4.16 for details of the sample-rate control registers.
The ASRC supports sample rates from 8–192 kHz. The ratio of the applicable SAMPLE_RATE_n and ASYNC_SAMPLE_
RATE_n fields must not exceed 6.
The ASRC1_RATE1 and ASRC1_RATE2 fields must not be changed if any of the respective x_SRCn fields is nonzero.
The associated x_SRCn fields must be cleared before writing new values to ASRC1_RATE1 or ASRC1_RATE2. A
minimum delay of 125 s must be allowed between clearing the x_SRCn fields and writing to the associated ASRC1_
RATE1 or ASRC1_RATE2 fields. See Table 4-27 for details.
88
DS1162F1
CS42L92
4.3 Digital Core
The ASRC signal paths are enabled using the ASRC1_INnx_ENA bits, as follows:
•
The ASRC1 IN1 (left and right) paths convert from the ASRC1_RATE1 sample rate to the ASRC1_RATE2 sample
rate. These paths are enabled by setting the ASRC1_IN1L_ENA and ASRC1_IN1R_ENA bits, respectively.
•
The ASRC1 IN2 (left and right) paths convert from the ASRC1_RATE2 sample rate to the ASRC1_RATE1 sample
rate. These paths are enabled by setting the ASRC1_IN2L_ENA and ASRC1_IN2R_ENA bits, respectively.
Synchronization (lock) between different clock domains is not instantaneous when the clocking or sample rate
configurations are updated. The lock status of each ASRC path is an input to the interrupt control circuit and can be used
to trigger an interrupt event; see Section 4.15.
The ASRC lock status of each ASRC path can be output directly on a GPIO pin as an external indication of ASRC lock.
See Section 4.14 to configure a GPIO pin for this function.
The CS42L92 performs automatic checks to confirm that the SYSCLK or ASYNCCLK frequency is high enough to support
the commanded ASRC and digital mixing functions. If the frequency is too low, an attempt to enable an ASRC signal path
fails. Note that active signal paths are not affected under such circumstances.
The status bits in register R3809 indicate the status of each ASRC signal path. If an underclocked error condition occurs,
these bits indicate which ASRC signal paths have been enabled.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
The ASRC signal paths and control registers are shown in Fig. 4-32.
The ASRC provides asynchronous conversion between the SYSCLK and ASYNCCLK clock domains.
ASRC1_RATE1 selects the sample rate of the ASRC1 IN1x inputs, and the ASRC1 IN2x outputs.
ASRC1_RATE2 selects the sample rate of the ASRC1 IN2x inputs, and the ASRC1 IN1x outputs.
Each sample rate may be referenced to either the SYSCLK or ASYNCCLK clock domain..
ASRC1_RATE1
…
ASRC1IN1L_SRC
…
ASRC1IN1R_SRC
ASRC1 IN2L (0x92)
ASRC1 IN2R (0x93)
ASRC1_IN2L_ENA p. 90
ASRC1_IN2R_ENA p. 90
ASRC1_RATE2
ASRC1_IN1L_ENA p. 90
ASRC1 IN1L (0x90)
ASRC1_IN1R_ENA p. 90
ASRC1 IN1R (0x91)
…
ASRC1IN2L_SRC
…
ASRC1IN2R_SRC
x_SRCn p. 52
Figure 4-32. Asynchronous Sample-Rate Converters (ASRCs)
The ASRC1 input control fields (see Fig. 4-32) are located at register addresses R2688–R2712 (0x0A80–0x0A98).
DS1162F1
89
CS42L92
4.3 Digital Core
The full list of digital mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
The x_SRCn fields select the input sources for the ASRC paths. Note that the selected input sources must be configured
for the same sample rate as the ASRC to which they are connected.
The hexadecimal numbers in Fig. 4-32 indicate the corresponding x_SRCn setting for selection of that signal as an input
to another digital-core function.
The fields associated with the ASRC are described in Table 4-27.
Table 4-27. Digital-Core ASRC Control
Register Address
R3808 (0x0EE0)
ASRC1_ENABLE
90
Bit
3
Label
ASRC1_IN2L_
ENA
Default
0
2
ASRC1_IN2R_
ENA
0
1
ASRC1_IN1L_
ENA
0
0
ASRC1_IN1R_
ENA
0
Description
ASRC1 IN2 (left) enable
(Left channel from ASRC1_RATE2 sample rate to ASRC1_RATE1 sample rate)
0 = Disabled
1 = Enabled
ASRC1 IN2 (right) enable
(Right channel from ASRC1_RATE2 sample rate to ASRC1_RATE1 sample rate)
0 = Disabled
1 = Enabled
ASRC1 IN1 (left) enable
(Left channel from ASRC1_RATE1 sample rate to ASRC1_RATE2 sample rate)
0 = Disabled
1 = Enabled
ASRC1 IN1 (right) enable
(Right channel from ASRC1_RATE1 sample rate to ASRC1_RATE2 sample rate)
0 = Disabled
1 = Enabled
DS1162F1
CS42L92
4.3 Digital Core
Table 4-27. Digital-Core ASRC Control (Cont.)
Register Address
R3809 (0x0EE1)
ASRC1_STATUS
Bit
3
Label
ASRC1_IN2L_
ENA_STS
Default
0
2
ASRC1_IN2R_
ENA_STS
0
1
ASRC1_IN1L_
ENA_STS
0
0
ASRC1_IN1R_
ENA_STS
0
R3810 (0x0EE2)
ASRC1_RATE1
15:11 ASRC1_
RATE1[4:0]
0x00
R3811 (0x0EE3)
ASRC1_RATE2
15:11 ASRC1_
RATE2[4:0]
0x08
Description
ASRC1 IN2 (left) enable status
(Left channel from ASRC1_RATE2 sample rate to ASRC1_RATE1 sample rate)
0 = Disabled
1 = Enabled
ASRC1 IN2 (right) enable status
(Right channel from ASRC1_RATE2 sample rate to ASRC1_RATE1 sample rate)
0 = Disabled
1 = Enabled
ASRC1 IN1 (left) enable status
(Left channel from ASRC1_RATE1 sample rate to ASRC1_RATE2 sample rate)
0 = Disabled
1 = Enabled
ASRC1 IN1 (right) enable status
(Right channel from ASRC1_RATE1 sample rate to ASRC1_RATE2 sample rate)
0 = Disabled
1 = Enabled
ASRC1 Sample Rate select for ASRC1 IN1x inputs and ASRC1 IN2x outputs
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
All ASRC1_IN1x_SRC fields must be cleared before changing ASRC1_RATE1.
ASRC1 Sample Rate select for ASRC1 IN2x inputs and ASRC1 IN1x outputs
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
All ASRC1_IN1x_SRC fields must be cleared before changing ASRC1_RATE1.
4.3.16 Isochronous Sample-Rate Converter (ISRC)
The CS42L92 supports multiple signal paths through the digital core. The ISRCs provide sample-rate conversion between
synchronized sample rates on the SYSCLK clock domain, or between synchronized sample rates on the ASYNCCLK clock
domain.
There are two ISRCs on the CS42L92. Each ISRC provides two stereo signal paths between two different sample rates,
as shown in Fig. 4-33.
The sample rates associated with each ISRC can be set independently. Note that the two sample rates associated with
any single ISRC must both be referenced to the same clock domain (SYSCLK or ASYNCCLK).
•
When an ISRC is used on the SYSCLK domain, the associated sample rates may be selected from SAMPLE_
RATE_1, SAMPLE_RATE_2, or SAMPLE_RATE_3.
•
When an ISRC is used on the ASYNCCLK domain, the associated sample rates are ASYNC_SAMPLE_RATE_1
and ASYNC_SAMPLE_RATE_2.
See Section 4.16 for details of the sample-rate control registers.
Each ISRC converts between a sample rate selected by ISRCn_FSL and a sample rate selected by ISRCn_FSH, (where
n identifies the applicable ISRC 1 or 2). The higher of the two sample rates must be selected by ISRCn_FSH in each case.
DS1162F1
91
CS42L92
4.3 Digital Core
The ISRCs support sample rates in the range 8–384 kHz. For each ISRC, the ratio of the applicable SAMPLE_RATE_n
or ASYNC_SAMPLE_RATE_n fields must not exceed 24. The sample-rate conversion ratio must be an integer (1–24) or
equal to 1.5.
The ISRCn_FSL and ISRCn_FSH fields must not be changed if any of the respective x_SRCn fields is nonzero. The
associated x_SRCn fields must be cleared before writing new values to ISRCn_FSL or ISRCn_FSH. A minimum delay of
125 s must be allowed between clearing the x_SRCn fields and writing to the associated ISRCn_FSL or ISRCn_FSH
fields. See Table 4-28 for details.
The ISRC signal paths are enabled using the ISRCn_INTm_ENA and ISRCn_DECm_ENA bits, as follows:
•
The ISRCn interpolation paths (increasing sample rate) are enabled by setting the ISRCn_INTm_ENA bits, (where
m identifies the applicable channel).
•
The ISRCn decimation paths (decreasing sample rate) are enabled by setting the ISRCn_DECm_ENA bits.
The CS42L92 performs automatic checks to confirm that the SYSCLK or ASYNCCLK frequency is high enough to support
the commanded ISRC and digital mixing functions. If the frequency is too low, an attempt to enable an ISRC signal path
fails. Note that active signal paths are not affected under such circumstances.
The status bits in registers R1600–R3576 indicate the status of each digital mixer. If an underclocked error condition
occurs, these bits indicate which mixers have been enabled.
The ISRC signal paths and control registers are shown in Fig. 4-33.
ISRC provides sample-rate conversions between synchronized sample rates on the SYSCLK or ASYNCCLK
domain. Both sample rates must be referenced to the same clock domain (SYSCLK or AYSNCCLK).
ISRCn_FSL identifies the lower of the two sample rates.
ISRCn_FSH identifies the higher of the two sample rates.
ISRCn_FSL
ISRCn_FSH
…
ISRCnINT1_SRC
ISRCn_INT1_ENA
ISRC1 INT1 (0xA0)
ISRC2 INT1 (0xA8)
…
ISRCnINT2_SRC
ISRCn_INT2_ENA
ISRC1 INT2 (0xA1)
ISRC2 INT2 (0xA9)
ISRC1 DEC1 (0xA4)
ISRC2 DEC1 (0xAC)
ISRCn_DEC1_ENA
…
ISRCnDEC1_SRC
ISRC1 DEC2 (0xA5)
ISRC2 DEC2 (0xAD)
ISRCn_DEC2_ENA
…
ISRCnDEC2_SRC
CS42L92 supports two ISRC blocks, i.e., n = 1–2
Figure 4-33. Isochronous Sample-Rate Converters (ISRCs)
The ISRC input control fields (see Fig. 4-33) are located at register addresses R2816–R2920 (0x0B00–0x0B68).
The full list of digital mixer control registers (R1600–R3576) is provided in Section 6. Generic register field definitions are
provided in Table 4-11.
92
DS1162F1
CS42L92
4.3 Digital Core
The x_SRC fields select the input sources for the respective ISRC processing blocks. Note that the selected input sources
must be configured for the same sample rate as the ISRC to which they are connected.
The hexadecimal numbers in Fig. 4-33 indicate the corresponding x_SRC setting for selection of that signal as an input to
another digital-core function.
The fields associated with the ISRCs are described in Table 4-28.
Table 4-28. Digital-Core ISRC Control
Register Address Bit
Label
R3824 (0x0EF0)
15:11 ISRC1_FSH[4:0]
ISRC1_CTRL_1
R3825 (0x0EF1)
ISRC1_CTRL_2
R3826 (0x0EF2)
ISRC1_CTRL_3
R3827 (0x0EF3)
ISRC2_CTRL_1
DS1162F1
15:11 ISRC1_FSL[4:0]
15
ISRC1_INT1_ENA
14
ISRC1_INT2_ENA
9
ISRC1_DEC1_
ENA
8
ISRC1_DEC2_
ENA
15:11 ISRC2_FSH[4:0]
Default
Description
0x00 ISRC1 High Sample Rate (Sets the higher of the ISRC1 sample rates)
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
The ISRC1_FSH and ISRC1_FSL fields must both select sample rates referenced to
the same clock domain (SYSCLK or ASYNCCLK).
All ISRC1_DECn_SRC fields must be cleared before changing ISRC1_FSH.
0x00 ISRC1 Low Sample Rate (Sets the lower of the ISRC1 sample rates)
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
The ISRC1_FSH and ISRC1_FSL fields must both select sample rates referenced to
the same clock domain (SYSCLK or ASYNCCLK).
All ISRC1_INTn_SRC fields must be cleared before changing ISRC1_FSL.
0
ISRC1 INT1 Enable (Interpolation Channel 1 path from ISRC1_FSL rate to ISRC1_
FSH rate)
0 = Disabled
1 = Enabled
0
ISRC1 INT2 Enable (Interpolation Channel 2 path from ISRC1_FSL rate to ISRC1_
FSH rate)
0 = Disabled
1 = Enabled
0
ISRC1 DEC1 Enable (Decimation Channel 1 path from ISRC1_FSH rate to ISRC1_
FSL rate)
0 = Disabled
1 = Enabled
0
ISRC1 DEC2 Enable (Decimation Channel 2 path from ISRC1_FSH rate to ISRC1_
FSL rate)
0 = Disabled
1 = Enabled
0x00 ISRC2 High Sample Rate (Sets the higher of the ISRC2 sample rates)
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
The ISRC2_FSH and ISRC2_FSL fields must both select sample rates referenced to
the same clock domain (SYSCLK or ASYNCCLK).
All ISRC2_DECn_SRC fields must be cleared before changing ISRC2_FSH.
93
CS42L92
4.4 DSP Firmware Control
Table 4-28. Digital-Core ISRC Control (Cont.)
Register Address Bit
Label
R3828 (0x0EF4)
15:11 ISRC2_FSL[4:0]
ISRC2_CTRL_2
R3829 (0x0EF5)
ISRC2_CTRL_3
15
ISRC2_INT1_ENA
14
ISRC2_INT2_ENA
9
ISRC2_DEC1_
ENA
8
ISRC2_DEC2_
ENA
Default
Description
0x00 ISRC2 Low Sample Rate (Sets the lower of the ISRC2 sample rates)
0x00 = SAMPLE_RATE_1
0x01 = SAMPLE_RATE_2
0x02 = SAMPLE_RATE_3
0x08 = ASYNC_SAMPLE_RATE_1
0x09 = ASYNC_SAMPLE_RATE_2
All other codes are reserved.
The selected sample rate is valid in the range 8–192 kHz.
The ISRC2_FSH and ISRC2_FSL fields must both select sample rates referenced to
the same clock domain (SYSCLK or ASYNCCLK).
All ISRC2_INTn_SRC fields must be cleared before changing ISRC2_FSL.
0
ISRC2 INT1 Enable (Interpolation Channel 1 path from ISRC2_FSL rate to ISRC2_
FSH rate)
0 = Disabled
1 = Enabled
0
ISRC2 INT2 Enable (Interpolation Channel 2 path from ISRC2_FSL rate to ISRC2_
FSH rate)
0 = Disabled
1 = Enabled
0
ISRC2 DEC1 Enable (Decimation Channel 1 path from ISRC2_FSH rate to ISRC2_
FSL rate)
0 = Disabled
1 = Enabled
0
ISRC2 DEC2 Enable (Decimation Channel 2 path from ISRC2_FSH rate to ISRC2_
FSL rate)
0 = Disabled
1 = Enabled
4.4 DSP Firmware Control
The CS42L92 digital core incorporates one programmable DSP processing block, capable of running a range of
application-specific algorithms. Different firmware configurations can be loaded onto the DSP, enabling the CS42L92 to
be customized for specific application requirements. Full read/write access to the device register map is supported from
the DSP core.
The DSP can be clocked at up to 75 MHz, corresponding to 75 MIPS. A software programming guide can be provided to
assist users in developing their own software algorithms—please contact your Cirrus Logic representative for further
information.
To use the programmable DSP, the required firmware configuration must first be loaded onto the device by writing the
appropriate files to the CS42L92 register map. The firmware configuration comprises program, data, and coefficient
content.
Details of the DSP firmware memory registers are provided in Section 4.4.1. Note that the WISCE evaluation board control
software provides support for easy loading of program, data, and coefficient content onto the CS42L92. Please contact
your Cirrus Logic representative for more details of the WISCE evaluation board control software.
After loading the DSP firmware, the DSP functions must be enabled using the associated control fields.
The audio signal paths to and from the DSP processing block are configured as described in Section 4.3. Note that the
DSP firmware must be loaded and enabled before audio signal paths can be enabled.
4.4.1
DSP Firmware Memory and Register Mapping
The DSP firmware memory is programmed by writing to the registers referenced in Table 4-29. Note that clocking is not
required for access to the firmware registers by the host processor.
94
DS1162F1
CS42L92
4.4 DSP Firmware Control
The CS42L92 program, data, and coefficient register memory space is described in Table 4-29. The full register map
listing is provided in Section 6.
The program firmware parameters are formatted as 40-bit words. For this reason, 3 x 32-bit register addresses are
required for every 2 x 40-bit words.
Table 4-29. DSP Program, Data, and Coefficient Registers
DSP Number
Description
DSP1
Program memory
X-Data memory
Y-Data memory
Coefficient memory
Register Address
0x08_0000–0x08_2FFE
0x0A_0000–0x0A_1FFE
0x0C_0000–0x0C_1FFE
0x0E_0000–0x0E_1FFE
Number of Registers
6144
4096
4096
4096
DSP Memory Size
4k x 40-bit words
4k x 24-bit words
4k x 24-bit words
4k x 24-bit words
The X-memory on the DSP supports read/write access to all register fields throughout the device, including the codec
control registers, and the other firmware-memory regions of DSP core itself. Access to the register address space is
supported using a number of register windows within the X-memory on the DSP.
Note that the register window space is additional to the X-data memory size described in Table 4-29.
Addresses 0xC000 to 0xDFFF in X-memory map directly to addresses 0x0000 to 0x1FFF in the device register space.
This fixed register window contains primarily the codec control registers; it also includes the virtual DSP control registers
(described in Section 4.4.7). Each X-memory address within this window maps onto one 16-bit register in the codec
memory space.
Four movable register windows are also provided, starting at X-memory addresses 0xF000, 0xF400, 0xF800, and 0xFC00
respectively. Each window represents 1024 addresses in the X-memory space. The start address, within the
corresponding device register space, for each window is configured using DSP1_EXT_[A/B/C/D]_PAGE (where A defines
the first window, B defines the second window, etc.).
Two mapping modes are supported and are selected using the DSP1_EXT_[A/B/C/D]_PSIZE16 bits for the respective
window. In 16-Bit Mode, each address within the window maps onto one 16-bit register in the device memory space; the
window equates to 1024 x 16-bit registers. In 32-Bit Mode, each address within the window maps onto two 16-bit registers
in the device memory space; the window equates to 1024 x 32-bit registers.
Note that the X-memory is only 24-bits wide; as a result, the upper 8 bits of the odd-numbered register addresses are not
mapped, and cannot be accessed, in 32-Bit Mode.
The DSP1_EXT_[A/B/C/D]_PAGE fields are defined with an LSB = 512. Accordingly, the base address of each window
must be aligned with 512-word boundaries. Note that the base addresses are entirely independent of each other; for
example, overlapping windows are permissible if required, and there is no requirement for the A/B/C/D windows to be at
incremental locations.
The register map window functions are shown in Fig. 4-34. Further information on the definition and usage of the DSP
firmware memories is provided in the software programming guide; contact your Cirrus Logic representative if required.
DS1162F1
95
CS42L92
Page D Base Address
0xFFFF
Register
Window D
Page C Base Address
0xFC00
0xF800
0xF400
Register
Window C
Register
Window B
Page B Base Address
Register
Window A
0xF000
Internal DSP Control
Page A Base Address
0xE000
Write Sequencer, DSP Peripherals, and DSP Firmware Address Space
4.4 DSP Firmware Control
Moveable
Register
Window D
Moveable
Register
Window C
Moveable
Register
Window B
Moveable
Register
Window A
Virtual DSP Ctrl
0x3000
0xD000
16-bits
0x2000
0xC000
CODEC Register
Address Space
X Data Memory
(shared DSP2/DSP3)
X Data Memory
0x0000
24-bits
DSP X-Memory Map
0x0000
Fixed codec
Register Window
16-bits
Audio Hub Register Map
Figure 4-34. X-Data Memory Map
Note that the full CS42L92 register space is shown here as 16-bit width. (SPI/I2C register access uses 32-bit data width
at 0x3000 and above.) However, the window base address fields (DSP1_EXT_[A/B/C/D]_PAGE) are referenced to 16-bit
width, and 16-bit register mapping is shown. Hence, the device register map is shown here entirely as 16-bit width for ease
of explanation.
The control registers associated with the register map window functions are described in Table 4-30.
96
DS1162F1
CS42L92
4.4 DSP Firmware Control
Table 4-30. X-Data Memory and Clocking Control
Register Address
R1048148 (0xF_FE54)
DSP1_Ext_window_A
Bit
31
Label
DSP1_EXT_A_PSIZE16
15:0 DSP1_EXT_A_PAGE[15:0]
R1048150 (0xF_FE56)
DSP1_Ext_window_B
31
DSP1_EXT_B_PSIZE16
15:0 DSP1_EXT_B_PAGE[15:0]
R1048152 (0xF_FE58)
DSP1_Ext_window_C
31
DSP1_EXT_C_PSIZE16
15:0 DSP1_EXT_C_PAGE[15:0]
R1048154 (0xF_FE5A)
DSP1_Ext_window_D
31
DSP1_EXT_D_PSIZE16
15:0 DSP1_EXT_D_PAGE[15:0]
4.4.2
Default
Description
0
Register Window A page width select
0 = 32-bit
1 = 16-bit
Note that, in 32-Bit Mode, only the lower 24 bits can be accessed.
0x0000 Sets the Base Address of Register Window A in X-memory.
Coded as LSB = 512 (0x200)
0
Register Window B page width select
0 = 32-bit
1 = 16-bit
Note that, in 32-Bit Mode, only the lower 24 bits can be accessed.
0x0000 Sets the Base Address of Register Window B in X-memory.
Coded as LSB = 512 (0x200)
0
Register Window C page width select
0 = 32-bit
1 = 16-bit
Note that, in 32-Bit Mode, only the lower 24 bits can be accessed.
0x0000 Sets the Base Address of Register Window C in X-memory.
Coded as LSB = 512 (0x200)
0
Register Window D page width select
0 = 32-bit
1 = 16-bit
Note that, in 32-Bit Mode, only the lower 24 bits can be accessed.
0x0000 Sets the Base Address of Register Window D in X-memory.
Coded as LSB = 512 (0x200)
DSP Memory Locking
The DSP core has the capability for read/write access to all register fields throughout the device, including the codec
control registers, DSP peripheral control registers, and the virtual DSP control registers. Access to these registers is
supported via the DSP’s X-memory (using the register windows), as described in Section 4.4.1.
The CS42L92 provides a register-locking feature that blocks DSP register-write attempts to invalid register regions,
preventing the firmware from making unintentional changes to register and memory contents. An interrupt event and
associated debug information are generated if any write-access attempt is blocked; this can be used to assist software
development and debug.
The register map and DSP firmware memories are partitioned into four regions; each region can be locked independently.
This allows full flexibility to lock different register/memory regions according to the applicable DSP firmware configuration.
The DSP has direct access to its own X-, Y-, Z-, and P- memories; this is always enabled and cannot be locked. Access
to the codec registers, DSP peripheral registers, and the virtual DSP registers is effected using the X-memory register
windows (fixed codec window, and four configurable windows)—write access to these locations is governed by the
register-locking configuration settings.
The virtual DSP registers occupy addresses within the codec register space; these registers represent one of the lockable
regions within the register map—two independent locks are provided for the codec and virtual DSP registers.
Note:
A DSP register window can be mapped onto the X-, Y-, Z-, or P- memory region of the DSP. In this event, write
access via that window is governed by the register locks, potentially blocking the DSP from accessing its own
memory. This is not the intended use of the register lock, however.
The lockable register/memory regions are defined in Table 4-31.
DS1162F1
97
CS42L92
4.4 DSP Firmware Control
Table 4-31. DSP Memory Locking Regions
Region
Region 0
Region 1
Region 2
Region 3
Description
Virtual DSP registers
Codec registers
DSP peripheral control registers
DSP1 memory
Register Address
0x00_1000–0x00_2FFF
0x00_0000–0x03_FFFE
0x04_0000–0x07_FFFE
0x08_0000–0x09_FFFE
Notes
Excludes memory lock and watchdog reset registers
Excludes virtual DSP registers
—
—
The register locks are controlled using the DSP1_CTRL_REGIONm_LOCK fields (where m identifies the register/memory
region). The associated lock determines whether the DSP core is granted write access to region m. To change the lock
status, two writes must be made to the respective register field:
•
Writing 0x5555, followed by 0xAAAA, sets the respective lock
•
Writing 0xCCCC, followed by 0x3333, clears the respective lock
The status of each lock can be read from the DSP1_CTRL_REGIONm_LOCK_STS bits.
Write access to the DSP1_CTRL_REGIONm_LOCK fields is always possible. This means that the DSP core always has
write access for configuring the memory-access locks.
The DSP memory locking function is an input to the interrupt control circuit and can be used to trigger an interrupt event
if an invalid register write is attempted—see Section 4.4.5. Additional status and control fields are provided for debug
purposes, as described in Section 4.4.6.
The control registers associated with the DSP memory locking functions are described in Table 4-32.
Table 4-32. DSP Memory Locking Control
Register Address
R1048164 (0xF_FE64)
DSP1_Region_lock_sts_0
R1048166 (0xF_FE66)
DSP1_Region_lock_1___
DSP1_Region_lock_0
R1048168 (0xF_FE68)
DSP1_Region_lock_3___
DSP1_Region_lock_2
Bit
3
2
1
0
31:16
Label
DSP1_CTRL_REGION3_LOCK_STS
DSP1_CTRL_REGION2_LOCK_STS
DSP1_CTRL_REGION1_LOCK_STS
DSP1_CTRL_REGION0_LOCK_STS
DSP1_CTRL_REGION1_LOCK[15:0]
15:0 DSP1_CTRL_REGION0_LOCK[15:0]
31:16 DSP1_CTRL_REGION3_LOCK[15:0]
15:0 DSP1_CTRL_REGION2_LOCK[15:0]
Default
0
0
0
0
See
Footnote 1
See
Footnote 1
See
Footnote 1
See
Footnote 1
Description
DSP1 memory region m lock status
0 = Unlocked
1 = Locked (write access is blocked)
DSP1 memory region m lock.
Write 0x5555, then 0xAAAA, to set the lock.
Write 0xCCCC, then 0x3333, to clear the lock.
1. Default is not applicable to these write-only fields
4.4.3
DSP Firmware Control
The configuration and control of the DSP firmware is described in the following subsections.
4.4.3.1
DSP Memory
The DSP memory (program, X-data, Y-data, and coefficient) is enabled by setting DSP1_MEM_ENA. This memory must
be enabled (DSP1_MEM_ENA = 1) for read/write access, code execution, and DMA functions. The DSP memory is
disabled, and the contents lost, whenever the DSP1_MEM_ENA bit is cleared.
The DSP1_RAM_RDY status bit indicates whether the DSP memory is ready for read/write access. The DSP memory
should not be accessed until this bit has been set.
The DSP1_MEM_ENA bit is not affected by software reset; it remains in its previous state under software reset conditions.
Accordingly, the DSP memory contents are maintained through software reset, provided DCVDD is held above its reset
threshold.
The DSP firmware memory is always cleared under power-on reset, hardware reset, and Sleep Mode conditions. See
Section 5.2 for a summary of the CS42L92 reset behavior.
98
DS1162F1
CS42L92
4.4 DSP Firmware Control
4.4.3.2
DSP Clocking
Clocking is required for the DSP processing block, when executing software or when supporting DMA functions. (Note that
clocking is not required for access to the firmware registers by the host processor.) Clocking within the DSP is enabled
and disabled automatically, as required by the DSP core and DMA channel status.
The clock source for each DSP is derived from DSPCLK. See Section 4.16 for details of how to configure DSPCLK.
The clock frequency for the DSP is selected using DSP1_CLK_FREQ_SEL. The DSP clock frequency must be less than
or equal to the DSPCLK frequency.
The DSP1_CLK_FREQ_STS field indicates the clock frequency for the DSP core. This can be used to confirm the clock
frequency, in cases where code execution has a minimum clock frequency requirement. The DSP1_CLK_FREQ_STS
field is only valid when the core is running code; typical usage of this field would be for the DSP core itself to read the clock
status and to take action as applicable, in particular, if the available clock does not meet the application requirements.
Note that, depending on the DSPCLK frequency and the available clock dividers, the DSP1 clock frequency may differ
from the selected clock. In most cases, the DSP1 clock frequency equals or exceeds the requested frequency. A lower
frequency is implemented if limited by either the DSPCLK frequency or the maximum DSP1 clocking frequency.
The DSPCLK configuration provides input to the interrupt control circuit and can be used to trigger an interrupt event when
the DSP1 clock frequency is less than the requested frequency; see Section 4.15.
4.4.3.3
DSP Code Execution
After the DSP firmware has been loaded, and the clocks configured, the DSP block is enabled by setting DSP1_CORE_
ENA. When the DSP is configured and enabled, the firmware execution can be started by writing 1 to DSP1_START.
Alternative methods to trigger the firmware execution can also be configured using the DSP1_START_IN_SEL field.
Using the DSP1_START_IN_SEL field, the DSP firmware execution can be linked to the respective DMA function, the
IRQ2 status, or to the FIFO status in the event logger:
•
DMA function: firmware execution commences when all enabled DSP input (WDMA) channel buffers have been
filled, and all enabled DSP output (RDMA) channel buffers have been emptied
•
IRQ2: firmware execution commences when one or more of the unmasked IRQ2 events has occurred
•
Event logger status: firmware execution commences when the FIFO not-empty status is asserted within the event
logger
To enable firmware execution on the DSP block, the DSP1_CORE_ENA bit must be set. Note that the usage of the DSP1_
START bit may vary depending on the particular firmware that is being executed: in some applications (e.g., when an
alternative trigger is selected using DSP1_START_IN_SEL), writing to the DSP1_START bit is not required.
4.4.3.4
DSP Watchdog Timer
A watchdog timer is provided for the DSP, which can be used to detect software lock-ups, and other conditions that require
corrective action in order to resume the intended DSP behavior.
The DSP1 watchdog is enabled using DSP1_WDT_ENA. The timeout period is configured using DSP1_WDT_MAX_
COUNT.
In normal operation, the watchdog should be reset regularly—this action is used to confirm that the DSP code is running
correctly. The watchdog is reset by writing 0x5555, followed by 0xAAAA, to the DSP1_WDT_RESET field.
The watchdog status bit, DSP1_WDT_TIMEOUT_STS, is set if the timeout period elapses before the watchdog is reset;
this event typically signals that a lock-up or other error condition has occurred.
The DSP watchdog is an input to the interrupt control circuit and can be used to trigger an interrupt event if the timeout
period elapses—see Section 4.4.5.
Note that write access to the DSP1_WDT_RESET field is not affected by the register locking mechanism (see
Section 4.4.2). This means that the DSP core always has write access to reset the watchdog.
DS1162F1
99
CS42L92
4.4 DSP Firmware Control
4.4.3.5
DSP Control Registers
The DSP memory, clocking, code-execution, and watchdog control registers are described in Table 4-33.
The audio signal paths connecting to/from the DSP processing block are configured as described in Section 4.3. Note that
the DSP firmware must be loaded and enabled before audio signal paths can be enabled.
Table 4-33. DSP Control Registers
Register Address
R1048064 (0xF_
FE00)
Bit
4
Label
DSP1_MEM_ENA
1
DSP1_CORE_ENA
0
DSP1_START
DSP1_Config_1
R1048066 (0xF_
FE02)
DSP1_Config_2
R1048070 (0xF_
FE06)
DSP1_Status_2
R1048072 (0xF_
FE08)
DSP1_Status_3
R1048074 (0xF_
FE0A)
DSP1_Watchdog_1
15:0 DSP1_CLK_FREQ_
SEL[15:0]
0
DSP1_CLK_AVAIL
15:0 DSP1_CLK_FREQ_
STS[15:0]
4:1
DSP1_WDT_MAX_
COUNT[3:0]
0
DSP1_WDT_ENA
R1048120 (0xF_
FE38)
DSP1_External_Start
4:0
DSP1_START_IN_
SEL[4:0]
R1048158 (0xF_
FE5E)
DSP1_Watchdog_2
R1048186 (0xF_
FE7A)
DSP1_Region_lock_
ctrl_0
15:0 DSP1_WDT_
RESET[15:0]
4.4.4
13
DSP1_WDT_
TIMEOUT_STS
Default
Description
0
DSP1 memory control
0 = Disabled
1 = Enabled
The DSP1 memory contents are lost when DSP1_MEM_ENA =0. Note that
this bit is not affected by software reset; it remains in its previous condition.
0
DSP1 enable. Controls the DSP1 firmware execution
0 = Disabled
1 = Enabled
—
DSP1 start
Write 1 to start DSP1 firmware execution
0x0000 DSP1 clock frequency select
Coded as LSB = 1/64 MHz, Valid from 5.6 to 75 MHz.
The DSP1 clock must be less than or equal to the DSPCLK frequency. The
DSP1 clock is generated by division of DSPCLK, and may differ from the
selected frequency. The DSP1 clock frequency can be read from DSP1_
CLK_FREQ_STS.
0
DSP1 clock availability (read only)
0 = No Clock
1 = Clock Available
This bit exists for legacy software support only; it is not recommended for
future designs—it may be unreliable on the latest device architectures.
0x0000 DSP1 clock frequency (read only). Valid only when the respective DSP core
is enabled.
Coded as LSB = 1/64 MHz.
0x0
DSP1 watchdog timeout value.
0xA = 2 s
0x5 = 64 ms
0x0 = 2 ms
0xB = 4 s
0x6 = 128 ms
0x1 = 4 ms
0xC = 8 s
0x7 = 256 ms
0x2 = 8 ms
0xD–0xF = reserved
0x8 = 512 ms
0x3 = 16 ms
0x9 = 1 s
0x4 = 32 ms
0
DSP1 watchdog enable
0 = Disabled
1 = Enabled
0x00
DSP1 firmware execution control. Selects the trigger for DSP1 firmware
execution.
0x00 = DMA
0x0B = IRQ2
0x10 = Event Logger 1
All other codes are reserved.
Note that the DSP1_START bit also starts the DSP1 firmware execution,
regardless of this field setting.
0x0000 DSP1 watchdog reset.
Write 0x5555, followed by 0xAAAA, to reset the watchdog.
0
DSP1 watchdog timeout status
This bit, when set, indicates that the watchdog timeout has occurred. This bit
is latched when set; it is cleared when the watchdog is disabled or reset.
DSP Direct Memory Access (DMA) Control
The DSP provides a multichannel DMA function; this is configured using the registers described in Table 4-34.
100
DS1162F1
CS42L92
4.4 DSP Firmware Control
There are eight WDMA (DSP input) and six RDMA (DSP output) channels; these are enabled using the DSP1_WDMA_
CHANNEL_ENABLE and DSP1_RDMA_CHANNEL_ENABLE fields. The status of each WDMA channel is indicated in
DSP1_WDMA_ACTIVE_CHANNELS.
The DMA can access the X-data memory or Y-data memory associated with the DSP block. The applicable memory is
selected using bit [15] of the respective x_START_ADDRESS field for each DMA channel.
The start address of each DMA channel is configured as described in Table 4-34. Note that the required address is defined
relative to the base address of the selected (X-data or Y-data) memory.
The buffer length of the DMA channels is configured using the DSP1_DMA_BUFFER_LENGTH field. The selected buffer
length applies to all enabled DMA channels.
Note that the start-address fields and buffer-length fields are defined in 24-bit DSP data word units. This means that the
LSB of these fields represents one 24-bit DSP memory word. This differs from the CS42L92 register map layout described
in Table 4-29.
The parameters of a DMA channel (i.e., start address or offset address) must not be changed while the respective DMA
is enabled. All of the DMA channels must be disabled before changing the DMA buffer length.
Each DMA channel uses a twin buffer mechanism to support uninterrupted data flow through the DSP. The buffers are
called ping and pong, and are of configurable size, as noted above. Data is transferred to/from each of the buffers in turn.
When the ping input data buffer is full, the DSP1_PING_FULL bit is set, and a DSP start signal is generated. The start
signal from the DMA is typically used to start firmware execution, as noted in Table 4-33. Meanwhile, further DSP input
data fills up the pong buffer.
When the pong input buffer is full, the DSP1_PONG_FULL bit is set, and another DSP start signal is generated. The DSP
firmware must take care to read the input data from the applicable buffer, in accordance with the DSP1_PING_FULL and
DSP1_PONG_FULL status bits.
Twin buffers are also used on the DSP output (RDMA) channels. The output ping buffers are emptied at the same time as
the input ping buffers are filled; the output pong buffers are emptied at the same time that the input pong buffers are filled.
The DSP core supports 24-bit signal processing. Under default conditions, the DSP audio data is in 2’s complement Q3.20
format (i.e., 0xF00000 corresponds to the –1.0 level, and 0x100000 corresponds to the +1.0 level; a sine wave with peak
values of ±1.0 corresponds to the 0 dBFS level). If DSP1_DMA_WORD_SEL is set, audio data is transferred to and from
the DSP in Q0.23 format. The applicable format should be set according to the requirements of the specific DSP firmware.
Note that the DSP core is optimized for Q3.20 audio data processing; Q0.23 data can be supported, but the firmware
implementation may incur a reduction in power efficiency due to the higher MIPS required for arithmetic operations in
non-native data word format.
The DMA function is an input to the interrupt control circuit—see Section 4.4.5. The respective interrupt event is triggered
if all enabled input (WDMA) channel buffers have been filled and all enabled output (RDMA) channel buffers have been
emptied.
Further details of the DMA are provided in the software programming guide; contact your Cirrus Logic representative if
required.
DS1162F1
101
CS42L92
4.4 DSP Firmware Control
Table 4-34. DMA Control
Register Address
R1048068 (0xF_FE04)
DSP1_Status_1
Bit
31
Label
DSP1_PING_FULL
Default
0
30
DSP1_PONG_FULL
0
23:16 DSP1_WDMA_ACTIVE_
CHANNELS[7:0]
0x00
R1048080 (0xF_FE10) 31:16 DSP1_START_ADDRESS_
WDMA_BUFFER_1[15:0]
DSP1_WDMA_Buffer_1
0x0000
15:0 DSP1_START_ADDRESS_
WDMA_BUFFER_0[15:0]
0x0000
R1048082 (0xF_FE12) 31:16 DSP1_START_ADDRESS_
WDMA_BUFFER_3[15:0]
DSP1_WDMA_Buffer_2
15:0 DSP1_START_ADDRESS_
WDMA_BUFFER_2[15:0]
0x0000
R1048084 (0xF_FE14) 31:16 DSP1_START_ADDRESS_
WDMA_BUFFER_5[15:0]
DSP1_WDMA_Buffer_3
15:0 DSP1_START_ADDRESS_
WDMA_BUFFER_4[15:0]
0x0000
R1048086 (0xF_FE16) 31:16 DSP1_START_ADDRESS_
WDMA_BUFFER_7[15:0]
DSP1_WDMA_Buffer_4
15:0 DSP1_START_ADDRESS_
WDMA_BUFFER_6[15:0]
0x0000
R1048096 (0xF_FE20)
DSP1_RDMA_Buffer_1
31:16 DSP1_START_ADDRESS_
RDMA_BUFFER_1[15:0]
0x0000
15:0 DSP1_START_ADDRESS_
RDMA_BUFFER_0[15:0]
0x0000
31:16 DSP1_START_ADDRESS_
RDMA_BUFFER_3[15:0]
0x0000
15:0 DSP1_START_ADDRESS_
RDMA_BUFFER_2[15:0]
0x0000
31:16 DSP1_START_ADDRESS_
RDMA_BUFFER_5[15:0]
0x0000
15:0 DSP1_START_ADDRESS_
RDMA_BUFFER_4[15:0]
0x0000
R1048098 (0xF_FE22)
DSP1_RDMA_Buffer_2
R1048100 (0xF_FE24)
DSP1_RDMA_Buffer_3
102
0x0000
0x0000
0x0000
Description
DSP1 WDMA Ping Buffer Status
0 = Not Full
1 = Full
DSP1 WDMA Pong Buffer Status
0 = Not Full
1 = Full
DSP1 WDMA Channel Status
There are eight WDMA channels; each bit of this field indicates
the status of the respective WDMA channel.
Each bit is coded as follows:
0 = Inactive
1 = Active
DSP1 WDMA Channel 1 Start Address
Bit [15] = Memory select
0 = X-data memory
1 = Y-data memory
Bits [14:0] = Address select
The address is defined relative to the base address of the
applicable data memory. The LSB represents one 24-bit DSP
memory word.
Note that the start address is also controlled by the respective
DSP1_WDMA_CHANNEL_OFFSET bit.
DSP1 WDMA Channel 0 Start Address
Field description is as above.
DSP1 WDMA Channel 3 Start Address
Field description is as above.
DSP1 WDMA Channel 2 Start Address
Field description is as above.
DSP1 WDMA Channel 5 Start Address
Field description is as above.
DSP1 WDMA Channel 4 Start Address
Field description is as above.
DSP1 WDMA Channel 7 Start Address
Field description is as above.
DSP1 WDMA Channel 6 Start Address
Field description is as above.
DSP1 RDMA Channel 1 Start Address
Bit [15] = Memory select
0 = X-data memory
1 = Y-data memory
Bits [14:0] = Address select
The address is defined relative to the base address of the
applicable data memory. The LSB represents one 24-bit DSP
memory word.
Note that the start address is also controlled by the respective
DSP1_RDMA_CHANNEL_OFFSET bit.
DSP1 RDMA Channel 0 Start Address
Field description is as above.
DSP1 RDMA Channel 3 Start Address
Field description is as above.
DSP1 RDMA Channel 2 Start Address
Field description is as above.
DSP1 RDMA Channel 5 Start Address
Field description is as above.
DSP1 RDMA Channel 4 Start Address
Field description is as above.
DS1162F1
CS42L92
4.4 DSP Firmware Control
Table 4-34. DMA Control (Cont.)
Register Address
R1048112 (0xF_FE30)
DSP1_DMA_Config_1
Bit
Label
23:16 DSP1_WDMA_CHANNEL_
ENABLE[7:0]
Default
0x00
13:0 DSP1_DMA_BUFFER_
LENGTH[13:0]
0x0000
R1048114 (0xF_FE32)
DSP1_DMA_Config_2
R1048116 (0xF_FE34)
DSP1_DMA_Config_3
7:0
DSP1_WDMA_CHANNEL_
OFFSET[7:0]
0x00
21:16 DSP1_RDMA_CHANNEL_
OFFSET[5:0]
0x00
R1048118 (0xF_FE36)
DSP1_DMA_Config_4
4.4.5
5:0
DSP1_RDMA_CHANNEL_
ENABLE[5:0]
0x00
0
DSP1_DMA_WORD_SEL
0
Description
DSP1 WDMA Channel Enable
There are eight WDMA channels; each bit of this field enables
the respective WDMA channel.
Each bit is coded as follows:
0 = Disabled
1 = Enabled
DSP1 DMA Buffer Length
Selects the amount of data transferred in each DMA channel.
The LSB represents one 24-bit DSP memory word.
DSP1 WDMA Channel Offset
There are eight WDMA channels; each bit of this field offsets the
start Address of the respective WDMA channel.
Each bit is coded as follows:
0 = No offset
1 = Offset by 0x8000
DSP1 RDMA Channel Offset
There are six RDMA channels; each bit of this field offsets the
start Address of the respective RDMA channel.
Each bit is coded as follows:
0 = No offset
1 = Offset by 0x8000
DSP1 RDMA Channel Enable
There are six RDMA channels; each bit of this field enables the
respective RDMA channel.
Each bit is coded as follows:
0 = Disabled
1 = Enabled
DSP1 Data Word Format
0 = Q3.20 format (4 integer bits, 20 fractional bits)
1 = Q0.23 format (1 integer bit, 23 fractional bits)
The data word format should be set according to the
requirements of the applicable DSP firmware.
DSP Interrupts
The DSP core provides inputs to the interrupt circuit and can be used to trigger an interrupt event when the associated
conditions occur. The following interrupts are provided for DSP core:
•
DMA interrupt—Asserted when all enabled DSP input (WDMA) channel buffers have been filled, and all enabled
DSP output (RDMA) channel buffers have been emptied
•
DSP Start 1, DSP Start 2 interrupts—Asserted when the respective start signal is triggered
•
DSP Busy interrupt—Asserted when the DSP is busy (i.e., when firmware execution or DMA processes are started)
•
DSP Bus Error interrupt—Asserted when a locked register address, invalid memory address, or watchdog timeout
error is detected
The CS42L92 also provides 16 control bits that allow the DSP core to generate programmable interrupt events. When a
1 is written to these bits (see Table 4-35), the respective DSP interrupt (DSP_IRQn_EINTx) is triggered. The associated
interrupt bits are latched once set; they can be polled at any time or used to control the IRQ signal.
See Section 4.15 for further details.
Table 4-35. DSP Interrupts
Register Address
R5632 (0x1600)
ADSP2_IRQ0
R5633 (0x1601)
ADSP2_IRQ1
DS1162F1
Bit
1
0
1
0
Label
DSP_IRQ2
DSP_IRQ1
DSP_IRQ4
DSP_IRQ3
Default
0
0
0
0
Description
DSP IRQ2. Write 1 to trigger the DSP_IRQ2_EINTn interrupt.
DSP IRQ1. Write 1 to trigger the DSP_IRQ1_EINTn interrupt.
DSP IRQ4. Write 1 to trigger the DSP_IRQ4_EINTn interrupt.
DSP IRQ3. Write 1 to trigger the DSP_IRQ3_EINTn interrupt.
103
CS42L92
4.4 DSP Firmware Control
Table 4-35. DSP Interrupts (Cont.)
Register Address
R5634 (0x1602)
ADSP2_IRQ2
R5635 (0x1603)
ADSP2_IRQ3
R5636 (0x1604)
ADSP2_IRQ4
R5637 (0x1605)
ADSP2_IRQ5
R5638 (0x1606)
ADSP2_IRQ6
R5639 (0x1607)
ADSP2_IRQ7
4.4.6
Bit
1
0
1
0
1
0
1
0
1
0
1
0
Label
DSP_IRQ6
DSP_IRQ5
DSP_IRQ8
DSP_IRQ7
DSP_IRQ10
DSP_IRQ9
DSP_IRQ12
DSP_IRQ11
DSP_IRQ14
DSP_IRQ13
DSP_IRQ16
DSP_IRQ15
Default
0
0
0
0
0
0
0
0
0
0
0
0
Description
DSP IRQ6. Write 1 to trigger the DSP_IRQ6_EINTn interrupt.
DSP IRQ5. Write 1 to trigger the DSP_IRQ5_EINTn interrupt.
DSP IRQ8. Write 1 to trigger the DSP_IRQ8_EINTn interrupt.
DSP IRQ7. Write 1 to trigger the DSP_IRQ7_EINTn interrupt.
DSP IRQ10. Write 1 to trigger the DSP_IRQ10_EINTn interrupt.
DSP IRQ9. Write 1 to trigger the DSP_IRQ9_EINTn interrupt.
DSP IRQ12. Write 1 to trigger the DSP_IRQ12_EINTn interrupt.
DSP IRQ11. Write 1 to trigger the DSP_IRQ11_EINTn interrupt.
DSP IRQ14. Write 1 to trigger the DSP_IRQ14_EINTn interrupt.
DSP IRQ13. Write 1 to trigger the DSP_IRQ13_EINTn interrupt.
DSP IRQ16. Write 1 to trigger the DSP_IRQ16_EINTn interrupt.
DSP IRQ15. Write 1 to trigger the DSP_IRQ15_EINTn interrupt.
DSP Debug Support
General-purpose registers are provided for the DSP. These have no assigned function and can be used to assist in
algorithm development.
The JTAG interface provides test and debug access to the CS42L92, as described in Section 4.20. The JTAG interface
clock can be enabled for the DSP core using DSP1_DBG_CLK_ENA. Note that, when the JTAG interface is used to
access the DSP core, the DSP1_CORE_ENA bit must also be set.
The DSP1_LOCK_ERR_STS bit indicates that the DSP attempted to write to a locked register address. The DSP1_
ADDR_ERR_STS bit indicates that the DSP attempted to access an invalid memory address (i.e., an address whose
contents are undefined). Once set, these bits remain set until a 1 is written to DSP1_ERR_CLEAR.
The DSP1_PMEM_ERR_ADDR and DSP1_XMEM_ERR_ADDR fields contain the program memory and X-data memory
addresses associated with a locked register address error condition. If DSP1_LOCK_ERR_STS is set, these fields
correspond to the first-detected locked register address error. Note that no subsequent error event can be reported in
these fields until the DSP1_LOCK_ERR_STS is cleared.
Note:
The DSP1_PMEM_ERR_ADDR value is the prefetched address of a code instruction that has not yet been
executed; it does not point directly to the instruction that caused the error.
The DSP1_BUS_ERR_ADDR field indicates the register/memory address that resulted in a register-access error. The
field relates either to a locked register address error or to an invalid memory address error, as follows:
•
If DSP1_LOCK_ERR_STS is set, the DSP1_BUS_ERR_ADDR value corresponds to the first-detected locked
register address error. Note that no subsequent error event can be reported in this field until DSP1_LOCK_ERR_
STS is cleared.
•
If DSP1_ADDR_ERR_STS is set, and DSP1_LOCK_ERR_STS is clear, the DSP1_BUS_ERR_ADDR field
corresponds to the most recent invalid memory address error.
•
If the DSP1_LOCK_ERR_STS and DSP1_ADDR_ERR_STS are both clear, the DSP1_BUS_ERR_ADDR field is
undefined.
Note:
The DSP1_BUS_ERR_ADDR value is coded using a byte-referenced address, so the actual register address is
equal to DSP1_BUS_ERR_ADDR / 2. If the register-access error is the result of an attempt to access the virtual
DSP registers, a register address of 0 is reported.
If the DSP1_ERR_PAUSE bit is set, the DSP code execution stops immediately on detection of a locked register address
error. This enables debug information to be retrieved from the DSP core during code development. In this event, code
execution can be restarted by clearing the DSP1_ERR_PAUSE bit. Alternatively, the DSP core can restarted by clearing
and setting DSP1_CORE_ENA (described in Section 4.4.3.3).
104
DS1162F1
CS42L92
4.4 DSP Firmware Control
Table 4-36. DSP Debug Support
Register Address
R1048064 (0xF_FE00)
DSP1_Config_1
Description
DSP1 Debug Clock Enable
0 = Disabled
1 = Enabled
R1048128 (0xF_FE40)
31:16 DSP1_SCRATCH_1[15:0]
0x0000 DSP1 Scratch Register 1
DSP1_Scratch_1
15:0 DSP1_SCRATCH_0[15:0]
0x0000 DSP1 Scratch Register 0
R1048130 (0xF_FE42)
31:16 DSP1_SCRATCH_3[15:0]
0x0000 DSP1 Scratch Register 3
DSP1_Scratch_2
15:0 DSP1_SCRATCH_2[15:0]
0x0000 DSP1 Scratch Register 2
R1048146 (0xF_FE52)
23:0 DSP1_BUS_ERR_ADDR[23:0]
0x00_0000 Contains the register address of a memory region lock
or memory address error event.
DSP1_Bus_Error_Addr
Note the associated register address is equal to DSP1_
BUS_ERR_ADDR / 2.
R1048186 (0xF_FE7A)
15 DSP1_LOCK_ERR_STS
0
DSP1 memory region lock error status.
DSP1_Region_lock_ctrl_0
This bit, when set, indicates that DSP1 attempted to
write to a locked register address.
This bit is latched when set; it is cleared when a 1 is
written to DSP1_ERR_CLEAR.
14 DSP1_ADDR_ERR_STS
0
DSP1 memory address error status.
This bit, when set, indicates that DSP1 attempted to
access an undefined locked register address.
This bit is latched when set; it is cleared when a 1 is
written to DSP1_ERR_CLEAR.
1
DSP1_ERR_PAUSE
0
DSP1 bus address error control.
Configures the DSP1 response to a memory region lock
error event.
0 = No action
1 = Pause DSP1 code execution
0
DSP1_ERR_CLEAR
0
Write 1 to clear the memory region lock error and
memory address error status bits.
30:16 DSP1_PMEM_ERR_ADDR[14:0]
0x0000 Contains the program memory address of a memory
R1048188 (0xF_FE7C)
region lock error event. Note this is the prefetched
DSP1_PMEM_Err_Addr___
address of a subsequent instruction; it does not point
XMEM_ERR_Addr
directly to the address that caused the error.
15:0 DSP1_XMEM_ERR_ADDR[15:0]
0x0000 Contains the X-data memory address of a memory
region lock error event.
4.4.7
Bit
3
Label
DSP1_DBG_CLK_ENA
Default
0
Virtual DSP Registers
The DSP control registers are described throughout Section 4.4. Each control register has a unique location within the
CS42L92 register map.
An additional set of DSP control registers is also defined, which can be used in firmware to access the DSP control fields:
the virtual DSP (or DSP 0) registers are defined at address R4096 (0x1000) in the device register map. The full register
map listing is provided in Section 6.
Note that read/write access to the virtual DSP registers is only possible via firmware running on the integrated DSP core.
When DSP firmware accesses the virtual registers, the registers are automatically mapped onto the DSP1 control
registers. The virtual DSP registers are designed to allow software to be transferable across different DSPs (e.g., on
multicore devices) without modification to the software code.
The virtual DSP registers are defined at register addresses R4096–R4192 (0x1000–0x1060) in the device register map.
Note that these registers cannot be accessed directly at the addresses shown; they can be only accessed through DSP
firmware code, using the register window function shown in Fig. 4-34. The virtual DSP registers are located at address
0xD000 in the X-data memory map.
DS1162F1
105
CS42L92
4.5 DSP Peripheral Control
4.5 DSP Peripheral Control
The CS42L92 incorporates a suite of DSP peripheral functions that can be integrated together to provide an enhanced
capability for DSP applications. Configurable event log functions provide multichannel monitoring of internal and external
signals. The general-purpose timer provides time-stamp data for the event logger; it also supports the watchdog and other
miscellaneous time-based functions. Maskable GPIO provides an efficient mechanism for the DSP core to access the
required input and output signals.
The DSP peripherals are designed to provide a comprehensive DSP capability, operating with a high degree of autonomy
from the host processor.
4.5.1
Event Logger
The CS42L92 provides an event log function, supporting multichannel, edge-sensitive monitoring and recording of internal
or external signals.
4.5.1.1
Overview
The event logger allows status information to be captured from a large number of sources, to be prioritized and acted upon
as required. For the purposes of the event logger, an event is recorded when a logic transition (edge) is detected on a
selected signal source.
The logged events are held in a FIFO buffer, which is managed by the application software. A 32-bit time stamp, derived
from the general-purpose timer, is associated and recorded with each FIFO index, to provide a comprehensive record of
the detected events.
The event logger must be associated with the general-purpose timer. The timer is the source of time stamp data for any
logged events. If DSPCLK is disabled, the timer also provides the clock source for the event logger. (If DSPCLK is enabled,
DSPCLK is used as the clock source instead.)
A maximum of one event per cycle of the clock source can be logged. If more than one event occurs within the cycle time,
the highest priority (lowest channel number) event is logged at the rising edge of the clock. In this case, any lower priority
events are queued, and are logged as soon as no higher priority events are pending. It is possible for recurring events on
a high-priority channel to be logged, while low-priority ones remain queued. Note that recurring instances of queued events
are not logged.
The event logger can use a slow clock (e.g., 32 kHz), but higher clock frequencies may also be commonly used, depending
on the application and use case. The clock frequency determines the maximum possible event logging rate.
4.5.1.2
Event Logger Control
The event logger is enabled by setting EVENTLOG1_ENA. The event logger can be reset by writing 1 to EVENTLOG1_
RST—executing this function clears all the event logger status flags and clears the contents of the FIFO buffer.
The associated timer (and time-stamp source) is selected using EVENTLOG1_TIME_SEL. Note that the event logger
must be disabled (EVENTLOG1_ENA = 0) when selecting the timer source.
4.5.1.3
Input Channel Configuration
The event logger allows up to 16 input channels to be configured for detection and logging. The EVENTLOG1_CHx_SEL
field selects the applicable input source for each channel (where x identifies the channel number, 1 to 16). The polarity
selection and debounce options are configured using the EVENTLOG1_CHx_POL and EVENTLOG1_CHx_DB bits
respectively.
To avoid filling the FIFO buffer with repeated instances of any event, a selectable filter is provided for each input channel.
If the EVENTLOG1_CHx_FILT bit is set, new events on the respective channel are ignored by the event logger if the
unread entries in the FIFO buffer indicate a previous event of the same type (i.e., same input source and same polarity).
The read/write pointers of the FIFO buffer (see Section 4.5.1.4) are used to determine which FIFO entries are unread (i.e.,
have not yet been read by the host processor).
106
DS1162F1
CS42L92
4.5 DSP Peripheral Control
The input channels can be enabled or disabled freely, using EVENTLOG1_CHx_ENA, without having to disable the event
logger entirely. An input channel must be disabled whenever the associated x_SEL, x_FILT, x_POL, or x_DB fields are
written. It is possible to reconfigure input channels while the event logger is enabled, provided the channels being
reconfigured are disabled when doing so.
The available input sources include GPIO inputs, external accessory status (jack, mic, sensors), and signals generated by
the integrated DSP core. A list of the valid input sources for the event logger is provided in Table 4-38. Note that, to log
both rising and falling events from any source, two separate input channels must be configured—one for each polarity.
If an input channel is configured for rising edge detection (EVENTLOG1_CHx_POL = 0), and the corresponding input
signal is asserted (Logic 1) at the time when the event logger is enabled, an event is logged in respect of this initial state.
Similarly, if an input channel is configured for falling edge detection, and is deasserted (Logic 0) when the event logger is
enabled, a corresponding event is logged. If rising and falling edges are both configured for detection, an event is always
logged in respect of the initial condition.
4.5.1.4
FIFO Buffer
Each event (signal transition) that meets the criteria of an enabled channel is written to the 16-stage FIFO buffer. The
buffer is filled cyclically, but does not overwrite unread data when full. A status bit is provided to indicate if the buffer fills
up completely.
Note that the FIFO behavior is not enforced or fully implemented in the device hardware, but assumes that a compatible
software implementation is in place. New events are written to the buffer in a cyclic manner, but the data can be read out
in any order, if desired. The designed FIFO behavior requires the software to update the read pointer (RPTR) in the
intended manner for smooth operation.
The entire contents of the 16-stage FIFO buffer can be accessed directly in the register map. Each FIFO index (y = 0 to
15) comprises the EVENTLOG1_FIFOy_ID (identifying the source signal of the associated log event), the EVENTLOG1_
FIFOy_POL (the polarity of the respective event transition), and the EVENTLOG1_FIFOy_TIME field (containing the 32-bit
time stamp from the timer).
The FIFO buffer is managed using EVENTLOG1_FIFO_WPTR and EVENTLOG1_FIFO_RPTR. The write pointer
(WPTR) field identifies the index location (0 to 15) in which the next event is logged. The read pointer (RPTR) field
identifies the index location of the first set of unread data, if any exists. Both of these fields are initialized to 0 when the
event logger is reset.
•
If RPTR WPTR, the buffer contains new data. The number of new events is equal to the difference between the
two pointer values (WPTR – RPTR, allowing for wraparound beyond Index 15). For example, if WPTR = 12 and
RPTR = 8, this means that there are four unread data sets in the buffer, at index locations 8, 9, 10, and 11.
After reading the new data from the buffer, the RPTR value should be incremented by the corresponding amount
(e.g., increment by 4, in the example described above). Note that the RPTR value can either be incremented once
for each read, or can be incremented in larger steps after a batch read.
•
If RPTR = WPTR, the buffer is either empty (0 events) or full (16 events). In this case, the status bits described in
Section 4.5.1.5 confirm the current status of the buffer.
4.5.1.5
Status Bits
The EVENTLOG1_CHx_STS bits indicate the status of the source signal for the respective input channel. Note that the
status indication is not valid for all input source selections—it is not possible to provide indication of transitory events (e.g.,
microphone accessory detection).
The EVENTLOG1_NOT_EMPTY bit indicates whether the FIFO buffer is empty. If this bit is set, it indicates one or more
new sets of data in the FIFO.
The EVENTLOG1_WMARK_STS bit indicates when the number of FIFO index locations available for new events reaches
a configurable threshold, known as the watermark level. The watermark level is held in the EVENTLOG1_FIFO_WMARK
field.
DS1162F1
107
CS42L92
4.5 DSP Peripheral Control
The EVENTLOG1_FULL bit indicates when the FIFO buffer is full. If this bit is set, it indicates that there are 16 sets of new
event data in the FIFO. Note that this does not mean that a buffer overflow condition has occurred, but further events are
not logged or indicated until the buffer has been cleared.
Note:
4.5.1.6
Following a buffer full condition, the FIFO operation resumes as soon as the RPTR field has been updated to a
new value. Writing the same value to RPTR does not restart the FIFO operation, even if the entire buffer contents
have been read. After all of the required data has been read from the buffer, the RPTR value should be set equal
to the WPTR value; an intermediate (different) value must also be written to the RPTR field in order to clear the
buffer full status and restart the FIFO operation.
Interrupts, GPIO, Write Sequencer, and DSP Firmware Control
The control-write sequencer is automatically triggered whenever the NOT_EMPTY status of the event log buffer is
asserted. See Section 4.18 for further details.
The event log status flags are inputs to the interrupt control circuit and can be used to trigger an interrupt event when the
respective FIFO condition (full, not empty, or watermark level) occurs; see Section 4.15.
The event log status can be output directly on a GPIO pin as an external indication of the event logger; see Section 4.14
to configure a GPIO pin for this function.
The event log NOT_EMPTY status can also be selected as a start trigger for DSP firmware execution; see Section 4.4.
4.5.1.7
Event Logger Control Registers
The event logger control registers are described in Table 4-37.
Table 4-37. Event Logger (EVENTLOG1) Control
Register Address
R294912 (0x4_8000)
Bit
1
Label
EVENTLOG1_RST
0
EVENTLOG1_ENA
EVENTLOG1_CONTROL
R294916 (0x4_8004)
EVENTLOG1_TIMER_SEL
1:0
EVENTLOG1_TIMER_
SEL[1:0]
R294924 (0x4_800C)
EVENTLOG1_FIFO_
CONTROL1
3:0
EVENTLOG1_FIFO_
WMARK[3:0]
R294926 (0x4_800E)
EVENTLOG1_FIFO_
POINTER1
18
EVENTLOG1_FULL
17
EVENTLOG1_WMARK_STS
16
EVENTLOG1_NOT_EMPTY
11:8 EVENTLOG1_FIFO_
WPTR[3:0]
3:0
108
EVENTLOG1_FIFO_
RPTR[3:0]
Default
Description
0
Event Log Reset
Write 1 to reset the status outputs and clear the FIFO buffer.
0
Event Log Enable
0 = Disabled
1 = Enabled
00
Event Log Timer Source Select
00 = Timer 1
All other codes are reserved. Note that the event log must be
disabled when updating this field.
0x1 Event Log FIFO Watermark. The watermark status output is
asserted when the number of FIFO locations available for new
events is less than or equal to the FIFO watermark.
Valid from 0 to 15.
0
Event Log FIFO Full Status. This bit, when set, indicates that
the FIFO buffer is full. It is cleared when a new value is written
to the FIFO read pointer, or when the event log is Reset.
0
Event Log FIFO Watermark Status. This bit, when set,
indicates that the FIFO space available for new events to be
logged is less than or equal to the watermark threshold.
0
Event Log FIFO Not-Empty Status. This bit, when set,
indicates one or more new sets of logged event data in the
FIFO.
0x0 Event Log FIFO Write Pointer. Indicates the FIFO index
location in which the next event is logged.
This is a read-only field.
0x0 Event Log FIFO Read Pointer. Indicates the FIFO index
location of the first set of unread data, if any exists. For the
intended FIFO behavior, this field must be incremented after
the respective data has been read.
DS1162F1
CS42L92
4.5 DSP Peripheral Control
Table 4-37. Event Logger (EVENTLOG1) Control (Cont.)
Register Address
R294944 (0x4_8020)
EVENTLOG1_CH_ENABLE
R294948 (0x4_8024)
EVENTLOG1_CH_STATUS
DS1162F1
Bit
15
Label
EVENTLOG1_CH16_ENA
14
EVENTLOG1_CH15_ENA
13
EVENTLOG1_CH14_ENA
12
EVENTLOG1_CH13_ENA
11
EVENTLOG1_CH12_ENA
10
EVENTLOG1_CH11_ENA
9
EVENTLOG1_CH10_ENA
8
EVENTLOG1_CH9_ENA
7
EVENTLOG1_CH8_ENA
6
EVENTLOG1_CH7_ENA
5
EVENTLOG1_CH6_ENA
4
EVENTLOG1_CH5_ENA
3
EVENTLOG1_CH4_ENA
2
EVENTLOG1_CH3_ENA
1
EVENTLOG1_CH2_ENA
0
EVENTLOG1_CH1_ENA
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
EVENTLOG1_CH16_STS
EVENTLOG1_CH15_STS
EVENTLOG1_CH14_STS
EVENTLOG1_CH13_STS
EVENTLOG1_CH12_STS
EVENTLOG1_CH11_STS
EVENTLOG1_CH10_STS
EVENTLOG1_CH9_STS
EVENTLOG1_CH8_STS
EVENTLOG1_CH7_STS
EVENTLOG1_CH6_STS
EVENTLOG1_CH5_STS
EVENTLOG1_CH4_STS
EVENTLOG1_CH3_STS
EVENTLOG1_CH2_STS
EVENTLOG1_CH1_STS
Default
Description
0
Event Log Channel 16 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 15 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 14 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 13 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 12 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 11 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 10 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 9 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 8 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 7 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 6 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 5 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 4 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 3 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 2 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 1 Enable
0 = Disabled, 1 = Enabled
0
Event Log Channel 16 Status
0
Event Log Channel 15 Status
0
Event Log Channel 14 Status
0
Event Log Channel 13 Status
0
Event Log Channel 12 Status
0
Event Log Channel 11 Status
0
Event Log Channel 10 Status
0
Event Log Channel 9 Status
0
Event Log Channel 8 Status
0
Event Log Channel 7 Status
0
Event Log Channel 6 Status
0
Event Log Channel 5 Status
0
Event Log Channel 4 Status
0
Event Log Channel 3 Status
0
Event Log Channel 2 Status
0
Event Log Channel 1 Status
109
CS42L92
4.5 DSP Peripheral Control
Table 4-37. Event Logger (EVENTLOG1) Control (Cont.)
Register Address
R294976 (0x4_8040)
EVENTLOG1_CH1_DEFINE
to
R295006 (0x4_805E)
EVENTLOG1_CH16_DEFINE
R295040 (0x4_8080)
EVENTLOG1_FIFO0_READ
R295042 (0x4_8082)
EVENTLOG1_FIFO0_TIME
R295044 (0x4_8084)
EVENTLOG1_FIFO1_READ
R295046 (0x4_8086)
EVENTLOG1_FIFO1_TIME
R295048 (0x4_8088)
EVENTLOG1_FIFO2_READ
R295050 (0x4_808A)
EVENTLOG1_FIFO2_TIME
R295052 (0x4_808C)
EVENTLOG1_FIFO3_READ
R295054 (0x4_808E)
EVENTLOG1_FIFO3_TIME
R295056 (0x4_8090)
EVENTLOG1_FIFO4_READ
R295058 (0x4_8092)
EVENTLOG1_FIFO4_TIME
R295060 (0x4_8094)
EVENTLOG1_FIFO5_READ
R295062 (0x4_8096)
EVENTLOG1_FIFO5_TIME
R295064 (0x4_8098)
EVENTLOG1_FIFO6_READ
R295066 (0x4_809A)
EVENTLOG1_FIFO6_TIME
R295068 (0x4_809C)
EVENTLOG1_FIFO7_READ
R295070 (0x4_809E)
EVENTLOG1_FIFO7_TIME
R295072 (0x4_80A0)
EVENTLOG1_FIFO8_READ
110
Bit
15
Label
EVENTLOG1_CHn_DB
14
EVENTLOG1_CHn_POL
13
EVENTLOG1_CHn_FILT
9:0
EVENTLOG1_CHn_SEL[9:0]
12
EVENTLOG1_FIFO0_POL
9:0 EVENTLOG1_FIFO0_ID[9:0]
31:0 EVENTLOG1_FIFO0_
TIME[31:0]
12
EVENTLOG1_FIFO1_POL
9:0 EVENTLOG1_FIFO1_ID[9:0]
31:0 EVENTLOG1_FIFO1_
TIME[31:0]
12
EVENTLOG1_FIFO2_POL
9:0 EVENTLOG1_FIFO2_ID[9:0]
31:0 EVENTLOG1_FIFO2_
TIME[31:0]
12
EVENTLOG1_FIFO3_POL
9:0 EVENTLOG1_FIFO3_ID[9:0]
31:0 EVENTLOG1_FIFO3_
TIME[31:0]
12
EVENTLOG1_FIFO4_POL
9:0 EVENTLOG1_FIFO4_ID[9:0]
31:0 EVENTLOG1_FIFO4_
TIME[31:0]
12
EVENTLOG1_FIFO5_POL
9:0 EVENTLOG1_FIFO5_ID[9:0]
31:0 EVENTLOG1_FIFO5_
TIME[31:0]
12
EVENTLOG1_FIFO6_POL
9:0 EVENTLOG1_FIFO6_ID[9:0]
31:0 EVENTLOG1_FIFO6_
TIME[31:0]
12
EVENTLOG1_FIFO7_POL
9:0 EVENTLOG1_FIFO7_ID[9:0]
31:0 EVENTLOG1_FIFO7_
TIME[31:0]
12
EVENTLOG1_FIFO8_POL
9:0
EVENTLOG1_FIFO8_ID[9:0]
Default
Description
0
Event Log Channel n debounce
0 = Disabled, 1 = Enabled
Note that channel must be disabled when updating this field.
0
Event Log Channel n polarity
0 = Rising edge triggered, 1 = Falling edge triggered
Note that channel must be disabled when updating this field.
0
Event Log Channel n filter
0 = Disabled, 1 = Enabled
If the filter is enabled, the channel is ignored if the FIFO
contains unread events of the same source/polarity.
Note that channel must be disabled when updating this field.
0x000 Event Log Channel n source 1
Note that channel must be disabled when updating this field.
0
Event Log FIFO Index 0 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 0 source 1
0x0000 Event Log FIFO Index 0 Time
_0000
0
Event Log FIFO Index 1 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 1 source 1
0x0000 Event Log FIFO Index 1 Time
_0000
0
Event Log FIFO Index 2 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 2 source 1
0x0000 Event Log FIFO Index 2 Time
_0000
0
Event Log FIFO Index 3 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 3 source 1
0x0000 Event Log FIFO Index 3 Time
_0000
0
Event Log FIFO Index 4 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 4 source 1
0x0000 Event Log FIFO Index 4 Time
_0000
0
Event Log FIFO Index 5 polarity
Field description is as above.
0x000 Event Log FIFO Index 5 source 1
0x0000 Event Log FIFO Index 5 Time
_0000
0
Event Log FIFO Index 6 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 6 source 1
0x0000 Event Log FIFO Index 6 Time
_0000
0
Event Log FIFO Index 7 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 7 source 1
0x0000 Event Log FIFO Index 7 Time
_0000
0
Event Log FIFO Index 8 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 8 source 1
DS1162F1
CS42L92
4.5 DSP Peripheral Control
Table 4-37. Event Logger (EVENTLOG1) Control (Cont.)
Register Address
R295074 (0x4_80A2)
EVENTLOG1_FIFO8_TIME
R295076 (0x4_80A4)
EVENTLOG1_FIFO9_READ
Bit
Label
31:0 EVENTLOG1_FIFO8_
TIME[31:0]
12
EVENTLOG1_FIFO9_POL
Default
Description
0x0000 Event Log FIFO Index 8 Time
_0000
0
Event Log FIFO Index 9 polarity
0 = Rising edge, 1 = Falling edge
0x000 Event Log FIFO Index 9 source 1
0x0000 Event Log FIFO Index 9 Time
_0000
9:0 EVENTLOG1_FIFO9_ID[9:0]
R295078 (0x4_80A6)
31:0 EVENTLOG1_FIFO9_
TIME[31:0]
EVENTLOG1_FIFO9_TIME
R295080 (0x4_80A8)
12 EVENTLOG1_FIFO10_POL
0
Event Log FIFO Index 10 polarity
EVENTLOG1_FIFO10_READ
0 = Rising edge, 1 = Falling edge
9:0 EVENTLOG1_FIFO10_ID[9:0] 0x000 Event Log FIFO Index 10 source 1
R295082 (0x4_80AA)
31:0 EVENTLOG1_FIFO10_
0x0000 Event Log FIFO Index 10 Time
TIME[31:0]
_0000
EVENTLOG1_FIFO10_TIME
R295084 (0x4_80AC)
EVENTLOG1_FIFO11_READ
R295086 (0x4_80AE)
EVENTLOG1_FIFO11_TIME
R295088 (0x4_80B0)
EVENTLOG1_FIFO12_READ
R295090 (0x4_80B2)
EVENTLOG1_FIFO12_TIME
R295092 (0x4_80B4)
EVENTLOG1_FIFO13_READ
R295094 (0x4_80B6)
EVENTLOG1_FIFO13_TIME
R295096 (0x4_80B8)
EVENTLOG1_FIFO14_READ
R295098 (0x4_80BA)
EVENTLOG1_FIFO14_TIME
R295100 (0x4_80BC)
EVENTLOG1_FIFO15_READ
R295102 (0x4_80BE)
EVENTLOG1_FIFO15_TIME
12
EVENTLOG1_FIFO11_POL
0
Event Log FIFO Index 11 polarity
0 = Rising edge, 1 = Falling edge
9:0 EVENTLOG1_FIFO11_ID[9:0] 0x000 Event Log FIFO Index 11 source 1
31:0 EVENTLOG1_FIFO11_
0x0000 Event Log FIFO Index 11 Time
TIME[31:0]
_0000
12
EVENTLOG1_FIFO12_POL
0
12
EVENTLOG1_FIFO13_POL
0
12
EVENTLOG1_FIFO14_POL
0
12
EVENTLOG1_FIFO15_POL
0
Event Log FIFO Index 12 polarity
0 = Rising edge, 1 = Falling edge
9:0 EVENTLOG1_FIFO12_ID[9:0] 0x000 Event Log FIFO Index 12 source 1
31:0 EVENTLOG1_FIFO12_
0x0000 Event Log FIFO Index 12 Time
TIME[31:0]
_0000
Event Log FIFO Index 13 polarity
0 = Rising edge, 1 = Falling edge
9:0 EVENTLOG1_FIFO13_ID[9:0] 0x000 Event Log FIFO Index 13 source 1
31:0 EVENTLOG1_FIFO13_
0x0000 Event Log FIFO Index 13 Time
TIME[31:0]
_0000
Event Log FIFO Index 14 polarity
0 = Rising edge, 1 = Falling edge
9:0 EVENTLOG1_FIFO14_ID[9:0] 0x000 Event Log FIFO Index 14 source 1
31:0 EVENTLOG1_FIFO14_
0x0000 Event Log FIFO Index 14 Time
TIME[31:0]
_0000
Event Log FIFO Index 15 polarity
0 = Rising edge, 1 = Falling edge
9:0 EVENTLOG1_FIFO15_ID[9:0] 0x000 Event Log FIFO Index 15 source 1
31:0 EVENTLOG1_FIFO15_
0x0000 Event Log FIFO Index 15 Time
TIME[31:0]
_0000
1.See Table 4-38 for valid channel source selections
4.5.1.8
Event Logger Input Sources
A list of the valid input sources for the event logger is provided in Table 4-38.
The EDGE type noted is coded as S (single edge) or D (dual edge). Note that a single-edge input source only provides
valid input to the event logger in the default (rising edge triggered) polarity.
Take care when enabling IRQ1 or IRQ2 as an input source for the event logger; a recursive loop, where the IRQn signal
is also an output from the event logger, must be avoided.
Table 4-38. Event Logger Input Sources
ID
3
4
9
24
25
Description
irq1
irq2
sysclk_fail
fll1_lock
fll2_lock
DS1162F1
Edge
D
D
S
D
D
ID
137
160
161
162
163
Description
asrc1_in2_lock
dsp_irq1
dsp_irq2
dsp_irq3
dsp_irq4
Edge
D
S
S
S
S
ID
258
259
260
261
262
Description
gpio3
gpio4
gpio5
gpio6
gpio7
Edge
D
D
D
D
D
111
CS42L92
4.5 DSP Peripheral Control
Table 4-38. Event Logger Input Sources (Cont.)
ID
28
29
30
32
33
34
40
41
80
88
89
96
97
98
99
100
101
104
105
128
129
130
136
Description
sysclk_err
asyncclk_err
dspclk_err
frame_start_g1r1
frame_start_g1r2
frame_start_g1r3
frame_start_g2r1_sys
frame_start_g2r2_sys
hpdet
micdet1
micdet2
jd1_rise
jd1_fall
jd2_rise
jd2_fall
micd_clamp_rise
micd_clamp_fall
jd3_rise
jd3_fall
drc1_sig_det
drc2_sig_det
inputs_sig_det
asrc1_in1_lock
4.5.2
Edge
D
D
D
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
D
D
D
D
ID
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
184
185
236
256
257
Description
dsp_irq5
dsp_irq6
dsp_irq7
dsp_irq8
dsp_irq9
dsp_irq10
dsp_irq11
dsp_irq12
dsp_irq13
dsp_irq14
dsp_irq15
dsp_irq16
hp1l_sc
hp1r_sc
hp2l_sc
hp2r_sc
hp3l_sc
hp3r_sc
hp4l_sc
hp4r_sc
dfc_saturate
gpio1
gpio2
Edge
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
S
D
D
ID
263
264
265
266
267
268
269
270
271
320
336
352
368
384
416
432
448
464
512
560
561
562
563
Description
gpio8
gpio9
gpio10
gpio11
gpio12
gpio13
gpio14
gpio15
gpio16
Timer1
event1_not_empty
event1_full
event1_wmark
dsp1_dma
dsp1_start1
dsp1_start2
dsp1_start
dsp1_busy
dsp1_bus_err
alarm1_ch1
alarm1_ch2
alarm1_ch3
alarm1_ch4
Edge
D
D
D
D
D
D
D
D
D
S
S
S
S
S
S
S
S
D
S
S
S
S
S
Alarm Generators
The CS42L92 provides four alarm-generator circuits are associated with the general-purpose timer. These can be used
to generate interrupt events according to the count value of the timer. The alarm interrupts can be either one-off events,
or can be configured for cyclic (repeated) triggers.
4.5.2.1
Alarm Control
The alarm is enabled by writing 1 to the ALM1_CHn_START bit (where n identifies the respective alarm, 1–4). The alarm
is disabled by writing 1 to ALM1_CHn_STOP.
The operating mode of each alarm is configured using ALM1_CHn_TRIG_MODE. In each mode, the alarm events are
controlled by the alarm-trigger value, ALM1_CHn_TRIG_VAL.
•
In Absolute Mode, the alarm output is triggered when the timer count value is equal to the alarm trigger value.
•
In Relative Mode, the alarm output is triggered when the timer count value has incremented by a number equal to
the alarm trigger value—this mode counts the number of clock cycles after the ALM1_CHn_START bit is written.
•
In Combination Mode, the alarm output is initially triggered as described for the Absolute Mode; the alarm then
operates as described for the Relative Mode.
When the alarm output is triggered, an output signal is asserted for the respective alarm. The output is asserted for a
duration that is configured using ALM1_CHn_PULSE_DUR. The resulting signal can be output directly on a GPIO pin.
If an alarm is enabled and an update is written to ALM1_CHn_TRIG_VAL or ALM1_CHn_PULSE_DUR, the new value is
loaded into the respective control register, but does not reconfigure the alarm immediately. If the ALM1_CHn_UPD bit is
set, the alarm-trigger and pulse-duration values are updated when the alarm is next triggered. The alarm-trigger and
pulse-duration settings can also be updated by writing 1 to ALM1_CHn_START.
Note that, if an alarm is enabled, the general-purpose timer must be configured for continuous, count-up operation. The
TIMER1_MAX_COUNT value must be greater than the respective ALM1_CHn_TRIG_VAL setting.
112
DS1162F1
CS42L92
4.5 DSP Peripheral Control
4.5.2.2
Interrupts and GPIO Output
The alarm generators provide input to the interrupt control circuit and can be used to trigger an interrupt event when the
alarm-trigger conditions are met. An interrupt event is triggered on the rising edge of the alarm output signal.
The alarm output status bits, TIMER_ALM1_CHn_STSx, are asserted for a duration that is configured using ALM1_CHn_
PULSE_DUR. Note that the TIMER_ALM1_CHn_STS1 and TIMER_ALM1_CHn_STS2 bits provide the same information.
See Section 4.15 for details of the CS42L92 interrupt controller.
The alarm status can be output directly on a GPIO pin as an external indication of the alarm events. See Section 4.14 to
configure a GPIO pin for this function.
4.5.2.3
Alarm Control Registers
The alarm control registers are described in Table 4-39.
Table 4-39. Alarm (ALM1) Control
Register Address
R303104 (0x4A000)
ALM1_CFG
R303120 (0x4A010)
ALM1_CONFIG1
R303122 (0x4A012)
ALM1_CTRL1
R303124 (0x4A014)
ALM1_TRIG_VAL1
R303126 (0x4A016)
ALM1_PULSE_DUR1
R303128 (0x4A018)
ALM1_STATUS1
DS1162F1
Bit
0
Label
ALM1_TIMER_
SEL
Default
Description
0
Alarm block ALM1 timer source select
0 = Timer 1
All other codes are reserved.
All ALM1 channels must be disabled when updating this register.
4
ALM1_CH1_
0
Channel 1 continuous mode select
CONT
0 = Single mode
1 = Continuous mode
Channel 1 must be disabled (ALM1_CH1_STS = 0) when updating this field.
1:0 ALM1_CH1_
00
Channel 1 trigger mode select
TRIG_MODE[1:0]
00 = Absolute Mode: Alarm is triggered when the count value of the timer source
is equal to ALM1_CH1_TRIG_VAL.
01 = Relative Mode: Alarm is triggered when the count value has incremented by
a number equal to ALM1_CH1_TRIG_VAL.
10 = Combination Mode: Alarm is initially triggered as described for Absolute
Mode; the alarm then operates as described for Relative Mode.
11 = Reserved
Channel 1 must be disabled (ALM1_CH1_STS = 0) when updating this field.
15 ALM1_CH1_UPD
0
Channel 1 update control—Write 1 to indicate a new trigger value or pulse duration
is ready to be applied.
If Channel 1 is enabled and ALM1_CH1_UPD is set, the ALM1_CH1_TRIG_VAL
and ALM1_CH1_PULSE_DUR settings are updated when the alarm is next
triggered or by writing 1 to ALM1_CH1_START.
If Channel 1 is disabled, the ALM1_CH1_UPD bit has no effect, and the ALM1_
CH1_TRIG_VAL and ALM1_CH1_PULSE_DUR settings are updated
immediately when writing to the respective fields.
4
ALM1_CH1_
—
Channel 1 stop control—Write 1 to disable Channel 1
STOP
0
ALM1_CH1_
—
Channel 1 start control—Write 1 to enable or restart Channel 1
START
31:0 ALM1_CH1_
0x0000 Channel 1 alarm trigger value
TRIG_VAL[31:0]
_0000
31:0 ALM1_CH1_
0x0000 Channel 1 alarm output pulse duration
PULSE_
_0000 The pulse duration is referenced to the count rate of the selected timer source
DUR[31:0]
0
ALM1_CH1_STS
0
Channel 1 status
0 = Disabled
1 = Enabled
113
CS42L92
4.5 DSP Peripheral Control
Table 4-39. Alarm (ALM1) Control (Cont.)
Register Address
R303136 (0x4A020)
ALM1_CONFIG2
R303138 (0x4A022)
ALM1_CTRL2
R303140 (0x4A024)
ALM1_TRIG_VAL2
R303142 (0x4A026)
ALM1_PULSE_DUR2
R303144 (0x4A028)
ALM1_STATUS2
R303152 (0x4A030)
ALM1_CONFIG3
R303154 (0x4A032)
ALM1_CTRL3
R303156 (0x4A034)
ALM1_TRIG_VAL3
114
Bit
4
Label
ALM1_CH2_
CONT
Default
Description
0
Channel 2 continuous mode select
0 = Single mode
1 = Continuous mode
Channel 2 must be disabled (ALM1_CH2_STS = 0) when updating this field.
1:0 ALM1_CH2_
00
Channel 2 trigger mode select
TRIG_MODE[1:0]
00 = Absolute Mode: Alarm is triggered when the count value of the timer source
is equal to ALM1_CH2_TRIG_VAL.
01 = Relative Mode: Alarm is triggered when the count value has incremented by
a number equal to ALM1_CH2_TRIG_VAL.
10 = Combination Mode: Alarm is initially triggered as described for Absolute
Mode; the alarm then operates as described for Relative Mode.
11 = Reserved
Channel 2 must be disabled (ALM1_CH2_STS = 0) when updating this field.
15 ALM1_CH2_UPD
0
Channel 2 update control—Write 1 to indicate a new trigger value or pulse duration
is ready to be applied.
If Channel 2 is enabled and ALM1_CH2_UPD is set, the ALM1_CH2_TRIG_VAL
and ALM1_CH2_PULSE_DUR settings are updated when the alarm is next
triggered or by writing 1 to ALM1_CH2_START.
If Channel 2 is disabled, the ALM1_CH2_UPD bit has no effect, and the ALM1_
CH2_TRIG_VAL and ALM1_CH2_PULSE_DUR settings are updated
immediately when writing to the respective fields.
4
ALM1_CH2_
—
Channel 2 stop control—Write 1 to disable Channel 2
STOP
0
ALM1_CH2_
—
Channel 2 start control—Write 1 to enable or restart Channel 2
START
31:0 ALM1_CH2_
0x0000 Channel 2 alarm trigger value
TRIG_VAL[31:0]
_0000
31:0 ALM1_CH2_
0x0000 Channel 2 alarm output pulse duration
PULSE_
_0000 The pulse duration is referenced to the count rate of the selected timer source
DUR[31:0]
0
ALM1_CH2_STS
0
Channel 2 status
0 = Disabled
1 = Enabled
4
ALM1_CH3_
0
Channel 3 continuous mode select
CONT
0 = Single mode
1 = Continuous mode
Channel 3 must be disabled (ALM1_CH3_STS = 0) when updating this field.
1:0 ALM1_CH3_
00
Channel 3 trigger mode select
TRIG_MODE[1:0]
00 = Absolute Mode: Alarm is triggered when the count value of the timer source
is equal to ALM1_CH3_TRIG_VAL.
01 = Relative Mode: Alarm is triggered when the count value has incremented by
a number equal to ALM1_CH3_TRIG_VAL.
10 = Combination Mode: Alarm is initially triggered as described for Absolute
Mode; the alarm then operates as described for Relative Mode.
11 = Reserved
Channel 3 must be disabled (ALM1_CH3_STS = 0) when updating this field.
15 ALM1_CH3_UPD
0
Channel 3 update control—Write 1 to indicate a new trigger value or pulse duration
is ready to be applied.
If Channel 3 is enabled and ALM1_CH3_UPD is set, the ALM1_CH3_TRIG_VAL
and ALM1_CH3_PULSE_DUR settings are updated when the alarm is next
triggered or by writing 1 to ALM1_CH3_START.
If Channel 3 is disabled, the ALM1_CH3_UPD bit has no effect, and the ALM1_
CH3_TRIG_VAL and ALM1_CH3_PULSE_DUR settings are updated
immediately when writing to the respective fields.
4
ALM1_CH3_
—
Channel 3 stop control—Write 1 to disable Channel 3
STOP
0
ALM1_CH3_
—
Channel 3 start control—Write 1 to enable or restart Channel 3
START
31:0 ALM1_CH3_
0x0000 Channel 3 alarm trigger value
TRIG_VAL[31:0]
_0000
DS1162F1
CS42L92
4.5 DSP Peripheral Control
Table 4-39. Alarm (ALM1) Control (Cont.)
Register Address
R303158 (0x4A036)
ALM1_PULSE_DUR3
R303160 (0x4A038)
ALM1_STATUS3
R303168 (0x4A040)
ALM1_CONFIG4
R303170 (0x4A042)
ALM1_CTRL4
R303172 (0x4A044)
ALM1_TRIG_VAL4
R303174 (0x4A046)
ALM1_PULSE_DUR4
R303176 (0x4A048)
ALM1_STATUS4
4.5.3
Bit
Label
Default
Description
31:0 ALM1_CH3_
0x0000 Channel 3 alarm output pulse duration
PULSE_
_0000 The pulse duration is referenced to the count rate of the selected timer source
DUR[31:0]
0
ALM1_CH3_STS
0
Channel 3 status
0 = Disabled
1 = Enabled
4
ALM1_CH4_
0
Channel 4 continuous mode select
CONT
0 = Single mode
1 = Continuous mode
Channel 4 must be disabled (ALM1_CH4_STS = 0) when updating this field.
1:0 ALM1_CH4_
00
Channel 4 trigger mode select
TRIG_MODE[1:0]
00 = Absolute Mode: Alarm is triggered when the count value of the timer source
is equal to ALM1_CH4_TRIG_VAL.
01 = Relative Mode: Alarm is triggered when the count value has incremented by
a number equal to ALM1_CH4_TRIG_VAL.
10 = Combination Mode: Alarm is initially triggered as described for Absolute
Mode; the alarm then operates as described for Relative Mode.
11 = Reserved
Channel 4 must be disabled (ALM1_CH4_STS = 0) when updating this field.
15 ALM1_CH4_UPD
0
Channel 4 update control—Write 1 to indicate a new trigger value or pulse duration
is ready to be applied.
If Channel 4 is enabled and ALM1_CH4_UPD is set, the ALM1_CH4_TRIG_VAL
and ALM1_CH4_PULSE_DUR settings are updated when the alarm is next
triggered or by writing 1 to ALM1_CH4_START.
If Channel 4 is disabled, the ALM1_CH4_UPD bit has no effect, and the ALM1_
CH4_TRIG_VAL and ALM1_CH4_PULSE_DUR settings are updated
immediately when writing to the respective fields.
4
ALM1_CH4_
—
Channel 4 stop control—Write 1 to disable Channel 4
STOP
0
ALM1_CH4_
—
Channel 4 start control—Write 1 to enable or restart Channel 4
START
31:0 ALM1_CH4_
0x0000 Channel 4 alarm trigger value
TRIG_VAL[31:0]
_0000
31:0 ALM1_CH4_
0x0000 Channel 4 alarm output pulse duration
PULSE_
_0000 The pulse duration is referenced to the count rate of the selected timer source
DUR[31:0]
0
ALM1_CH4_STS
0
Channel 4 status
0 = Disabled
1 = Enabled
General-Purpose Timer
The CS42L92 incorporates a general-purpose timer, which supports a wide variety of uses. The general-purpose timer
provides time-stamp data for the event logger; it also supports the watchdog and other miscellaneous time-based
functions, providing additional capability for signal-processing applications.
4.5.3.1
Overview
The timer allows time-stamp information to be associated with external signal detection, and other system events, enabling
real-time data to be more easily integrated into user applications. The timer allows many advanced functions to be
implemented with a high degree of autonomy from a host processor.
The timer can use either internal system clocks, or external clock signals, as a reference. The selected reference is scaled
down, using configurable dividers, to the required clock count frequency.
4.5.3.2
Timer Control
The reference clock for the timer is selected using TIMER1_REFCLK_SRC.
DS1162F1
115
CS42L92
4.5 DSP Peripheral Control
If SYSCLK, ASYNCCLK, or DSPCLK is selected, a lower clock frequency, derived from the applicable system clock, can
be selected using the TIMER1_REFCLK_FREQ_SEL field (for SYSCLK or ASYNCCLK source) or the TIMER1_
DSPCLK_FREQ_SEL field (for DSPCLK source). The applicable division ratio is determined automatically, assuming the
respective clock source has been correctly configured as described in Section 4.16.
Note that, depending on the DSPCLK frequency and the available clock dividers, the timer reference clock may differ from
the selected clock if DSPCLK is the selected source. In most cases, the reference clock frequency equals or exceeds the
requested frequency. A lower frequency is implemented if limited by either the DSPCLK frequency or the maximum
TIMER1 clocking frequency.
If any source other than DSPCLK is selected, the clock can be further divided using TIMER1_REFCLK_DIV. Division ratios
in the range 1 to 128 can be selected.
Note that, if DSPCLK is enabled, the CS42L92 synchronizes the selected reference clock to DSPCLK. As a result of this,
if a non-DSPCLK is selected as source, the following additional constraints must be observed: the reference clock
frequency (after TIMER1_REFCLK_FREQ_SEL and after TIMER1_REFCLK_DIV) must be less than DSPCLK / 3, and
must be less than 12 MHz; it must also be close to 50% duty cycle. The TIMER1_REFCLK_DIV field can be used to ensure
that these criteria are met.
One final division, controlled by TIMER1_PRESCALE, determines the timer count frequency. This field is valid for all clock
reference sources; division ratios in the range 1 to 128 can be selected. The output from this division corresponds to the
frequency at which the TIMER1_COUNT field is incremented (or decremented).
The maximum count value of the timer is determined by the TIMER1_MAX_COUNT field. This is the final count value
(when counting up), or the initial count value (when counting down). The current value of the timer counter can be read
from the TIMER1_CUR_COUNT field.
The timer is started by writing 1 to TIMER1_START. Note that, if the timer is already running, it restarts from its initial value.
The timer is stopped by writing 1 to TIMER1_STOP. The count direction (up or down) is selected using the TIMER1_DIR
bit.
The TIMER1_CONTINUOUS bit selects whether the timer automatically restarts after the end-of-count condition has been
reached. The TIMER1_RUNNING_STS indicates whether the timer is running, or if it has stopped.
Note that the timer should be stopped before making any changes to the timer control registers. The timer configuration
should only be changed if TIMER1_RUNNING_STS = 0.
4.5.3.3
Interrupts and GPIO Output
The timer status is an input to the interrupt control circuit and can be used to trigger an interrupt event after the final count
value is reached; see Section 4.15. Note that the interrupt does not occur immediately when the final count value is
reached; the interrupt is triggered at the point when the next update to the timer count value would be due.
The timer status can be output directly on a GPIO pin as an external indication of the timer activity. See Section 4.14 to
configure a GPIO pin for this function.
116
DS1162F1
CS42L92
4.5 DSP Peripheral Control
4.5.3.4
Timer Block Diagram and Control Registers
The timer block is shown in Fig. 4-35.
DSPCLK
32k Clock
MCLK1
MCLK2
SYSCLK
ASYNCCLK
GPIO1
GPIO2
GPIO3
GPIO4
TIMER1_REFCLK_SRC[3:0] p. 118
If DSPCLK is enabled, and a clock
source other than DSPCLK is selected,
f ≤ DSPCLK/3, f ≤ 12MHz
Divider
Divider
TIMER1_REFCLK_FREQ_SEL[2:0] p. 118
TIMER1_REFCLK_DIV[2:0] p. 118
TIMER1_PRESCALE[2:0] p. 118
SYSCLK / ASYNCCLK only
Divide by 1, 2, 4, 8 … 64
except DSPCLK
Divide by 1, 2, 4, 8 … 128
TIMER1_DSPCLK_FREQ_SEL[15:0] p. 119
Divider
f = TIMER
count rate
DSPCLK only
Figure 4-35. General-Purpose Timer
The timer control registers are described in Table 4-40.
DS1162F1
117
CS42L92
4.5 DSP Peripheral Control
Table 4-40. General-Purpose Timer (TIMER1) Control
Register Address
R311296 (0x4_C000)
Timer1_Control
Default
Description
0
Timer Continuous Mode select
0 = Single mode
1 = Continuous mode
Timer must be stopped (TIMER1_RUNNING_STS = 0) when updating this field
20 TIMER1_DIR
0
Timer Count Direction
0 = Down
1 = Up
Timer must be stopped (TIMER1_RUNNING_STS = 0) when updating this field
18:16 TIMER1_
000 Timer Count Rate Prescale
PRESCALE[2:0]
000 = Divide by 1
011 = Divide by 8
110 = Divide by 64
001 = Divide by 2
100 = Divide by 16
111 = Divide by 128
010 = Divide by 4
101 = Divide by 32
Timer must be stopped (TIMER1_RUNNING_STS = 0) when updating this field
14:12 TIMER1_
000 Timer Reference Clock Divide (Not valid for DSPCLK source).
REFCLK_DIV[2:0]
000 = Divide by 1
011 = Divide by 8
110 = Divide by 64
001 = Divide by 2
100 = Divide by 16
111 = Divide by 128
010 = Divide by 4
101 = Divide by 32
If DSPCLK is enabled, and DSPCLK is not selected as source, the output
frequency from this divider must be set less than or equal to DSPCLK / 3, and less
than or equal to 12 MHz.
If DSPCLK is disabled, the output of this divider is used as clock reference for the
event logger. In this case, the divider output corresponds to the frequency of event
logging opportunities on the respective modules.
Timer must be stopped (TIMER1_RUNNING_STS = 0) when updating this field
10:8 TIMER1_
000 Timer Reference Frequency Select (SYSCLK or ASYNCCLK source)
REFCLK_FREQ_
000 = 6.144 MHz (5.6448 MHz)
010 = 24.576 MHz (22.5792 MHz)
SEL[2:0]
001 = 12.288 MHz (11.2896 MHz)
011 = 49.152 MHz (45.1584 MHz)
All other codes are reserved.
The selected frequency must be less than or equal to the frequency of the source.
Timer must be stopped (TIMER1_RUNNING_STS = 0) when updating this field.
3:0 TIMER1_
0000 Timer Reference Source Select.
REFCLK_
Timer must be stopped (TIMER1_RUNNING_STS=0) when updating this field.
SRC[3:0]
1110 = GPIO3
1000 = SYSCLK
0000 = DSPCLK
1111 = GPIO4
1001 = ASYNCCLK
0001 = 32-kHz clock
All other codes are
1100 = GPIO1
0100 = MCLK1
reserved.
1101 = GPIO2
0101 = MCLK2
R311298 (0x4_C002) 31:0 TIMER1_MAX_
0x0000 Timer Maximum Count.
COUNT[31:0]
_0000 Final count value (when counting up). Starting count value (when counting down).
Timer1_Count_Preset
Timer must be stopped (TIMER1_RUNNING_STS = 0) when updating this field.
R311302 (0x4_C006)
4
TIMER1_STOP
0
Timer Stop Control
Timer1_Start_and_
Write 1 to stop.
Stop
0
TIMER1_START
0
Timer Start Control
Write 1 to start.
If the timer is already running, it restarts from its initial value.
0
Timer Running Status
R311304 (0x4_C008)
0
TIMER1_
RUNNING_STS
0 = Timer stopped
Timer1_Status
1 = Timer running
118
Bit
21
Label
TIMER1_
CONTINUOUS
DS1162F1
CS42L92
4.5 DSP Peripheral Control
Table 4-40. General-Purpose Timer (TIMER1) Control (Cont.)
Register Address
R311306 (0x4_C00A)
Timer1_Count_
Readback
R311308 (0x4_C00C)
Timer1_DSP_Clock_
Config
R311310 (0x4_C00E)
Timer1_DSP_Clock_
Status
4.5.4
Bit
Label
31:0 TIMER1_CUR_
COUNT[31:0]
Default
0x0000 Timer Current Count value
Description
15:0 TIMER1_
0x0000 Timer Reference Frequency Select (DSPCLK source)
DSPCLK_FREQ_
Coded as LSB = 1/64 MHz, Valid from 5.6 MHz to 148 MHz.
SEL[15:0]
The timer reference frequency must be less than or equal to the DSPCLK
frequency. The timer reference is generated by division of DSPCLK, and may
differ from the selected frequency. The timer reference frequency can be read from
TIMER1_DSPCLK_FREQ_STS.
Timer must be stopped (TIMER1_RUNNING_STS=0) when updating this field.
15:0 TIMER1_
0x0000 Timer Reference Frequency (Read only)
DSPCLK_FREQ_
Only valid when DSPCLK is the selected clock source.
STS[15:0]
Coded as LSB = 1/64 MHz.
DSP GPIO
The DSP GPIO function provides an advanced I/O capability, supporting enhanced flexibility for signal-processing
applications.
4.5.4.1
Overview
The CS42L92 supports up to 16 GPIO pins, which can be assigned to application-specific functions. There are 2 dedicated
GPIO pins; the remaining 14 GPIOs are implemented as alternate functions to a pin-specific capability.
The GPIOs can be used to provide status outputs and control signals to external hardware; the supported functions include
interrupt output, FLL clock output, accessory detection status, and S/PDIF or PWM-coded audio channels; see
Section 4.14.
The GPIOs can support miscellaneous logic input and output, interfacing directly with the integrated DSPs, or with the host
application software. A basic level of I/O functionality is described in Section 4.14, under the configuration where GPn_
FN = 0x001. The GPn_FN field selects the functionality for the respective pin, GPIOn.
The DSP GPIO pins are accessed using maskable sets of I/O control registers; this allows the selected combinations of
GPIOs to be controlled with ease, regardless of how the allocation of GPIO pins has been implemented in hardware. In a
typical use case, one GPIO mask is defined for each DSP function; this provides a highly efficient mechanism for the DSP
to independently access the respective input and output signals.
4.5.4.2
DSP GPIO Control
The DSP GPIO function is selected by setting GPn_FN = 0x002 for the respective GPIO pin (where n identifies the
applicable GPIOn pin).
Each DSP GPIO is controlled using bits that determine the direction (input/output) and the logic state (0/1) of the pin. These
bits are replicated in eight control sets; each which can determine the logic level of any DSP GPIO.
Mask bits are provided within each control set, to determine which of the control sets has control of each DSP GPIO. To
avoid logic contention, a DSP GPIO output must be controlled (unmasked) in a maximum of one control set at any time.
Note that write access to the direction control bits (DSPGPn_SETx_DIR) and level control bits (DSPGPn_SETx_LVL) is
only valid when the channel (DSPGPn) is unmasked in the respective control set. Writes to these fields are implemented
for the unmasked DSP GPIOs, and are ignored in respect of the masked DSP GPIOs. Note that the level control bits
(DSPGPn_SETx_LVL) provide output level control only—they cannot be used to read the status of DSP GPIO inputs.
The logic level of the unmasked DSP GPIO outputs in any control set can be configured using a single register write.
Writing to the output level control registers determines the logic level of the unmasked DSP GPIOs in that set only; all other
outputs are unaffected.
DS1162F1
119
CS42L92
4.5 DSP Peripheral Control
DSP GPIO status bits are provided, indicating the logic level of every input or output pin that is configured as a DSP GPIO.
The DSPGPn_STS bits also provide logic-level indication for any pin that is configured as a GPIO input, with GPn_
FN = 0x001.Note that there is only one set of DSP GPIO status bits.
The status bits indicate the logic level of the DSP GPIO outputs. The respective pins are driven as outputs if configured
as a DSP GPIO output, and unmasked in one of the control sets. Note that a DSP GPIO continues to be driven as an
output, even if the mask bit is subsequently asserted in that set. The pin only ceases to be driven if it is configured as a
DSP GPIO input and is unmasked in one of the control sets, or if the pin is configured as an input under a different GPn_
FN field selection.
4.5.4.3
Common Functions to Standard GPIOs
The DSP GPIO functions are implemented alongside the standard GPIO capability, providing an alternative method of
maskable I/O control for all of the GPIO pins. The DSP GPIO control bits in the register map are implemented in a manner
that supports efficient read/write access for multiple GPIOs at once.
The DSP GPIO logic is shown in Fig. 4-36, which also shows the control fields relating to the standard GPIO.
The DSP GPIO function is selected by setting GPn_FN = 0x002 for the respective GPIO pin. Integrated pull-up and
pull-down resistors are provided on each GPIO pin, which are also valid for DSP GPIO function. A bus keeper function is
supported on the GPIO pins; this is enabled using the respective pull-up and pull-down control bits. The bus keeper
function holds the logic level unchanged whenever the pin is undriven (e.g., if the signal is tristated). See Table 4-93 for
details of the GPIO pull-up and pull-down control bits.
120
DS1162F1
CS42L92
4.5 DSP Peripheral Control
4.5.4.4
DSP GPIO Block Diagram and Control Registers
Input / Output control
Logic Level control
DSPGPn_SET1_LVL
DSPGPn_SET1_DIR
Input / Output control
Logic Level control
DSPGPn_SET2_LVL
DSPGPn_SET2_DIR
Input / Output control
Logic Level control
DSPGPn_SET3_LVL
DSPGPn_SET3_DIR
Input / Output control
Logic Level control
DSPGPn_SET4_LVL
DSPGPn_SET4_DIR
Input / Output control
Logic Level control
DSPGPn_SET5_LVL
DSPGPn_SET5_DIR
Input / Output control
Logic Level control
DSPGPn_SET6_LVL
DSPGPn_SET6_DIR
Input / Output control
Logic Level control
DSPGPn_SET7_LVL
DSPGPn_SET7_DIR
Input / Output control
Logic Level control
DSPGPn_SET8_LVL
DSPGPn_SET8_DIR
Mask control
DSPGPn_SET1_MASK
Pin-Specific
Function
Mask control
DSPGPn_SET2_MASK
GPn_FN = 0x000
GPIO Control
& Readback
Mask control
DSPGPn_SET3_MASK
GPn_LVL p. 192
GPn_FN = 0x001
Mask control
DSPGPn_SET4_MASK
DSP GPIO
Readback
GPIOn
GPn_FN = 0x002
DSPGPn_STS
Mask control
GPn_PU p. 193
GPn_PD p. 193
GPn_FN[9:0] p. 192
DSPGPn_SET5_MASK
GPn_FN > 0x002
Other GPIO
functions
Mask control
DSPGPn_SET6_MASK
GPn_POL p. 192
GPn_OP_CFG p. 192
Mask control
These bits have no effect if GPn_FN = 0x000 or 0x002.
DSPGPn_SET7_MASK
GPn_DB p. 192
Valid for GPn_LVL readback and GPIO IRQ event trigger only.
GPn_DIR p. 193
Mask control
DSPGPn_SET8_MASK
These bits have no effect if GPn_FN = 0x000 or 0x002.
If GPn_FN = 0x000, pin direction is set automatically .
If GPn_FN = 0x002, pin direction is set by DSPGPn _SETx_DIR.
Figure 4-36. DSP GPIO Control
The control registers associated with the DSP GPIO are described in Table 4-41.
DS1162F1
121
CS42L92
4.5 DSP Peripheral Control
Table 4-41. DSP GPIO Control
Register Address
R315392 (0x4_D000)
DSPGP_Status_1
R315424 (0x4_D020)
DSPGP_SET1_Mask_1
R315456 (0x4_D040)
DSPGP_SET2_Mask_1
R315488 (0x4_D060)
DSPGP_SET3_Mask_1
R315520 (0x4_D080)
DSPGP_SET4_Mask_1
R315552 (0x4_D0A0)
DSPGP_SET5_Mask_1
R315584 (0x4_D0C0)
DSPGP_SET6_Mask_1
R315616 (0x4_D0E0)
DSPGP_SET7_Mask_1
R315648 (0x4_D100)
DSPGP_SET8_Mask_1
R315432 (0x4_D028)
DSPGP_SET1_Direction_1
R315464 (0x4_D048)
DSPGP_SET2_Direction_1
R315496 (0x4_D068)
DSPGP_SET3_Direction_1
R315528 (0x4_D088)
DSPGP_SET4_Direction_1
R315560 (0x4_D0A8)
DSPGP_SET5_Direction_1
R315592 (0x4_D0C8)
DSPGP_SET6_Direction_1
R315624 (0x4_D0E8)
DSPGP_SET7_Direction_1
R315656 (0x4_D108)
DSPGP_SET8_Direction_1
122
Bit
Label
15 DSPGP16_STS
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
15
DSPGP15_STS
DSPGP14_STS
DSPGP13_STS
DSPGP12_STS
DSPGP11_STS
DSPGP10_STS
DSPGP9_STS
DSPGP8_STS
DSPGP7_STS
DSPGP6_STS
DSPGP5_STS
DSPGP4_STS
DSPGP3_STS
DSPGP2_STS
DSPGP1_STS
DSPGP16_SETn_MASK
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
15
DSPGP15_SETn_MASK
DSPGP14_SETn_MASK
DSPGP13_SETn_MASK
DSPGP12_SETn_MASK
DSPGP11_SETn_MASK
DSPGP10_SETn_MASK
DSPGP9_SETn_MASK
DSPGP8_SETn_MASK
DSPGP7_SETn_MASK
DSPGP6_SETn_MASK
DSPGP5_SETn_MASK
DSPGP4_SETn_MASK
DSPGP3_SETn_MASK
DSPGP2_SETn_MASK
DSPGP1_SETn_MASK
DSPGP16_SETn_DIR
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
DSPGP15_SETn_DIR
DSPGP14_SETn_DIR
DSPGP13_SETn_DIR
DSPGP12_SETn_DIR
DSPGP11_SETn_DIR
DSPGP10_SETn_DIR
DSPGP9_SETn_DIR
DSPGP8_SETn_DIR
DSPGP7_SETn_DIR
DSPGP6_SETn_DIR
DSPGP5_SETn_DIR
DSPGP4_SETn_DIR
DSPGP3_SETn_DIR
DSPGP2_SETn_DIR
DSPGP1_SETn_DIR
Default
Description
0
DSPGP16 Status
Valid for DSPGP input and output
0
DSPGP15 Status
0
DSPGP14 Status
0
DSPGP13 Status
0
DSPGP12 Status
0
DSPGP11 Status
0
DSPGP10 Status
0
DSPGP9 Status
0
DSPGP8 Status
0
DSPGP7 Status
0
DSPGP6 Status
0
DSPGP5 Status
0
DSPGP4 Status
0
DSPGP3 Status
0
DSPGP2 Status
0
DSPGP1 Status
1
DSP SETn GPIO16 Mask Control
0 = Unmasked, 1 = Masked
A GPIO pin should be unmasked in a maximum of one SET at any time.
1
DSP SETn GPIO15 Mask Control
1
DSP SETn GPIO14 Mask Control
1
DSP SETn GPIO13 Mask Control
1
DSP SETn GPIO12 Mask Control
1
DSP SETn GPIO11 Mask Control
1
DSP SETn GPIO10 Mask Control
1
DSP SETn GPIO9 Mask Control
1
DSP SETn GPIO8 Mask Control
1
DSP SETn GPIO7 Mask Control
1
DSP SETn GPIO6 Mask Control
1
DSP SETn GPIO5 Mask Control
1
DSP SETn GPIO4 Mask Control
1
DSP SETn GPIO3 Mask Control
1
DSP SETn GPIO2 Mask Control
1
DSP SETn GPIO1 Mask Control
1
DSP SETn GPIO16 Direction Control
0 = Output, 1 = Input
1
DSP SETn GPIO15 Direction Control
1
DSP SETn GPIO14 Direction Control
1
DSP SETn GPIO13 Direction Control
1
DSP SETn GPIO12 Direction Control
1
DSP SETn GPIO11 Direction Control
1
DSP SETn GPIO10 Direction Control
1
DSP SETn GPIO9 Direction Control
1
DSP SETn GPIO8 Direction Control
1
DSP SETn GPIO7 Direction Control
1
DSP SETn GPIO6 Direction Control
1
DSP SETn GPIO5 Direction Control
1
DSP SETn GPIO4 Direction Control
1
DSP SETn GPIO3 Direction Control
1
DSP SETn GPIO2 Direction Control
1
DSP SETn GPIO1 Direction Control
DS1162F1
CS42L92
4.6 Digital Audio Interface
Table 4-41. DSP GPIO Control (Cont.)
Register Address
R315440 (0x4_D030)
DSPGP_SET1_Level_1
R315472 (0x4_D050)
DSPGP_SET2_Level_1
R315504 (0x4_D070)
DSPGP_SET3_Level_1
R315536 (0x4_D090)
DSPGP_SET4_Level_1
R315568 (0x4_D0B0)
DSPGP_SET5_Level_1
R315600 (0x4_D0D0)
DSPGP_SET6_Level_1
R315632 (0x4_D0F0)
DSPGP_SET7_Level_1
R315664 (0x4_D110)
DSPGP_SET8_Level_1
Bit
Label
15 DSPGP16_SETn_LVL
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
DSPGP15_SETn_LVL
DSPGP14_SETn_LVL
DSPGP13_SETn_LVL
DSPGP12_SETn_LVL
DSPGP11_SETn_LVL
DSPGP10_SETn_LVL
DSPGP9_SETn_LVL
DSPGP8_SETn_LVL
DSPGP7_SETn_LVL
DSPGP6_SETn_LVL
DSPGP5_SETn_LVL
DSPGP4_SETn_LVL
DSPGP3_SETn_LVL
DSPGP2_SETn_LVL
DSPGP1_SETn_LVL
Default
Description
0
DSP SETn GPIO16 Output Level
0 = Logic 0, 1 = Logic 1
0
DSP SETn GPIO15 Output Level
0
DSP SETn GPIO14 Output Level
0
DSP SETn GPIO13 Output Level
0
DSP SETn GPIO12 Output Level
0
DSP SETn GPIO11 Output Level
0
DSP SETn GPIO10 Output Level
0
DSP SETn GPIO9 Output Level
0
DSP SETn GPIO8 Output Level
0
DSP SETn GPIO7 Output Level
0
DSP SETn GPIO6 Output Level
0
DSP SETn GPIO5 Output Level
0
DSP SETn GPIO4 Output Level
0
DSP SETn GPIO3 Output Level
0
DSP SETn GPIO2 Output Level
0
DSP SETn GPIO1 Output Level
4.6 Digital Audio Interface
The CS42L92 provides three audio interfaces, AIF1–AIF3. Each interface is independently configurable on the respective
transmit (TX) and receive (RX) paths. Each AIF supports up to eight channels of input and output signal paths.
The data sources for the audio interface transmit (TX) paths can be selected from any of the CS42L92 input signal paths,
or from the digital-core processing functions. The audio interface receive (RX) paths can be selected as inputs to any of
the digital-core processing functions or digital-core outputs. See Section 4.3 for details of the digital-core routing options.
The digital audio interfaces provide flexible connectivity for multiple processors and other audio devices. Typical
connections include applications processor, baseband processor, and wireless transceiver. Note that the SLIMbus
interface also provides digital audio input/output paths, providing options for additional interfaces. A typical configuration
is shown in Fig. 4-37.
DS1162F1
123
CS42L92
4.6 Digital Audio Interface
Applications
Processor
SLIMbus interface
HDMI
Device
Audio Interface 1
Baseband
Processor
Audio Interface 2
Wireless
Transceiver
Audio Interface 3
CS42L92
Figure 4-37. Typical AIF Connections
In the general case, the digital audio interface uses four pins:
•
TXDAT: data output
•
RXDAT: data input
•
BCLK: bit clock, for synchronization
•
LRCLK: left/right data-alignment clock
In Master Mode, the clock signals BCLK and LRCLK are outputs from the CS42L92. In Slave Mode, these signals are
inputs, as shown in Section 4.6.1.
The following interface formats are supported on AIF1–AIF3:
•
DSP Mode A
•
DSP Mode B
•
I2S
•
Left-justified
The left-justified and DSP-B formats are valid in Master Mode only (i.e., BCLK and LRCLK are outputs from the CS42L92).
These modes cannot be supported in Slave Mode.
The audio interface formats are described in Section 4.6.2. The bit order is MSB-first in each case. Mono PCM operation
can be supported using the DSP modes. Refer to Table 3-16 through Table 3-18 for signal timing information.
For typical applications, AIF data is encoded in 2’s complement (signed, fixed-point) format. This format is compatible with
all of the digital mixing and signal-processing functions on the CS42L92. Other data types, including floating point formats,
can be supported using the DFCs. Note that, if unsigned or floating point data is present within the digital core, some
restrictions on the valid signal routing options apply—see Section 4.3.13.
124
DS1162F1
CS42L92
4.6 Digital Audio Interface
4.6.1
Master and Slave Mode Operation
The CS42L92 digital audio interfaces can operate as a master or slave, as shown in Fig. 4-38 and Fig. 4-39. The
associated control bits are described in Section 4.7.
BCLK
BCLK
LRCLK
CS42L92
TXDAT
LRCLK
Processor
CS42L92
RXDAT
Figure 4-38. Master Mode
4.6.2
TXDAT
Processor
RXDAT
Figure 4-39. Slave Mode
Audio Data Formats
The CS42L92 digital audio interfaces can be configured to operate in I2S, left-justified, DSP-A, or DSP-B interface modes.
Note that left-justified and DSP-B modes are valid in Master Mode only (i.e., BCLK and LRCLK are outputs from the
CS42L92).
The digital audio interfaces also provide flexibility to support multiple slots of audio data within each LRCLK frame. This
flexibility allows multiple audio channels to be supported within a single LRCLK frame.
The data formats described in this section are generic descriptions, assuming only one stereo pair of audio samples per
LRCLK frame. In these cases, the AIF is configured to transmit (or receive) in the first available position in each frame (i.e.,
the Slot 0 position).
The options for multichannel operation are described in Section 4.6.3.
The audio data modes supported by the CS42L92 are described as follows. Note that the polarity of the BCLK and LRCLK
signals can be inverted if required; the following descriptions all assume the default, noninverted polarity of these signals.
•
In DSP modes, the left channel MSB is available on either the first (Mode B) or second (Mode A) rising edge of
BCLK following a rising edge of LRCLK. 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 Master Mode, the LRCLK output resembles the frame pulse shown in Fig. 4-40 and Fig. 4-41. In Slave Mode, it
is possible to use any length of frame pulse less than 1/Fs, providing the falling edge of the frame pulse occurs at
least one BCLK period before the rising edge of the next frame pulse.
PCM operation is supported in DSP interface mode. CS42L92 data that is output on the left channel is read as mono
data by the receiving equipment. Mono PCM data received by the CS42L92 is treated as left-channel data. This
may be routed to the left/right playback paths using the control fields described in Section 4.3.
DS1162F1
125
CS42L92
4.6 Digital Audio Interface
DSP Mode A data format is shown in Fig. 4-40.
1/Fs
LRCLK
In Slave Mode, the falling edge can occur anywhere in this area
1 BCLK
1 BCLK
BCLK
LEFT CHANNEL
RXDAT/
TXDAT
1
2
3
MSB
RIGHT CHANNEL
n-2
n-1
n
1
2
3
n-2
n-1
n
LSB
Input Word Length (WL)
Figure 4-40. DSP Mode A Data Format
DSP Mode B data format is shown in Fig. 4-41.
1/Fs
LRCLK
In Slave Mode, the falling edge can occur anywhere in this area
1 BCLK
1 BCLK
BCLK
LEFT CHANNEL
RXDAT/
TXDAT
1
2
3
MSB
n-2
RIGHT CHANNEL
n-1
n
1
2
3
n-2
n-1
n
LSB
Input Word Length (WL)
Figure 4-41. DSP Mode B Data Format
•
In I2S Mode, the MSB is available on the second rising edge of BCLK following a LRCLK 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.
I2S Mode data format is shown in Fig. 4-42.
1/Fs
LEFT CHANNEL
RIGHT CHANNEL
LRCLK
BCLK
1 BCLK
RXDAT/
TXDAT
1
2
MSB
1 BCLK
3
n-2
n-1
n
1
2
3
n-2
n-1
n
LSB
Input Word Length (WL)
Figure 4-42. I2S Data Format (Assuming n-Bit Word Length)
•
In Left-Justified Mode, the MSB is available on the first rising edge of BCLK following a LRCLK 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 LRCLK transition.
Left-Justified Mode data format is shown in Fig. 4-43.
1/Fs
LEFT CHANNEL
RIGHT CHANNEL
LRCLK
BCLK
RXDAT/
TXDAT
1
MSB
2
3
n-2
n-1
Input Word Length (WL)
n
1
2
3
n-2
n-1
n
LSB
Figure 4-43. Left-Justified Data Format (Assuming n-Bit Word Length)
126
DS1162F1
CS42L92
4.6 Digital Audio Interface
4.6.3
AIF Time-Slot Configuration
Multichannel operation is supported on AIF1–AIF3, with up to eight channels of input and output on each. A high degree
of flexibility is provided to define the position of the audio samples within each LRCLK frame; the audio channel samples
may be arranged in any order within the frame. Note that, on each interface, all input and output channels must operate
at the same sample rate (Fs).
Each audio channel can be enabled or disabled independently on the transmit (TX) and receive (RX) signal paths. For
each enabled channel, the audio samples are assigned to one time slot within the LRCLK frame.
In DSP modes, the time slots are ordered consecutively from the start of the LRCLK frame. In I2S and left-justified modes,
the even-numbered time slots are arranged in the first half of the LRCLK frame, and the odd-numbered time slots are
arranged in the second half of the frame.
The time slots are assigned independently for the transmit (TX) and receive (RX) signal paths. There is no requirement to
assign every available time slot to an audio sample; slots may be left unused, if desired. Care is required, however, to
ensure that no time slot is allocated to more than one audio channel.
The number of BCLK cycles within a slot is configurable; this is the slot length. The number of valid data bits within a slot
is also configurable; this is the word length. The number of BCLK cycles per LRCLK frame must be configured; it must be
ensured that there are enough BCLK cycles within each LRCLK frame to transmit or receive all of the enabled audio
channels.
Examples of the AIF time-slot configurations are shown in Fig. 4-44 through Fig. 4-47. One example is shown for each of
the four possible data formats.
Fig. 4-44 shows an example of DSP Mode A format. Four enabled audio channels are shown, allocated to time slots 0
through 3.
LRCLK
BCLK
TXDAT/
RXDAT
Slot 0
Channel 1
Slot 0 AIF1[TX1/RX1]_SLOT = 0
Channel 2
Channel 3
Channel 4
Slot 1
Slot 2
Slot 3
Slot 4
Slot 5
Slot 6
Slot 7
...
Slot 1 AIF1[TX2/RX2]_SLOT = 1
Slot 2 AIF1[TX3/RX3]_SLOT = 2
Slot 3 AIF1[TX4/RX4]_SLOT = 3
Figure 4-44. DSP Mode A Example
DS1162F1
127
CS42L92
4.6 Digital Audio Interface
Fig. 4-45 shows an example of DSP Mode B format. Six enabled audio channels are shown, with time slots 4 and 5
unused.
LRCLK
BCLK
TXDAT/
RXDAT
Slot 0
Slot 1
Slot 2
Slot 4
Slot 5
Slot 6
Slot 7
...
Slot 2 AIF1[TX1/RX1]_SLOT = 2
Channel 1
Slot 3 AIF1[TX2/RX2]_SLOT = 3
Channel 2
Channel 3
Slot 3
Slot 0 AIF1[TX3/RX3]_SLOT = 0
Slot 1 AIF1[TX4/RX4]_SLOT = 1
Channel 4
Slot 6 AIF1[TX5/RX5]_SLOT = 6
Channel 5
Slot 7 AIF1[TX6/RX6]_SLOT = 7
Channel 6
Figure 4-45. DSP Mode B Example
Fig. 4-46 shows an example of I2S format. Four enabled channels are shown, allocated to time slots 0 through 3.
LRCLK
BCLK
TXDAT/
RXDAT
Slot 0
Channel 1
Slot 0 AIF1[TX1/RX1]_SLOT = 0
Slot 2
Slot 4
...
Slot 1
Slot 3
Slot 5
...
Slot 1 AIF1[TX2/RX2]_SLOT = 1
Channel 2
Slot 2 AIF1[TX3/RX3]_SLOT = 2
Channel 3
Slot 3 AIF1[TX4/RX4]_SLOT = 3
Channel 4
Figure 4-46. I2S Example
Fig. 4-47 shows an example of left-justified format. Six enabled channels are shown.
LRCLK
BCLK
TXDAT/
RXDAT
Slot 0
Slot 2
Slot 4
...
Slot 1
Slot 1 AIF1[TX3/RX3]_SLOT = 1
Slot 3 AIF1[TX4/RX4]_SLOT = 3
Channel 4
Channel 6
...
Slot 4 AIF1[TX2/RX2]_SLOT = 4
Channel 3
Channel 5
Slot 5
Slot 5 AIF1[TX1/RX1]_SLOT = 5
Channel 1
Channel 2
Slot 3
Slot 0 AIF1[TX5/RX5]_SLOT = 0
Slot 2 AIF1[TX6/RX6]_SLOT = 2
Figure 4-47. Left-Justified Example
128
DS1162F1
CS42L92
4.6 Digital Audio Interface
4.6.4
TDM Operation Between Three or More Devices
The AIF operation described in Section 4.6.3 illustrates how multiple audio channels can be interleaved on a single TXDAT
or RXDAT pin. The interface uses TDM to allocate time periods to each audio channel in turn.
This form of TDM is implemented between two devices, using the electrical connections shown Fig. 4-38 or Fig. 4-39.
It is also possible to implement TDM between three or more devices. This allows one codec to receive audio data from
two other devices simultaneously on a single audio interface, as shown in Fig. 4-48, Fig. 4-49, and Fig. 4-50.
The CS42L92 provides full support for TDM operation. The TXDAT pin can be tristated when not transmitting data, in order
to allow other devices to transmit on the same wire. The behavior of the TXDAT pin is configurable, to allow maximum
flexibility to interface with other devices in this way.
Typical configurations of TDM operation between three devices are shown in Fig. 4-48, Fig. 4-49, and Fig. 4-50.
BCLK
BCLK
CS42L92
CS42L92
or similar
CODEC
LRCLK
LRCLK
Processor
TXDAT
TXDAT
RXDAT
RXDAT
BCLK
LRCLK
TXDAT
RXDAT
Figure 4-48. TDM with CS42L92 as Master
DS1162F1
CS42L92
CS42L92
or similar
CODEC
Processor
BCLK
LRCLK
TXDAT
RXDAT
Figure 4-49. TDM with Other Codec as Master
129
CS42L92
4.7 Digital Audio Interface Control
BCLK
CS42L92
LRCLK
TXDAT
Processor
RXDAT
CS42L92
or similar
CODEC
BCLK
LRCLK
TXDAT
RXDAT
Figure 4-50. TDM with Processor as Master
4.7 Digital Audio Interface Control
This section describes the configuration of the CS42L92 digital audio interface paths.
Each AIF supports up to eight input signal paths and up to eight output signal paths. The digital audio interfaces can be
configured as master or slave interfaces; mixed master/slave configurations are also possible.
Each input and output signal path can be independently enabled or disabled. The AIF output (TX) and AIF input (RX) paths
use shared BCLK and LRCLK control signals.
The digital audio interface supports flexible data formats, selectable word length, configurable time-slot allocations, and
TDM tristate control.
The AIF1 and AIF3 interfaces provide full support for 32-bit data words (input and output). Audio data samples up to 32 bits
can be routed to the AIF1, AIF3, SLIMbus, S/PDIF, and DAC output paths. Note that other signal paths and
signal-processing blocks within the digital core are limited to 24-bit data length; data samples are truncated to 24-bit length
if they are routed through any function that does not support 32-bit data words.
The audio interfaces can be reconfigured while enabled, including changes to the LRCLK frame length and the channel
time-slot configurations. Care is required to ensure that any on-the-fly reconfiguration does not cause corruption to the
active signal paths. Wherever possible, it is recommended to disable all channels before changing the AIF configuration.
4.7.1
AIF Sample-Rate Control
The AIF RX inputs may be selected as input to the digital mixers or signal-processing functions within the CS42L92 digital
core. The AIF TX outputs are derived from the respective output mixers.
The sample rate for each digital audio interface AIFn is configured using the respective AIFn_RATE field—see Table 4-26.
Note that sample-rate conversion is required when routing the AIF paths to any signal chain that is asynchronous or
configured for a different sample rate.
130
DS1162F1
CS42L92
4.7 Digital Audio Interface Control
4.7.2
AIF Pin Configuration
The external connections associated with each digital audio interface (AIF) are implemented on multifunction GPIO pins,
which must be configured for the respective AIF functions when required. The AIF connections are pin-specific alternative
functions available on specific GPIO pins. See Section 4.14 to configure the GPIO pins for AIF operation.
Integrated pull-up and pull-down resistors can be enabled on the AIFnLRCLK, AIFnBCLK and AIFnRXDAT pins. This is
provided as part of the GPIO functionality, and provides a flexible capability for interfacing with other devices. Each pull-up
and pull-down resistor can be configured independently using the fields described in Table 4-93.
If the pull-up and pull-down resistors are both enabled, the CS42L92 provides a bus keeper function on the respective pin.
The bus-keeper function holds the logic level unchanged whenever the pin is undriven (e.g., if the signal is tristated).
4.7.3
AIF Master/Slave Control
The digital audio interfaces can operate in master or slave modes and also in mixed master/slave configurations. In Master
Mode, the BCLK and LRCLK signals are generated by the CS42L92 when any of the respective digital audio interface
channels is enabled. In Slave Mode, these outputs are disabled by default to allow another device to drive these pins.
Master Mode is selected on the AIFnBCLK pin by setting AIFn_BCLK_MSTR. In Master Mode, the AIFnBCLK signal is
generated by the CS42L92 when one or more AIFn channels is enabled.
If the AIFn_BCLK_FRC bit is set in BCLK Master Mode, the AIFnBCLK signal is output at all times, including when none
of the AIFn channels is enabled.
The AIFnBCLK signal can be inverted in master or slave modes using the AIFn_BCLK_INV bit.
Master Mode is selected on the AIFnLRCLK pin by setting AIFn_LRCLK_MSTR. In Master Mode, the AIFnLRCLK signal
is generated by the CS42L92 when one or more AIFn channels is enabled.
If AIFn_LRCLK_FRC is set in LRCLK Master Mode, the AIFnLRCLK signal is output at all times, including when none of
the AIFn channels is enabled. Note that AIFnLRCLK is derived from AIFnBCLK, and an internal or external AIFnBCLK
signal must be present to generate AIFnLRCLK.
The AIFnLRCLK signal can be inverted in master or slave modes using the AIFn_LRCLK_INV bit.
The timing of the AIFnLRCLK signal is selectable using AIFn_LRCLK_ADV. If this bit is set, the LRCLK signal transition
is advanced to the previous BCLK phase (as compared with the default behavior). Further details of this option, and
conditions for valid use cases, are described in Section 4.7.3.1.
The AIF1 master/slave control registers are described in Table 4-42.
Table 4-42. AIF1 Master/Slave Control
Register Address Bit
Label
R1280 (0x0500)
7 AIF1_
BCLK_INV
AIF1_BCLK_Ctrl
6 AIF1_
BCLK_FRC
5 AIF1_
BCLK_
MSTR
DS1162F1
Default
Description
0
AIF1 Audio Interface BCLK Invert
0 = AIF1BCLK not inverted
1 = AIF1BCLK inverted
0
AIF1 Audio Interface BCLK Output Control
0 = Normal
1 = AIF1BCLK always enabled in Master Mode
0
AIF1 Audio Interface BCLK Master Select
0 = AIF1BCLK Slave Mode
1 = AIF1BCLK Master Mode
131
CS42L92
4.7 Digital Audio Interface Control
Table 4-42. AIF1 Master/Slave Control (Cont.)
Register Address Bit
Label
R1282 (0x0502)
4 AIF1_
LRCLK_
AIF1_Rx_Pin_Ctrl
ADV
Default
Description
0
AIF1 Audio Interface LRCLK Advance
0 = Normal
1 = AIF1LRCLK transition is advanced to the previous BCLK phase
2 AIF1_
0
AIF1 Audio Interface LRCLK Invert
LRCLK_INV
0 = AIF1LRCLK not inverted
1 = AIF1LRCLK inverted
1 AIF1_
0
AIF1 Audio Interface LRCLK Output Control
LRCLK_
0 = Normal
FRC
1 = AIF1LRCLK always enabled in Master Mode
0 AIF1_
0
AIF1 Audio Interface LRCLK Master Select
LRCLK_
0 = AIF1LRCLK Slave Mode
MSTR
1 = AIF1LRCLK Master Mode
The AIF2 master/slave control registers are described in Table 4-43.
Table 4-43. AIF2 Master/Slave Control
Register Address Bit
Label
Default
Description
R1344 (0x0540)
7 AIF2_BCLK_
0
AIF2 Audio Interface BCLK Invert
INV
AIF2_BCLK_Ctrl
0 = AIF2BCLK not inverted
1 = AIF2BCLK inverted
6 AIF2_BCLK_
0
AIF2 Audio Interface BCLK Output Control
FRC
0 = Normal
1 = AIF2BCLK always enabled in Master Mode
5 AIF2_BCLK_
0
AIF2 Audio Interface BCLK Master Select
MSTR
0 = AIF2BCLK Slave Mode
1 = AIF2BCLK Master Mode
R1346 (0x0542)
4 AIF2_
0
AIF2 Audio Interface LRCLK Advance
LRCLK_ADV
AIF2_Rx_Pin_Ctrl
0 = Normal
1 = AIF2LRCLK transition is advanced to the previous BCLK phase
2 AIF2_
0
AIF2 Audio Interface LRCLK Invert
LRCLK_INV
0 = AIF2LRCLK not inverted
1 = AIF2LRCLK inverted
1 AIF2_
0
AIF2 Audio Interface LRCLK Output Control
LRCLK_FRC
0 = Normal
1 = AIF2LRCLK always enabled in Master Mode
0 AIF2_
0
AIF2 Audio Interface LRCLK Master Select
LRCLK_
0 = AIF2LRCLK Slave Mode
MSTR
1 = AIF2LRCLK Master Mode
The AIF3 master/slave control registers are described in Table 4-44.
Table 4-44. AIF3 Master/Slave Control
Register Address Bit
Label
Default
Description
R1408 (0x0580)
7 AIF3_BCLK_
0
AIF3 Audio Interface BCLK Invert
INV
AIF3_BCLK_Ctrl
0 = AIF3BCLK not inverted
1 = AIF3BCLK inverted
6 AIF3_BCLK_
0
AIF3 Audio Interface BCLK Output Control
FRC
0 = Normal
1 = AIF3BCLK always enabled in Master Mode
0
AIF3 Audio Interface BCLK Master Select
5 AIF3_BCLK_
MSTR
0 = AIF3BCLK Slave Mode
1 = AIF3BCLK Master Mode
132
DS1162F1
CS42L92
4.7 Digital Audio Interface Control
Table 4-44. AIF3 Master/Slave Control (Cont.)
Register Address Bit
Label
Default
Description
R1410 (0x0582)
4 AIF3_
0
AIF3 Audio Interface LRCLK Advance
LRCLK_ADV
AIF3_Rx_Pin_Ctrl
0 = Normal
1 = AIF3LRCLK transition is advanced to the previous BCLK phase
2 AIF3_
0
AIF3 Audio Interface LRCLK Invert
LRCLK_INV
0 = AIF3LRCLK not inverted
1 = AIF3LRCLK inverted
1 AIF3_
0
AIF3 Audio Interface LRCLK Output Control
LRCLK_FRC
0 = Normal
1 = AIF3LRCLK always enabled in Master Mode
0 AIF3_
0
AIF3 Audio Interface LRCLK Master Select
LRCLK_
0 = AIF3LRCLK Slave Mode
MSTR
1 = AIF3LRCLK Master Mode
4.7.3.1 LRCLK Advance
The timing of the AIFnLRCLK signal can be adjusted using AIFn_LRCLK_ADV. If this bit is set, the LRCLK signal transition
is advanced to the previous BCLK phase (as compared with the default behavior).
The LRCLK-advance option (AIFn_LRCLK_ADV = 1) is valid for DSP-A mode only, operating in Master Mode.
Note:
BCLK inversion must be enabled (AIFn_BCLK_INV = 1) if the LRCLK-advance option is enabled.
The adjusted interface timing (AIFn_LRCLK_ADV = 1), is shown in Fig. 4-51. The left-channel MSB is available on the
second rising edge of BCLK, 1.5 BCLK cycles after the LRCLK rising edge—assuming the BCLK output is inverted.
1/Fs
LRCLK
1.5 BCLK
BCLK
LEFT CHANNEL
RXDAT/
TXDAT
1
MSB
2
3
n-2
Input Word Length (WL)
RIGHT CHANNEL
n-1
n
1
2
3
n-2
n-1
n
LSB
Figure 4-51. LRCLK advance—DSP-A Master Mode
4.7.4
AIF Signal Path Enable
The AIF1–AIF3 interfaces support up to eight input (RX) channels and up to eight output (TX) channels. Each channel is
enabled or disabled using the bits defined in Table 4-45, Table 4-46 and Table 4-47.
The system clock, SYSCLK, must be configured and enabled before any audio path is enabled. The ASYNCCLK may also
be required, depending on the path configuration. See Section 4.16 for details of the system clocks.
The audio interfaces can be reconfigured if enabled, including changes to the LRCLK frame length and the channel
time-slot configurations. Care is required to ensure that this on-the-fly reconfiguration does not cause corruption to the
active signal paths. Wherever possible, it is recommended to disable all channels before changing the AIF configuration.
The CS42L92 performs automatic checks to confirm that the SYSCLK and ASYNCCLK frequencies are high enough to
support the commanded signal paths and processing functions. If the frequency is too low, an attempt to enable an AIF
signal path fails. Note that active signal paths are not affected under such circumstances.
DS1162F1
133
CS42L92
4.7 Digital Audio Interface Control
The AIF1 signal-path-enable bits are described in Table 4-45.
Table 4-45. AIF1 Signal Path Enable
Register Address
R1305 (0x0519)
AIF1_Tx_Enables
R1306 (0x051A)
AIF1_Rx_Enables
Bit
7
6
5
4
3
2
1
0
7
6
5
4
3
2
1
0
Label
AIF1TX8_ENA
AIF1TX7_ENA
AIF1TX6_ENA
AIF1TX5_ENA
AIF1TX4_ENA
AIF1TX3_ENA
AIF1TX2_ENA
AIF1TX1_ENA
AIF1RX8_ENA
AIF1RX7_ENA
AIF1RX6_ENA
AIF1RX5_ENA
AIF1RX4_ENA
AIF1RX3_ENA
AIF1RX2_ENA
AIF1RX1_ENA
Default
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Description
AIF1 Audio Interface TX Channel n Enable
0 = Disabled
1 = Enabled
AIF1 Audio Interface RX Channel n Enable
0 = Disabled
1 = Enabled
The AIF2 signal-path-enable bits are described in Table 4-46.
Table 4-46. AIF2 Signal Path Enable
Register Address
R1369 (0x0559)
AIF2_Tx_Enables
R1370 (0x055A)
AIF2_Rx_Enables
Bit
7
6
5
4
3
2
1
0
7
6
5
4
3
2
1
0
Label
AIF2TX8_ENA
AIF2TX7_ENA
AIF2TX6_ENA
AIF2TX5_ENA
AIF2TX4_ENA
AIF2TX3_ENA
AIF2TX2_ENA
AIF2TX1_ENA
AIF2RX8_ENA
AIF2RX7_ENA
AIF2RX6_ENA
AIF2RX5_ENA
AIF2RX4_ENA
AIF2RX3_ENA
AIF2RX2_ENA
AIF2RX1_ENA
Default
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Description
AIF2 Audio Interface TX Channel n Enable
0 = Disabled
1 = Enabled
AIF2 Audio Interface RX Channel n Enable
0 = Disabled
1 = Enabled
The AIF3 signal-path-enable bits are described in Table 4-47.
Table 4-47. AIF3 Signal Path Enable
Register Address
R1433 (0x0599)
AIF3_Tx_Enables
134
Bit
7
6
5
4
3
2
1
0
Label
AIF3TX8_ENA
AIF3TX7_ENA
AIF3TX6_ENA
AIF3TX5_ENA
AIF3TX4_ENA
AIF3TX3_ENA
AIF3TX2_ENA
AIF3TX1_ENA
Default
0
0
0
0
0
0
0
0
Description
AIF3 Audio Interface TX Channel n Enable
0 = Disabled
1 = Enabled
DS1162F1
CS42L92
4.7 Digital Audio Interface Control
Table 4-47. AIF3 Signal Path Enable (Cont.)
Register Address
R1434 (0x059A)
AIF3_Rx_Enables
4.7.5
Bit
7
6
5
4
3
2
1
0
Label
AIF3RX8_ENA
AIF3RX7_ENA
AIF3RX6_ENA
AIF3RX5_ENA
AIF3RX4_ENA
AIF3RX3_ENA
AIF3RX2_ENA
AIF3RX1_ENA
Default
0
0
0
0
0
0
0
0
Description
AIF3 Audio Interface RX Channel n Enable
0 = Disabled
1 = Enabled
AIF BCLK and LRCLK Control
The AIFnBCLK frequency is selected using the AIFn_BCLK_FREQ field. For each setting of this field, the actual frequency
depends on whether AIFn is configured for a 48-kHz-related sample rate, as described in Table 4-48 through Table 4-50.
•
If AIFn_RATE < 1000 (Table 4-26), AIFn is referenced to the SYSCLK clocking domain and the applicable
frequency depends upon the SAMPLE_RATE_1, SAMPLE_RATE_2 or SAMPLE_RATE_3 fields.
•
If AIFn_RATE 1000, AIFn is referenced to the ASYNCCLK clocking domain and the applicable frequency
depends upon the ASYNC_SAMPLE_RATE_1 or ASYNC_SAMPLE_RATE_2 fields.
The selected AIFnBCLK rate must be less than or equal to SYSCLK/2, or ASYNCCLK/2, as applicable. See Section 4.16
for details of SYSCLK and ASYNCCLK clock domains, and the associated control registers.
The AIFnLRCLK frequency is controlled relative to AIFnBCLK by the AIFn_BCPF divider.
Note that the BCLK rate must be configured in master and slave modes, using the AIFn_BCLK_FREQ fields. The LRCLK
rates only require to be configured in Master Mode.
The AIF1 BCLK/LRCLK control fields are described in Table 4-48.
Table 4-48. AIF1 BCLK and LRCLK Control
Register
Address
R1280
(0x0500)
AIF1_
BCLK_Ctrl
R1286
(0x0506)
AIF1_Rx_
BCLK_Rate
DS1162F1
Bit
Label
4:0 AIF1_
BCLK_
FREQ[4:0]
Default
Description
0x0C
AIF1BCLK Rate. The AIF1BCLK rate must be less than or equal to SYSCLK/2.
0x00–0x01 = Reserved
0x07 = 384 kHz (352.8 kHz)
0x0D = 3.072 MHz (2.8824 MHz)
0x02 = 64 kHz (58.8 kHz)
0x08 = 512 kHz (470.4 kHz)
0x0E = 4.096 MHz (3.7632 MHz)
0x03 = 96 kHz (88.2 kHz)
0x09 = 768 kHz (705.6 kHz)
0x0F = 6.144 MHz (5.6448 MHz)
0x04 = 128 kHz (117.6 kHz) 0x0A = 1.024 MHz (940.8 kHz)
0x10 = 8.192 MHz (7.5264 MHz)
0x05 = 192 kHz (176.4 kHz) 0x0B = 1.536 MHz (1.4112 MHz) 0x11 = 12.288 MHz (11.2896 MHz)
0x06 = 256 kHz (235.2 kHz) 0x0C = 2.048 MHz (1.8816 MHz) 0x12 = 24.576 MHz (22.5792 MHz)
The frequencies in brackets apply for 44.1 kHz–related sample rates only.
If AIF1_RATE < 1000, AIF1 is referenced to the SYSCLK clock domain. In this case, the
44.1 kHz–related frequencies apply if SAMPLE_RATE_n = 01XXX.
If AIF1_RATE 1000, AIF1 is referenced to the ASYNCCLK clock domain. In this case, the
44.1 kHz–related frequencies apply if ASYNC_SAMPLE_RATE_n = 01XXX.
12:0 AIF1_
0x0040 AIF1LRCLK Rate. Selects the number of BCLK cycles per AIF1LRCLK frame. AIF1LRCLK clock =
BCPF[12:0]
AIF1BCLK/AIF1_BCPF.
Integer (LSB = 1), Valid from 8 to 8191.
135
CS42L92
4.7 Digital Audio Interface Control
The AIF2 BCLK/LRCLK control fields are described in Table 4-49.
Table 4-49. AIF2 BCLK and LRCLK Control
Register
Address
R1344
(0x0540)
AIF2_
BCLK_Ctrl
Bit
Label
4:0 AIF2_
BCLK_
FREQ[4:0]
R1350
(0x0546)
AIF2_Rx_
BCLK_Rate
Default
Description
0x0C
AIF2BCLK Rate. The AIF2BCLK rate must be less than or equal to SYSCLK/2.
0x00–0x01 = Reserved
0x07 = 384 kHz (352.8 kHz)
0x0D = 3.072 MHz (2.8824 MHz)
0x02 = 64 kHz (58.8 kHz)
0x08 = 512 kHz (470.4 kHz)
0x0E = 4.096 MHz (3.7632 MHz)
0x03 = 96 kHz (88.2 kHz)
0x09 = 768 kHz (705.6 kHz)
0x0F = 6.144 MHz (5.6448 MHz)
0x04 = 128 kHz (117.6 kHz) 0x0A = 1.024 MHz (940.8 kHz)
0x10 = 8.192 MHz (7.5264 MHz)
0x05 = 192 kHz (176.4 kHz) 0x0B = 1.536 MHz (1.4112 MHz) 0x11 = 12.288 MHz (11.2896 MHz)
0x06 = 256 kHz (235.2 kHz) 0x0C = 2.048 MHz (1.8816 MHz) 0x12 = 24.576 MHz (22.5792 MHz)
The frequencies in brackets apply for 44.1 kHz–related sample rates only.
If AIF2_RATE < 1000, AIF2 is referenced to the SYSCLK clock domain. In this case, the
44.1 kHz–related frequencies apply if SAMPLE_RATE_n = 01XXX.
If AIF2_RATE 1000, AIF2 is referenced to the ASYNCCLK clock domain. In this case, the
44.1 kHz–related frequencies apply if ASYNC_SAMPLE_RATE_n = 01XXX.
12:0 AIF2_
0x0040 AIF2LRCLK Rate. Selects the number of BCLK cycles per AIF2LRCLK frame. AIF2LRCLK clock =
BCPF[12:0]
AIF2BCLK/AIF2_BCPF.
Integer (LSB = 1), Valid from 8 to 8191.
The AIF3 BCLK/LRCLK control fields are described in Table 4-50.
Table 4-50. AIF3 BCLK and LRCLK Control
Register
Address
R1408
(0x0580)
AIF3_
BCLK_Ctrl
Bit
4:0 AIF3_
BCLK_
FREQ[4:0]
R1414
(0x0586)
AIF3_Rx_
BCLK_Rate
4.7.6
Label
Default
Description
0x0C
AIF3BCLK Rate. The AIF3BCLK rate must be less than or equal to SYSCLK/2.
0x00–0x01 = Reserved
0x07 = 384 kHz (352.8 kHz)
0x0D = 3.072 MHz (2.8824 MHz)
0x02 = 64 kHz (58.8 kHz)
0x08 = 512 kHz (470.4 kHz)
0x0E = 4.096 MHz (3.7632 MHz)
0x03 = 96 kHz (88.2 kHz)
0x09 = 768 kHz (705.6 kHz)
0x0F = 6.144 MHz (5.6448 MHz)
0x04 = 128 kHz (117.6 kHz) 0x0A = 1.024 MHz (940.8 kHz)
0x10 = 8.192 MHz (7.5264 MHz)
0x05 = 192 kHz (176.4 kHz) 0x0B = 1.536 MHz (1.4112 MHz) 0x11 = 12.288 MHz (11.2896 MHz)
0x06 = 256 kHz (235.2 kHz) 0x0C = 2.048 MHz (1.8816 MHz) 0x12 = 24.576 MHz (22.5792 MHz)
The frequencies in brackets apply for 44.1 kHz–related sample rates only.
If AIF3_RATE < 1000, AIF3 is referenced to the SYSCLK clock domain. In this case, the
44.1 kHz–related frequencies apply if SAMPLE_RATE_n = 01XXX.
If AIF3_RATE 1000, AIF3 is referenced to the ASYNCCLK clock domain. In this case, the
44.1 kHz–related frequencies apply if ASYNC_SAMPLE_RATE_n = 01XXX.
12:0 AIF3_
0x0040 AIF3LRCLK Rate. Selects the number of BCLK cycles per AIF3LRCLK frame. AIF3LRCLK clock =
BCPF[12:0]
AIF3BCLK/AIF3_BCPF.
Integer (LSB = 1), Valid from 8 to 8191.
AIF Digital Audio Data Control
The fields controlling the audio data format, word length, and slot configurations for AIF1–AIF3 are described in Table 4-51
through Table 4-53 respectively.
Note that left-justified and DSP-B modes are valid in Master Mode only (i.e., BCLK and LRCLK are outputs from the
CS42L92).
The AIFn slot length is the number of BCLK cycles in one time slot within the overall LRCLK frame. The word length is the
number of valid data bits within each time slot. If the word length is less than the slot length, there are unused BCLK cycles
at the end of each time slot. The AIFn word length and slot length are independently selectable for the input (RX) and
output (TX) paths.
For each AIF input (RX) and AIF output (TX) channel, the position of the audio data sample within the LRCLK frame is
configurable. The x_SLOT fields define the time-slot position of the audio sample for the associated audio channel. Valid
selections are Slot 0 upwards. The time slots are numbered as shown in Fig. 4-44 through Fig. 4-47.
136
DS1162F1
CS42L92
4.7 Digital Audio Interface Control
Note that, in DSP modes, the time slots are ordered consecutively from the start of the LRCLK frame. In I2S and
left-justified modes, the even-numbered time slots are arranged in the first half of the LRCLK frame, and the odd-numbered
time slots are arranged in the second half of the frame.
The AIF1 data control fields are described in Table 4-51.
Table 4-51. AIF1 Digital Audio Data Control
Register Address
R1284 (0x0504)
AIF1_Format
Bit
2:0
R1287 (0x0507)
AIF1_Frame_Ctrl_1
13:8 AIF1TX_WL[5:0]
0x18
7:0
0x18
R1288 (0x0508)
AIF1_Frame_Ctrl_2
R1289 (0x0509)
to
R1296 (0x0510)
R1297 (0x0511)
to
R1304 (0x0518)
Label
AIF1_FMT[2:0]
AIF1TX_SLOT_
LEN[7:0]
Default
000
13:8 AIF1RX_WL[5:0]
0x18
7:0
AIF1RX_SLOT_
LEN[7:0]
0x18
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
AIF1TX1_SLOT[5:0]
AIF1TX2_SLOT[5:0]
AIF1TX3_SLOT[5:0]
AIF1TX4_SLOT[5:0]
AIF1TX5_SLOT[5:0]
AIF1TX6_SLOT[5:0]
AIF1TX7_SLOT[5:0]
AIF1TX8_SLOT[5:0]
AIF1RX1_SLOT[5:0]
AIF1RX2_SLOT[5:0]
AIF1RX3_SLOT[5:0]
AIF1RX4_SLOT[5:0]
AIF1RX5_SLOT[5:0]
AIF1RX6_SLOT[5:0]
AIF1RX7_SLOT[5:0]
AIF1RX8_SLOT[5:0]
0x0
0x1
0x2
0x3
0x4
0x5
0x6
0x7
0x0
0x1
0x2
0x3
0x4
0x5
0x6
0x7
Description
AIF1 Audio Interface Format
000 = DSP Mode A
001 = DSP Mode B
010 = I2S mode
011 = Left-Justified mode
Other codes are reserved.
AIF1 TX Word Length (Number of valid data bits per slot)
Integer (LSB = 1); Valid from 16 to 32
AIF1 TX Slot Length (Number of BCLK cycles per slot)
Integer (LSB = 1); Valid from 16 to 128
AIF1 RX Word Length (Number of valid data bits per slot)
Integer (LSB = 1); Valid from 16 to 32
AIF1 RX Slot Length (Number of BCLK cycles per slot)
Integer (LSB = 1); Valid from 16 to 128
AIF1 TX Channel n Slot position
Defines the TX time slot position of the Channel n audio sample
Integer (LSB=1); Valid from 0 to 63
AIF1 RX Channel n Slot position
Defines the RX time slot position of the Channel n audio sample
Integer (LSB=1); Valid from 0 to 63
The AIF2 data control fields are described in Table 4-52.
Table 4-52. AIF2 Digital Audio Data Control
Register Address
R1348 (0x0544)
AIF2_Format
Bit
2:0
R1351 (0x0547)
AIF2_Frame_Ctrl_1
13:8 AIF2TX_WL[5:0]
0x18
7:0
0x18
DS1162F1
Label
AIF2_FMT[2:0]
AIF2TX_SLOT_
LEN[7:0]
Default
000
Description
AIF2 Audio Interface Format
000 = DSP Mode A
001 = DSP Mode B
010 = I2S mode
011 = Left-Justified mode
Other codes are reserved.
AIF2 TX Word Length
(Number of valid data bits per slot)
Integer (LSB = 1); Valid from 16 to 32
AIF2 TX Slot Length
(Number of BCLK cycles per slot)
Integer (LSB = 1); Valid from 16 to 128
137
CS42L92
4.7 Digital Audio Interface Control
Table 4-52. AIF2 Digital Audio Data Control (Cont.)
Register Address
R1352 (0x0548)
AIF2_Frame_Ctrl_2
R1353 (0x0549)
to
R1360 (0x0550)
R1361 (0x0551)
to
R1368 (0x0558)
Bit
Label
13:8 AIF2RX_WL[5:0]
Default
0x18
7:0
AIF2RX_SLOT_
LEN[7:0]
0x18
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
AIF2TX1_SLOT[5:0]
AIF2TX2_SLOT[5:0]
AIF2TX3_SLOT[5:0]
AIF2TX4_SLOT[5:0]
AIF2TX5_SLOT[5:0]
AIF2TX6_SLOT[5:0]
AIF2TX7_SLOT[5:0]
AIF2TX8_SLOT[5:0]
AIF2RX1_SLOT[5:0]
AIF2RX2_SLOT[5:0]
AIF2RX3_SLOT[5:0]
AIF2RX4_SLOT[5:0]
AIF2RX5_SLOT[5:0]
AIF2RX6_SLOT[5:0]
AIF2RX7_SLOT[5:0]
AIF2RX8_SLOT[5:0]
0x0
0x1
0x2
0x3
0x4
0x5
0x6
0x7
0x0
0x1
0x2
0x3
0x4
0x5
0x6
0x7
Description
AIF2 RX Word Length
(Number of valid data bits per slot)
Integer (LSB = 1); Valid from 16 to 32
AIF2 RX Slot Length
(Number of BCLK cycles per slot)
Integer (LSB = 1); Valid from 16 to 128
AIF2 TX Channel n Slot position
Defines the TX time slot position of the Channel n audio sample
Integer (LSB=1); Valid from 0 to 63
AIF2 RX Channel n Slot position
Defines the RX time slot position of the Channel n audio sample
Integer (LSB=1); Valid from 0 to 63
The AIF3 data control fields are described in Table 4-53.
Table 4-53. AIF3 Digital Audio Data Control
Register Address
R1412 (0x0584)
AIF3_Format
Bit
2:0
R1415 (0x0587)
AIF3_Frame_Ctrl_1
13:8 AIF3TX_WL[5:0]
0x18
7:0
0x18
R1416 (0x0588)
AIF3_Frame_Ctrl_2
R1417 (0x0589)
to
R1424 (0x0590)
138
Label
AIF3_FMT[2:0]
AIF3TX_SLOT_
LEN[7:0]
Default
000
13:8 AIF3RX_WL[5:0]
0x18
7:0
AIF3RX_SLOT_
LEN[7:0]
0x18
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
AIF3TX1_SLOT[5:0]
AIF3TX2_SLOT[5:0]
AIF3TX3_SLOT[5:0]
AIF3TX4_SLOT[5:0]
AIF3TX5_SLOT[5:0]
AIF3TX6_SLOT[5:0]
AIF3TX7_SLOT[5:0]
AIF3TX8_SLOT[5:0]
0x0
0x1
0x2
0x3
0x4
0x5
0x6
0x7
Description
AIF3 Audio Interface Format
000 = DSP Mode A
001 = DSP Mode B
010 = I2S mode
011 = Left-Justified mode
Other codes are reserved.
AIF3 TX Word Length (Number of valid data bits per slot)
Integer (LSB = 1); Valid from 16 to 32
AIF3 TX Slot Length (Number of BCLK cycles per slot)
Integer (LSB = 1); Valid from 16 to 128
AIF3 RX Word Length (Number of valid data bits per slot)
Integer (LSB = 1); Valid from 16 to 32
AIF3 RX Slot Length (Number of BCLK cycles per slot)
Integer (LSB = 1); Valid from 16 to 128
AIF3 TX Channel n Slot position
Defines the TX time slot position of the Channel n audio sample
Integer (LSB=1); Valid from 0 to 63
DS1162F1
CS42L92
4.7 Digital Audio Interface Control
Table 4-53. AIF3 Digital Audio Data Control (Cont.)
Register Address
R1425 (0x0591)
to
R1432 (0x0598)
4.7.7
Bit
5:0
5:0
5:0
5:0
5:0
5:0
5:0
5:0
Label
AIF3RX1_SLOT[5:0]
AIF3RX2_SLOT[5:0]
AIF3RX3_SLOT[5:0]
AIF3RX4_SLOT[5:0]
AIF3RX5_SLOT[5:0]
AIF3RX6_SLOT[5:0]
AIF3RX7_SLOT[5:0]
AIF3RX8_SLOT[5:0]
Default
0x0
0x1
0x2
0x3
0x4
0x5
0x6
0x7
Description
AIF3 RX Channel n Slot position
Defines the RX time slot position of the Channel n audio sample
Integer (LSB=1); Valid from 0 to 63
AIF TDM and Tristate Control
The AIFn output pins are tristated when the AIFn_TRI bit is set. Note that this function only affects output pins configured
for the respective AIFn function—a GPIO pin that is configured for a different function is not affected by AIFn_TRI. See
Section 4.14 to configure the GPIO pins.
Under default conditions, the AIFnTXDAT output is held at Logic 0 when the CS42L92 is not transmitting data (i.e., during
time slots that are not enabled for output by the CS42L92). If the AIFnTX_DAT_TRI bit is set, the CS42L92 tristates the
respective AIFnTXDAT pin when not transmitting data, allowing other devices to drive the AIFnTXDAT connection.
The AIF1 TDM and tristate control fields are described in Table 4-54.
Table 4-54. AIF1 TDM and Tristate Control
Register Address
R1281 (0x0501)
AIF1_Tx_Pin_Ctrl
R1283 (0x0503)
AIF1_Rate_Ctrl
Bit
5
6
Label
Default
Description
AIF1TX_DAT_TRI
0
AIF1TXDAT Tristate Control
0 = Logic 0 during unused time slots
1 = Tristated during unused time slots
AIF1_TRI
0
AIF1 Audio Interface Tristate Control
0 = Normal
1 = AIF1 Outputs are tristated
Note that this bit only affects output pins configured for the respective AIF1 function.
The AIF2 TDM and tristate control fields are described in Table 4-55.
Table 4-55. AIF2 TDM and Tristate Control
Register Address
R1345 (0x0541)
AIF2_Tx_Pin_Ctrl
R1347 (0x0543)
AIF2_Rate_Ctrl
Bit
5
6
Label
Default
Description
AIF2TX_DAT_TRI
0
AIF2TXDAT Tristate Control
0 = Logic 0 during unused time slots
1 = Tristated during unused time slots
AIF2_TRI
0
AIF2 Audio Interface Tristate Control
0 = Normal
1 = AIF2 Outputs are tristated
Note that this bit only affects output pins configured for the respective AIF2 function.
The AIF3 TDM and tristate control fields are described in Table 4-56.
Table 4-56. AIF3 TDM and Tristate Control
Register Address
R1409 (0x0581)
AIF3_Tx_Pin_Ctrl
R1411 (0x0583)
AIF3_Rate_Ctrl
DS1162F1
Bit
5
6
Label
Default
Description
AIF3TX_DAT_TRI
0
AIF3TXDAT Tristate Control
0 = Logic 0 during unused time slots
1 = Tristated during unused time slots
AIF3_TRI
0
AIF3 Audio Interface Tristate Control
0 = Normal
1 = AIF3 Outputs are tristated
Note that this bit only affects output pins configured for the respective AIF3 function.
139
CS42L92
4.8 SLIMbus Interface
4.8 SLIMbus Interface
The SLIMbus protocol is highly configurable and adaptable, supporting multiple audio signal paths, and mixed sample
rates simultaneously. It also supports control messaging and associated communications between devices.
4.8.1
SLIMbus Devices
The SLIMbus components comprise different device classes (manager, framer, interface, generic). Each component on
the bus has an interface device, which provides bus management services for the respective component. One or more
components on the bus provide manager and framer device functions; the manager has the capabilities to administer the
bus, although the framer is responsible for driving the CLK line and for driving the DATA required to establish the frame
structure on the bus. Note that only one manager and one framer device is active at any time. The framer function can be
transferred between devices when required. Generic devices provide the basic SLIMbus functionality for the associated
ports, and for the transport protocol by which audio signal paths are established on the bus.
4.8.2
SLIMbus Frame Structure
The SLIMbus bit stream is formatted within a defined structure of cells, slots, subframes, frames, and superframes:
•
A single data bit is known as a cell.
•
Four cells make a slot.
•
A frame consists of 192 slots.
•
Eight frames make a superframe.
The bit stream structure is configurable to some extent, but the superframe definition always comprises 1536 slots. The
transmitted/received bit rate can be configured according to system requirements and can be changed dynamically without
interruption to active audio paths.
The SLIMbus CLK frequency (also the bus bit rate) is defined by a root frequency (RF) and a clock gear (CG). In the top
clock gear (Gear 10), the CLK frequency is equal to the root frequency. Each reduction in the clock gear halves the CLK
frequency, and doubles the duration of the superframe.
The SLIMbus bandwidth typically comprises control space (for bus messages, synchronization, etc.) and data space (for
audio paths). The precise allocation is configurable and can be entirely control space, if required.
The subframe definition comprises the number of slots per subframe (6, 8, 24 or 32) and the number of these slots per
subframe allocated as control space. The applicable combination of subframe length and control space width are defined
by the Subframe Mode (SM) parameter.
The SLIMbus frame always comprises 192 slots, regardless of the subframe definition. A number of slots are allocated to
control space, as noted above; the remaining slots are allocated to data space. Some of the control space is required for
framing information and for the guide channel (see Section 4.8.3); the remainder of the control space are allocated to the
message channel.
Multiline SLIMbus comprises one or more secondary data line, supporting additional bandwidth and flexibility for data
transfer over the bus. All data lines are synchronized to the bus clock; the RF and CG parameters are common to all data
lines. Note that control space is allocated on the primary data line only—secondary lines are used exclusively for data
space. Accordingly, the SM parameter is defined for the primary line only.
4.8.3
Control Space
Framing information is provided in slots 0 and 96 of every frame. Slot 0 contains a 4-bit synchronization code; slot 96
contains the 32-bit framing information, transmitted 4 bits at a time over the eight frames that make up the SLIMbus
superframe. The clock gear, root frequency, subframe configuration, along with some other parameters, are encoded
within the framing information.
140
DS1162F1
CS42L92
4.8 SLIMbus Interface
The guide channel occupies two slots within Frame 0. This provides the necessary information for a SLIMbus component
to acquire and verify the frame synchronization. The guide channel occupies the first two control space slots within the first
frame of the bit stream, excluding the framing information slots. Note that the exact slot allocation depends upon the
applicable subframe mode.
The message channel is allocated all of the control space not used by the framing information or the guide channel. The
message channel enables SLIMbus devices to communicate with each other, using a priority-based mechanism defined
in the MIPI specification.
Messages may be broadcast to all devices on the bus, or can be addressed to specific devices using their allocated logical
address (LA) or enumeration address (EA). Note that, device-specific messages are directed to a particular device (i.e.,
manager, framer, interface, or generic) within a component on the bus.
4.8.4
Data Space
The data space can be organized into a maximum of 256 data channels. Each channel, identified by a unique channel
number (CN), is a stream of one or more contiguous slots, organized in a consistent data structure that repeats at a fixed
interval.
A data channel is defined by its segment length (SL), (number of contiguous slots allocated), segment interval (spacing
between the first slots of successive segments), and segment offset (the slot number of the first allocated slot within the
superframe). The segment interval and segment offset are collectively defined by a segment distribution (SD), by which
the SLIMbus manager may configure or reconfigure any data channel.
Each segment may comprise TAG, AUX, and DATA portions. Any of these portions may have a length of zero; the exact
composition depends on the transport protocol (TP) for the associated channel. The DATA portion must be wide enough
to accommodate one full word of the data channel contents. Data words cannot be spread across multiple segments.
The segment interval for each data channel represents the minimum spacing between consecutive data samples for that
channel. (Note that the minimum spacing applies if every allocated segment is populated with new data; in many cases,
additional bandwidth is allocated and not every allocated segment is used.)
The segment interval gives rise to segment windows for each data channel, aligned to the start of every superframe. The
segment window boundaries define the times within which each new data sample must be buffered, ready for
transmission—adherence to these fixed boundaries allows slot allocations to be moved within a segment window, without
altering the signal latency. The segment interval may be either shorter or longer than the frame length, but there is always
an integer number of segment windows per superframe.
To transfer data between devices on the SLIMbus interface, a data channel connection is established between a source
and one or more destination (sink) ports. A unique port number (PN) address is defined for every active TX/RX port.
Multiple data channels can share the same port address by assigning different end point (EP) values to each channel.
The TP defines the flow control or handshaking method used by the ports associated with a data channel. The applicable
flow control modes depend on the relationship between the audio sample rate (flow rate) and the SLIMbus CLK frequency.
If the two rates are synchronized and integer related, no flow control is needed. In other cases, the flow may be regulated
by the use of a presence bit, which can be set by the source device (pushed protocol) or by the sink device (pulled
protocol).
The data-channel structure is defined in terms of the TP, SD, SL, and data line (LN) parameters. For multiline operation,
the LN value identifies the data line on which the channel is present. Note that the mapping of secondary data lines (1–7)
with respect to the secondary data pins is configurable on each multiline SLIMbus component, using value elements
associated with the respective interface device. See Section 4.9.3 for details of value elements.
The data-channel content definition includes a presence rate (PR) parameter (describing the nominal sample rate for the
audio channel) and a frequency locked (FL) bit (identifying whether the data source is synchronized to the SLIMbus CLK).
The data length (DL) parameter defines the size of each data sample (number of slots). The auxiliary bits format (AF) and
data type (DT) parameters provide support for non-PCM encoded data channels; the channel link (CL) parameter is an
indicator that channel CN is related to the previous channel, CN-1.
DS1162F1
141
CS42L92
4.9 SLIMbus Control Sequences
For a given root frequency and clock gear, the SL and SD parameters define the amount of SLIMbus bandwidth that is
allocated to a given data channel. The minimum bandwidth requirements of a data channel are represented by the
presence rate (PR) and data length (DL) parameters. The allocated SLIMbus bandwidth must be equal to or greater than
the bandwidth of the data to be transferred.
The segment interval defines the repetition rate of the SLIMbus slots allocated to consecutive data samples for a given
data channel. The presence rate (PR) is the nominal sample rate of the audio path. The segment rate (determined by the
segment interval value) must be equal to or greater than the presence rate for a given data channel. The following
constraints must be observed when configuring a SLIMbus channel:
•
If pushed or pulled transport protocol is selected, the segment rate must be greater than the presence rate to ensure
that samples are not dropped as a result of clock drift.
•
If isochronous transport protocol is selected, the segment rate must be equal to the presence rate. Isochronous
transport protocol should be selected only if the data source is frequency locked to the SLIMbus CLK (i.e., the data
source is synchronized to the SLIMbus framer device).
4.9 SLIMbus Control Sequences
This section describes the messages and general protocol associated with the SLIMbus system.
Note:
4.9.1
The SLIMbus specification permits flexibility in core message support for different components. See Section 4.10
for details regarding which messages are supported on each of the SLIMbus devices present on the CS42L92.
Device Management and Configuration
This section describes the SLIMbus messages associated with configuring all devices on the SLIMbus interface.
When the SLIMbus interface starts up, it is required that only one component provides the manager and framer device
functions. Other devices can request connection to the bus after they have gained synchronization.
The REPORT_PRESENT (DC, DCV) message may be issued by devices attempting to connect to the bus. The payload
of this message contains the device class (DC) and device class version (DCV) parameters, describing the type of device
that is attempting to connect. This message may be issued autonomously by the connecting device, or else in response
to a REQUEST_SELF_ANNOUNCEMENT message from the manager device.
After positively acknowledging the REPORT_PRESENT message, the manager device then issues the ASSIGN_
LOGICAL_ADDRESS (LA) message to allow the other device to connect to the bus. The payload of this message contains
the logical address (LA) parameter only; this is the unique address by which the connected device sends and receives
SLIMbus messages. The device is then said to be enumerated.
Once a device has been successfully connected to the bus, the logical address (LA) parameter can be changed at any
time using the CHANGE_LOGICAL_ADDRESS (LA) message.
The RESET_DEVICE message commands an individual SLIMbus device to perform its reset procedure. As part of the
reset, all associated ports are reset, and any associated data channels are canceled. Note that, if the RESET_DEVICE
command is issued to an interface device, it causes a component reset (i.e., all devices within the associated component
are reset). Under a component reset, every associated device releases its logical address, and the component becomes
disconnected from the bus.
4.9.2
Information Management
A memory map of information elements is defined for each device. This is arranged in 3 x 1-kB blocks, comprising core
value elements, device class-specific value elements, and user value elements respectively, as described in the MIPI
specification. Note that the contents of the user information portion for each CS42L92 SLIMbus device are reserved.
Read/write access is implemented using the messages described as follows. Specific elements within the information map
are identified using the element code (EC) parameter. In the case of read access, a unique transaction ID (TID) is assigned
to each message relating to a particular read/write request.
142
DS1162F1
CS42L92
4.9 SLIMbus Control Sequences
•
The REQUEST_INFORMATION (TID, EC) message is used to instruct a device to respond with the indicated
information. The payload of this message contains the transaction ID (TID) and the element code (EC).
•
The REQUEST_CLEAR_INFORMATION (TID, EC, CM) message is used to instruct a device to respond with the
indicated information, and also to clear all, or parts, of the same information slice. The payload of this message
contains the transaction ID (TID), element code (EC), and clear mask (CM). The clear mask field is used to select
which elements are to be cleared as part of the instruction.
•
The REPLY_INFORMATION (TID, IS) message is used to provide output of a requested parameter. The payload
of this message contains the transaction ID (TID) and the information slice (IS). The information slice bytes contain
the value of the requested parameter.
•
The CLEAR_INFORMATION (EC, CM) message is used to clear all, or parts, of the indicated information slice. The
payload of this message contains the element code (EC) and clear mask (CM). The clear mask field is used to select
which elements are to be cleared as part of the instruction.
•
The REPORT_INFORMATION (EC, IS) message is used to inform other devices about a change in a specified
element in the information map. The payload of this message contains the element code (EC) and the information
slice (IS). The information slice bytes contain the new value of the applicable parameter.
4.9.3
Value Management (Including Register Access)
A memory map of value elements is defined for each device. This is arranged in 3 x 1-kB blocks, comprising core value
elements, device class-specific value elements, and user value elements respectively, as described in the MIPI
specification. These elements are typically parameters used to configure device behavior.
The user value elements of the interface device are used on CS42L92 to support read/write access to the register map.
Details of how to access specific registers are described in Section 4.10. Note that, with the exception of the user value
elements of the interface device, the contents of the user value portion for each CS42L92 SLIMbus device are reserved.
Read/write access is implemented using the messages described as follows. Specific elements within the value map are
identified using the element code (EC) parameter. In the case of read access, a unique transaction ID (TID) is assigned
to each message relating to a particular read/write request.
•
The REQUEST_VALUE (TID, EC) message is used to instruct a device to respond with the indicated information.
The payload of this message contains the transaction ID (TID) and the element code (EC).
•
The REPLY_VALUE (TID, VS) message is used to provide output of a requested parameter. The payload of this
message contains the transaction ID (TID) and the value slice (VS). The value slice bytes contain the value of the
requested parameter.
•
The CHANGE_VALUE (EC, VU) message is used to write data to a specified element in the value map. The payload
of this message contains the element code (EC) and the value update (VU). The value update bytes contain the
new value of the applicable parameter.
4.9.4
Frame and Clocking Management
This section describes the SLIMbus messages associated with changing the frame or clocking configuration. One or more
configuration messages may be issued as part of a reconfiguration sequence; all of the updated parameters become
active at once, when the reconfiguration boundary is reached.
•
The BEGIN_RECONFIGURATION message is issued to define a reconfiguration boundary point: subsequent
NEXT_* messages become active at the first valid superframe boundary following receipt of the RECONFIGURE_
NOW message. (A valid boundary must be at least two slots after the end of the RECONFIGURE_NOW message.)
Both of these messages have no payload content.
•
The NEXT_ACTIVE_FRAMER (LAIF, NCo, NCi) message is used to select a new device as the active framer. The
payload of this message includes the logical address, incoming framer (LAIF). Two other fields (NCo, NCi) define
the number of clock cycles for which the CLK line shall be inactive during the handover.
•
The NEXT_SUBFRAME_MODE (SM) and NEXT_CLOCK_GEAR (CG) messages are used to reconfigure the
SLIMbus clocking or framing definition. The payload of each is the respective subframe mode (SM) or clock gear
(CG) respectively.
DS1162F1
143
CS42L92
4.10 SLIMbus Interface Control
•
The NEXT_PAUSE_CLOCK (RT) message instructs the active framer to pause the bus. The payload of the
message contains the restart time (RT), which indicates whether the interruption is to be of a specified time and/or
phase duration.
•
The NEXT_RESET_BUS message instructs all components on the bus to be reset. In this case, all devices on the
bus are reset and are disconnected from the bus. Subsequent reconnection to the bus follows the same process as
when the bus is first initialized.
•
The NEXT_SHUTDOWN_BUS message instructs all devices that the bus is to be shut down.
4.9.5
Data Channel Configuration
This section describes the SLIMbus messages associated with configuring a SLIMbus data channel. Note that the
manager device is responsible for allocating the available bandwidth as required for each data channel.
•
The CONNECT_SOURCE (PN, EP, CN) and CONNECT_SINK (PN, EP, CN) messages are issued to the
respective devices, defining the ports between which a data channel is to be established. The end point parameter
allows up to eight channels to share the same port number. Multiple destinations (sinks) can be configured for a
channel, if required. The payload of each message contains the port number (PN), end point (EP), and the channel
number (CN) parameters.
•
The BEGIN_RECONFIGURATION message is issued to define a Reconfiguration Boundary point: subsequent
NEXT_* messages become active at the first valid superframe boundary following receipt of the RECONFIGURE_
NOW message. A valid boundary must be at least two slots after the end of the RECONFIGURE_NOW message.
•
The NEXT_DEFINE_CHANNEL (CN, TP, SD, SL, LN) message informs the associated devices of the structure of
the data channel. The payload of this message contains the channel number (CN), TP, SD, SL, and LN parameters
for the data channel.
•
The NEXT_DEFINE_CONTENT (CN, FL, PR, AF, DT, CL, DL), or CHANGE_CONTENT (CN, FL, PR, AF, DT, CL,
DL) message provides more detailed information about the data channel contents. The payload of this message
contains the channel number (CN), frequency locked (FL), presence rate (PR), auxiliary bits format (AF), data type
(DT), channel link (CL), and data length (DL) parameters.
•
The NEXT_ACTIVATE_CHANNEL (CN) message instructs the channel to be activated at the next reconfiguration
boundary. The payload of this message contains the channel number (CN) only.
•
The RECONFIGURE_NOW message completes the reconfiguration sequence, causing all of the NEXT_
messages since the BEGIN_RECONFIGURATION to become active at the next valid superframe boundary. (A
valid boundary must be at least two slots after the end of the RECONFIGURE_NOW message.)
•
Active channels can be reconfigured using the CHANGE_CONTENT, NEXT_DEFINE_CONTENT, or NEXT_
DEFINE_CHANNEL messages. Note that these changes can be effected without interrupting the data channel; the
NEXT_DEFINE_CHANNEL, for example, may be used to change a segment distribution, in order to reallocate the
SLIMbus bandwidth.
•
An active channel can be paused using the NEXT_DEACTIVATE_CHANNEL message and reinstated using the
NEXT_ACTIVATE_CHANNEL message.
•
Data channels can be disconnected using the DISCONNECT_PORT or NEXT_REMOVE_CHANNEL messages.
These messages provide equivalent functionality, but use different parameters (PN or CN respectively) to identify
the affected signal path.
4.10 SLIMbus Interface Control
The CS42L92 features a MIPI-compliant SLIMbus interface. It supports multichannel audio input/output and control
register read/write access.
The SLIMbus interface on CS42L92 comprises a generic device, framer device, interface device, and 16 data ports,
providing up to 8 input (RX) channels and up to 8 output (TX) channels. Multiline capability is supported, offering additional
bandwidth and system-level flexibility.
The interface supports up to eight audio input channels and up to eight audio output channels. Mixed sample rates can be
supported simultaneously. The audio signal paths associated with the SLIMbus interface are described in Section 4.3.
144
DS1162F1
CS42L92
4.10 SLIMbus Interface Control
The SLIMbus interface also supports read/write access to the CS42L92 control registers via the value map of the interface
device, as described in Section 4.10.5.
The SLIMbus clocking rate and channel allocations are controlled by the manager device. The message channel and data
channel bandwidth may be dynamically adjusted according to the application requirements. Note that the manager device
functions are not implemented on the CS42L92, and these bandwidth allocation requirements are outside the scope of
this data sheet.
The SLIMbus interface provides full support for 32-bit data words (input and output). Audio data samples up to 32 bits can
be routed to the AIF1, AIF3, SLIMbus, S/PDIF, and DAC output paths. Note that other signal paths and signal-processing
blocks within the digital core are limited to 24-bit data length; data samples are truncated to 24-bit length if they are routed
through any function that does not support 32-bit data words.
4.10.1 SLIMbus Device Parameters
The SLIMbus interface on the CS42L92 comprises three devices. The enumeration address of each device within the
SLIMbus interface is derived from the parameters noted in Table 4-57.
Table 4-57. SLIMbus Device Parameters
Description
Generic
Framer
Interface
Manufacturer ID
0x01FA
0x01FA
0x01FA
Product Code
0x6371
0x6371
0x6371
Device ID
0x00
0x55
0x7F
Instance Value Enumeration Address
0x00
01FA_6371_0000
0x00
01FA_6371_5500
0x00
01FA_6371_7F00
4.10.2 SLIMbus Message Support
The SLIMbus interface on the CS42L92 supports bus messages as described in Table 4-58 and Table 4-59.
Table 4-58. SLIMbus Message Support
Category
Device Management
Messages
Data Channel
Management
Messages
Information
Management
Messages
DS1162F1
Message Code MC[6:0]
0x01
0x02
0x04
0x08
0x09
0x0C
0x0F
0x10
0x11
0x14
0x18
0x20
0x21
0x24
0x28
0x29
Description
REPORT_PRESENT (DC, DCV)
ASSIGN_LOGICAL_ADDRESS (LA)
RESET_DEVICE ()
CHANGE_LOGICAL_ADDRESS (LA)
CHANGE_ARBITRATION_PRIORITY (AP)
REQUEST_SELF_ANNOUNCEMENT ()
REPORT_ABSENT ()
CONNECT_SOURCE (PN, EP, CN)
CONNECT_SINK (PN, EP, CN)
DISCONNECT_PORT (PN)
CHANGE_CONTENT (CN, FL, PR, AF, DT, CL, DL)
REQUEST_INFORMATION (TID, EC)
REQUEST_CLEAR_INFORMATION (TID, EC, CM)
REPLY_INFORMATION (TID, IS)
CLEAR_INFORMATION (EC, CM)
REPORT_INFORMATION (EC, IS)
Generic
S
D
D
D
—
D
—
D
D
D
D
D
D
S
D
—
Framer
S
D
D
D
—
D
—
—
—
—
—
D
D
S
D
—
Interface
S
D
D
D
—
D
—
—
—
—
—
D
D
S
D
S
145
CS42L92
4.10 SLIMbus Interface Control
Table 4-58. SLIMbus Message Support (Cont.)
Category
Reconfiguration
Messages
Value Management
Messages
Message Code MC[6:0]
0x40
0x44
0x45
0x46
0x47
0x4A
0x4B
0x4C
0x50
0x51
0x54
0x55
0x58
0x5F
0x60
0x61
0x64
0x68
Description
Generic
BEGIN_RECONFIGURATION ()
D
NEXT_ACTIVE_FRAMER (LAIF, NCo, NCi)
—
NEXT_SUBFRAME_MODE (SM)
—
NEXT_CLOCK_GEAR (CG)
—
NEXT_ROOT_FREQUENCY (RF)
—
NEXT_PAUSE_CLOCK (RT)
—
NEXT_RESET_BUS ()
—
NEXT_SHUTDOWN_BUS ()
—
NEXT_DEFINE_CHANNEL (CN, TP, SD, SL, LN)
D
NEXT_DEFINE_CONTENT (CN, FL, PR, AF, DT, CL, DL)
D
NEXT_ACTIVATE_CHANNEL (CN)
D
NEXT_DEACTIVATE_CHANNEL (CN)
D
NEXT_REMOVE_CHANNEL (CN)
D
RECONFIGURE_NOW ()
D
REQUEST_VALUE (TID, EC)
—
REQUEST_CHANGE_VALUE (TID, EC, VU)
—
REPLY_VALUE (TID, VS)
—
CHANGE_VALUE (EC, VU)
—
Framer
D
D
D
D
D
D
D
D
—
—
—
—
—
D
—
—
—
—
Interface
D
—
D
—
—
—
—
—
—
—
—
—
—
D
D
—
S
D
Notes:
• S = Supported as a source device only.
• D = Supported as a destination device only.
The CS42L92 SLIMbus component must be reset prior to scheduling a hardware reset or power-on reset. This can be
achieved using the RESET_DEVICE message (issued to the CS42L92 interface device), or else using the NEXT_RESET_
BUS message.
Additional notes on specific SLIMbus parameters are described in Table 4-59.
Table 4-59. SLIMbus Parameter Support
Parameter Code
AF
CG
CL
CM
CN
DC
DCV
DL
DT
EC
EP
FL
IS
LA
LAIF
LN
NCi
NCo
146
Description
Auxiliary Bits Format
Clock Gear
Channel Link
Clear Mask
Comments
—
—
—
CS42L92 does not fully support this function. The CM bytes of the REQUEST_
CLEAR_INFORMATION or CLEAR_INFORMATION messages must not be
sent to CS42L92 Devices. When either of these messages is received, all bits
within the specified Information Slice are cleared.
Channel Number
—
Device Class
—
Device Class Variation
—
Data Length
—
Data Type
CS42L92 supports the following DT codes:
0x0 = Not indicated
0x1 = LPCM audio
Note that 2’s complement PCM can be supported with DT = 0x0.
Element Code
—
End Point
—
Frequency Locked
—
Information Slice
—
Logical Address
—
Logical Address, Incoming Framer
—
Data Line
All LN codes (0–7) are supported. The LN value must be equal to one of the
data lines that is mapped to one of the CS42L92 SLIMDATn pins.
The mapping of the secondary SLIMDATn pins onto the SLIMbus data lines is
configurable, using the value elements of the interface device. (Note that the
primary data pin, SLIMDAT1, is always mapped to SLIMbus data line DATA0.)
Number of Incoming Framer Clock Cycles —
Number of Outgoing Framer Clock Cycles —
DS1162F1
CS42L92
4.10 SLIMbus Interface Control
Table 4-59. SLIMbus Parameter Support (Cont.)
Parameter Code
Description
PN
Port Number
PR
Presence Rate
RF
Root Frequency
RT
Restart Time
SD
Segment Distribution
SL
Segment Length
SM
TID
TP
Subframe Mode
Transaction ID
Transport Protocol
VS
VU
Value Slice
Value Update
Comments
Note that the Port Numbers of the CS42L92 SLIMbus paths are
register-configurable, as described in Table 4-62.
Note that the Presence Rate must be the same as the sample rate selected for
the associated CS42L92 SLIMbus path.
CS42L92 supports the following RF codes as Active Framer:
0x1 = 24.576 MHz
0x2 = 22.5792 MHz
All codes are supported when CS42L92 is not the Active Framer.
CS42L92 supports the following RT codes:
0x0 = Fast Recovery
0x2 = Unspecified Delay
When either of these values is specified, the CS42L92 resumes toggling the
CLK line within four cycles of the CLK line frequency.
Note that any audio channels that are assigned the same SAMPLE_RATE_n or
ASYNC_SAMPLE_RATE_n value must also be assigned the same Segment
Interval.
Note that any active data channels that are assigned the same Port Number
must also be assigned the same Segment Length.
—
—
CS42L92 supports the following TP codes, according to the applicable audio
channel port:
Audio TX channel ports: 0x0 (Isochronous Protocol) or 0x1 (Pushed Protocol)
Audio RX channel ports: 0x0 (Isochronous Protocol) or 0x2 (Pulled Protocol)
Note that any active data channels that are assigned the same Port Number
must also be assigned the same Transport Protocol.
—
—
4.10.3 SLIMbus Clocking Control
The clock frequency of the SLIMbus interface is not fixed, and may be set according to the application requirements. The
clock frequency can be reconfigured dynamically as required.
The CS42L92 SLIMbus interface includes a framer device. When configured as the active framer, the SLIMbus clock
(SLIMCLK) is an output from the CS42L92. At other times, SLIMCLK is an input. The framer function can be transferred
from one device to another; this is known as framer handover, and is controlled by the manager device.
The supported root frequencies in active framer mode are 24.576 or 22.5792 MHz only. At other times, the supported root
frequencies are as defined in the MIPI Alliance specification for SLIMbus.
Under normal operating conditions, the SLIMbus interface operates with a fixed root frequency (RF); dynamic updates to
the bus rate are applied using a selectable clock gear (CG) function. The root frequency and the clock gear setting are
controlled by the manager device; these parameters are transmitted in every SLIMbus superframe to all devices on the
bus.
In Gear 10 (the highest clock gear setting), the SLIMCLK input (or output) frequency is equal to the root frequency. In lower
gears, the SLIMCLK frequency is reduced by increasing powers of 2.
The clock gear definition is shown in Table 4-60.
Note:
The 24.576MHz root frequency is an example only; other frequencies are also supported.
Table 4-60. SLIMbus Clock Gear Selection
Clock Gear
10
9
8
7
DS1162F1
Description
Divide by 1
Divide by 2
Divide by 4
Divide by 8
SLIMCLK Frequency 1
24.576 MHz
12.288 MHz
6.144 MHz
3.072 MHz
147
CS42L92
4.10 SLIMbus Interface Control
Table 4-60. SLIMbus Clock Gear Selection (Cont.)
Clock Gear
6
5
4
3
2
1
Description
Divide by 16
Divide by 32
Divide by 64
Divide by 128
Divide by 256
Divide by 512
SLIMCLK Frequency 1
1.536 MHz
768 kHz
384 kHz
192 kHz
96 kHz
48 kHz
1.Assuming 24.576-MHz root frequency
If the CS42L92 is the active framer, the SLIMCLK output is synchronized to the SYSCLK or ASYNCCLK system clock, as
selected by the SLIMCLK_SRC bit. The applicable system clock must be enabled and configured at the SLIMbus root
frequency, whenever the CS42L92 is the active framer.
If the CS42L92 is not the active framer, the SLIMCLK input can be used to provide a reference source for the FLLs. The
frequency of this reference is controlled using SLIMCLK_REF_GEAR, as described in Table 4-61.
The input clock reference for the FLLs is selected by using FLLn_REFCLK_SRC. If SLIMbus is selected as the clock
source, the reference signal is generated using an adaptive divider on the SLIMCLK input. The divider automatically
adapts to the SLIMbus clock gear (CG). If the clock gear on the bus is lower than the SLIMCLK_REF_GEAR, the selected
reference frequency cannot be supported, and the SLIMbus clock reference is disabled.
See Section 4.16 for details of system clocking and the FLLs.
Table 4-61. SLIMbus Clock Reference Control
Register Address
R1507 (0x05E3)
SLIMbus_Framer_
Ref_Gear
Bit
4
Label
SLIMCLK_SRC
Default
0
3:0
SLIMCLK_REF_
GEAR[3:0]
0x0
Description
SLIMbus Clock source
Selects the SLIMbus reference clock in Active Framer mode.
0 = SYSCLK
1 = ASYNCCLK
Note that the applicable clock must be enabled, and configured at the SLIMbus
Root Frequency, in Active Framer mode.
SLIMbus Clock Reference control. Sets the SLIMbus reference clock relative to
the SLIMbus Root Frequency (RF).
0x0 = Clock stopped
0x4 = Gear 4. (RF/64) 0x8 = Gear 8. (RF/4)
0x1 = Gear 1. (RF/512) 0x5 = Gear 5. (RF/32) 0x9 = Gear 9. (RF/2)
0x2 = Gear 2. (RF/256) 0x6 = Gear 6. (RF/16) 0xA = Gear 10. (RF)
0x3 = Gear 3. (RF/128) 0x7 = Gear 7. (RF/8) All other codes are reserved
4.10.4 SLIMbus Audio Channel Control
4.10.4.1 Port Number Control
The CS42L92 SLIMbus interface supports up to eight audio input (RX) channels and up to eight audio output (TX)
channels. The port number and end point number for each channel is configurable using the fields described in Table 4-62.
Table 4-62. SLIMbus Audio Port Number Control
Register Address
R1490 (0x05D2)
SLIMbus_RX_Ports0
R1491 (0x05D3)
SLIMbus_RX_Ports1
R1492 (0x05D4)
SLIMbus_RX_Ports2
R1493 (0x05D5)
SLIMbus_RX_Ports3
148
Bit
15:8
7:0
15:8
7:0
15:8
7:0
15:8
7:0
Label
SLIMRX2_PORT_ADDR[7:0]
SLIMRX1_PORT_ADDR[7:0]
SLIMRX4_PORT_ADDR[7:0]
SLIMRX3_PORT_ADDR[7:0]
SLIMRX6_PORT_ADDR[7:0]
SLIMRX5_PORT_ADDR[7:0]
SLIMRX8_PORT_ADDR[7:0]
SLIMRX7_PORT_ADDR[7:0]
Default
0x01
0x00
0x03
0x02
0x05
0x04
0x07
0x06
Description
SLIMbus RX Channel n Port number
Bits [7:5] specify the End Point (valid from
0–7). Bits [4:0] specify the Port Number
(valid from 0–31)
DS1162F1
CS42L92
4.10 SLIMbus Interface Control
Table 4-62. SLIMbus Audio Port Number Control (Cont.)
Register Address
R1494 (0x05D6)
SLIMbus_TX_Ports0
R1495 (0x05D7)
SLIMbus_TX_Ports1
R1496 (0x05D8)
SLIMbus_TX_Ports2
R1497 (0x05D9)
SLIMbus_TX_Ports3
Bit
15:8
7:0
15:8
7:0
15:8
7:0
15:8
7:0
Label
SLIMTX2_PORT_ADDR[7:0]
SLIMTX1_PORT_ADDR[7:0]
SLIMTX4_PORT_ADDR[7:0]
SLIMTX3_PORT_ADDR[7:0]
SLIMTX6_PORT_ADDR[7:0]
SLIMTX5_PORT_ADDR[7:0]
SLIMTX8_PORT_ADDR[7:0]
SLIMTX7_PORT_ADDR[7:0]
Default
0x09
0x08
0x0B
0x0A
0x0D
0x0C
0x0F
0x0E
Description
SLIMbus TX Channel n Port number
Valid from 0–31
Bits [7:5] specify the End Point (valid from
0–7). Bits [4:0] specify the Port Number
(valid from 0–31)
4.10.4.2 Sample-Rate Control
The SLIMbus audio inputs may be selected as input to the digital mixers or signal-processing functions within the CS42L92
digital core. The SLIMbus audio outputs are derived from the respective output mixers.
The sample rate for each SLIMbus channel is configured using SLIMRXn_RATE and SLIMTXn_RATE—see Table 4-26.
Note that the SLIMbus interface provides simultaneous support for SYSCLK-referenced and ASYNCCLK-referenced
sample rates on different channels. For example, 48-kHz and 44.1-kHz SLIMbus audio paths can be simultaneously
supported.
Sample-rate conversion is required when routing the SLIMbus paths to any signal chain that is asynchronous or configured
for a different sample rate.
4.10.4.3 Signal Path Enable
The SLIMbus interface supports up to eight audio input (RX) channels and up to eight audio output (TX) channels. Each
channel can be enabled or disabled using the fields defined in Table 4-63.
Note:
SLIMbus audio channels can be supported only when the corresponding ports have been enabled by the manager
device (i.e., in addition to setting the respective enable bits). The status bits in Registers R1527 and R1528
indicate the status of each SLIMbus port.
The system clock, SYSCLK, must be configured and enabled before any audio path is enabled. The ASYNCCLK may also
be required, depending on the path configuration. See Section 4.16 for details of the system clocks.
Table 4-63. SLIMbus Signal Path Enable
Register Address
R1525 (0x05F5)
SLIMbus_RX_
Channel_Enable
R1526 (0x05F6)
SLIMbus_TX_
Channel_Enable
DS1162F1
Bit
7
6
5
4
3
2
1
0
7
6
5
4
3
2
1
0
Label
SLIMRX8_ENA
SLIMRX7_ENA
SLIMRX6_ENA
SLIMRX5_ENA
SLIMRX4_ENA
SLIMRX3_ENA
SLIMRX2_ENA
SLIMRX1_ENA
SLIMTX8_ENA
SLIMTX7_ENA
SLIMTX6_ENA
SLIMTX5_ENA
SLIMTX4_ENA
SLIMTX3_ENA
SLIMTX2_ENA
SLIMTX1_ENA
Default
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Description
SLIMbus RX Channel n Enable
0 = Disabled
1 = Enabled
SLIMbus TX Channel n Enable
0 = Disabled
1 = Enabled
149
CS42L92
4.10 SLIMbus Interface Control
Table 4-63. SLIMbus Signal Path Enable (Cont.)
Register Address
R1527 (0x05F7)
SLIMbus_RX_
Port_Status
R1528 (0x05F8)
SLIMbus_TX_
Port_Status
Bit
7
6
5
4
3
2
1
0
7
6
5
4
3
2
1
0
Label
SLIMRX8_PORT_STS
SLIMRX7_PORT_STS
SLIMRX6_PORT_STS
SLIMRX5_PORT_STS
SLIMRX4_PORT_STS
SLIMRX3_PORT_STS
SLIMRX2_PORT_STS
SLIMRX1_PORT_STS
SLIMTX8_PORT_STS
SLIMTX7_PORT_STS
SLIMTX6_PORT_STS
SLIMTX5_PORT_STS
SLIMTX4_PORT_STS
SLIMTX3_PORT_STS
SLIMTX2_PORT_STS
SLIMTX1_PORT_STS
Default
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Description
SLIMbus RX Channel n Port Status
(Read only)
0 = Disabled
1 = Configured and active
SLIMbus TX Channel n Port Status
(Read only)
0 = Disabled
1 = Configured and active
4.10.5 SLIMbus Control Register Access
The SLIMbus interface supports read/write access to the CS42L92 control registers via the value map of the interface
device. Full read/write access to all registers is possible, via the user value elements portion of the value map.
Note that if multibyte transfers of more than 8 bytes are scheduled (see Section 4.10.5.3), system clocking constraints
must be observed to ensure control interface limits are not exceeded. Full details of the applicable clocking requirements
are provided in Section 4.16.7.
4.10.5.1 Control Register Write
Register write operations are implemented using the CHANGE_VALUE message. A maximum of two messages may be
required, depending on circumstances: the first CHANGE_VALUE message selects the register page (bits [23:8] of the
control register address); the second message contains the data and bits [7:0] of the register address. The first message
may be omitted if the register page is unchanged from the previous read or write operation.
The required SLIMbus parameters are described in Table 4-64 and Table 4-65, for the generic case of writing the value
0xVVVV to control register address 0xYYYYZZ. Note that it is also possible to write blocks of up to 16 bytes (to consecutive
register addresses), as described in Section 4.10.5.3.
Table 4-64. Register Write Message (1)—CHANGE_VALUE
Parameter
Source Address
0xSS
Value
Destination Address
0xLL
Access Mode
Byte Address
Slice Size
Value Update
0b1
0x800
0b001
0xYYYY
Description
SS is the 8-bit logical address of the message source. This could be any active device on the bus,
but is typically the manager device (0xFF).
LL is the 8-bit logical address of the message destination (i.e., the CS42L92 SLIMbus interface
device). The value is assigned by the SLIMbus manager device.
Selects byte-based access mode.
Identifies the user value element for selecting the control register page address.
Selects 2-byte slice size
YYYY is bits [23:8] of the applicable control register address.
Table 4-65. Register Write Message (2)—CHANGE_VALUE
Parameter
Source Address
0xSS
Destination Address
0xLL
Access Mode
0b1
150
Value
Description
SS is the 8-bit logical address of the message source. This could be any active device on the bus,
but is typically the manager device (0xFF).
LL is the 8-bit logical address of the message destination (i.e., the CS42L92 SLIMbus interface
device). The value is assigned by the SLIMbus manager device.
Selects byte-based access mode.
DS1162F1
CS42L92
4.10 SLIMbus Interface Control
Table 4-65. Register Write Message (2)—CHANGE_VALUE (Cont.)
Parameter
Byte Address
Value
0xUUU
Slice Size
Value Update
0b001
0xVVVV
Note:
Description
Specifies the value map address, calculated as
0xA00 + (2 x 0xZZ), where ZZ is bits [7:0] of the applicable control register address.
Selects 2-byte slice size
VVVV is the 16-bit data to be written.
The first message may be omitted if its contents are unchanged from the previous CHANGE_VALUE message
sent to the CS42L92.
4.10.5.2 Control Register Read
Register read operations are implemented using the CHANGE_VALUE and REQUEST_VALUE messages. A maximum
of two messages may be required, depending on circumstances: the CHANGE_VALUE message selects the register page
(bits [23:8] of the control register address); the REQUEST_VALUE message contains bits [7:0] of the register address.
The first message may be omitted if the register page is unchanged from the previous read or write operation.
The required SLIMbus parameters are described in Table 4-66 and Table 4-67, for the generic case of reading the
contents of control register address 0xYYYYZZ. Note that it is also possible to read blocks of up to 8 bytes (to consecutive
register addresses), as described in Section 4.10.5.3.
Table 4-66. Register Read Message (1)—CHANGE_VALUE
Parameter
Source Address
Value
0xSS
Description
SS is the 8-bit logical address of the message source. This could be any active device on the bus, but is
typically the manager device (0xFF).
Destination Address 0xLL
LL is the 8-bit logical address of the message destination (i.e., the CS42L92 SLIMbus interface device). The
value is assigned by the SLIMbus manager device.
Access Mode
0b1
Selects byte-based access mode.
Byte Address
0x800
Identifies the user value element for selecting the control register page address.
Slice Size
0b001 Selects 2-byte slice size
Value Update
0xYYYY YYYY is bits [23:8] of the applicable control register address.
Table 4-67. Register Read Message (2)—REQUEST_VALUE
Parameter
Source Address
Value
Description
0xSS
SS is the 8-bit logical address of the message source. This could be any active device on the bus, but is typically
the manager device (0xFF).
Destination Address 0xLL
LL is the 8-bit logical address of the message destination (i.e., the CS42L92 SLIMbus interface device). The
value is assigned by the SLIMbus manager device.
Access Mode
0b1
Selects byte-based access mode.
Byte Address
0xUUU Specifies the value map address, calculated as
0xA00 + (2 x 0xZZ), where ZZ is bits [7:0] of the applicable control register address.
Slice Size
0b001 Selects 2-byte slice size
Transaction ID
0xTTTT TTTT is the 16-bit transaction ID for the message. The value is assigned by the SLIMbus manager device.
Note:
The first message may be omitted if its contents are unchanged from the previous CHANGE_VALUE message
sent to the CS42L92.
The CS42L92 responds to the register read commands in accordance with the normal SLIMbus protocols.
Note that the CS42L92 assumes that sufficient control space slots are available in which to provide its response before
the next REQUEST_VALUE message is received. The CS42L92 response is made using a REPLY_VALUE message; the
SLIMbus manager should wait until the REPLY_VALUE message has been received before sending the next REQUEST_
VALUE message. If additional REQUEST_VALUE messages are received before the CS42L92 response has been made,
the earlier REQUEST_VALUE messages are ignored (i.e., only the last REQUEST_VALUE message is serviced).
4.10.5.3 Multibyte Control Register Access
Register data transfers of up to 16 bytes can be configured using the slice size parameter in the second message of the
applicable protocol (see Table 4-65 or Table 4-67). Additional value update words are appended to respective data
message in this case, with the applicable data contents.
DS1162F1
151
CS42L92
4.11 Output Signal Path
Multibyte register read/write access is supported with slice size of 2, 4, 8, 12, or 16 bytes. Note that if multibyte transfers
of more than 8 bytes are scheduled, system clocking constraints must be observed to ensure control interface limits are
not exceeded. See Section 4.16.7.
When a 2-byte transfer is selected, the register address 0xYYYYZZ is used (using the same naming conventions as
above). When more than 2 bytes are transferred, the register address is automatically incremented as described in
Table 4-68.
Table 4-68. SLIMbus Register Read/Write Sequence—16-Bit Register Space (< 0x3000)
Register Address
(30 k, may also be indicated using these
bits. Only valid when MICD1_ADC_MODE = 0.
0
Mic Detect 1 Data Valid
0 = Not Valid
1 = Valid
0
Mic Detect 1 Status
0 = Mic/accessory not detected
1 = Mic/accessory detected
Mic/accessory detection is assured for load impedance up to 30 k.
Only valid when MICD1_ADC_MODE = 0.
0x00 Mic Detect 1 ADC Level (Difference)
Only valid when MICD1_ADC_MODE = 1.
0x00
15
MICD2_ADC_
MODE
0
7:4
MICD2_SENSE_
SEL[3:0]
0001
2:0
MICD2_GND_
SEL[2:0]
000
Mic Detect 1 ADC Level
Only valid when MICD1_ADC_MODE = 1.
Mic Detect 2 Measurement Mode
0 = Discrete Mode
1 = ADC Mode
Mic Detect 2 Sense Select
1000 = MICDET5
0100 = HPDET1
0000 = MICDET1
1001 = JACKDET3
0101 = HPDET2
0001 = MICDET2
All other codes are
0110 = JACKDET1
0010 = MICDET3
reserved
0111 = JACKDET2
0011 = MICDET4
Mic Detect 2 Ground Select
000 = MICDET1/HPOUTFB1
011 = MICDET4/HPOUTFB4
001 = MICDET2/HPOUTFB2
100 = MICDET5/HPOUTFB5
010 = MICDET3/HPOUTFB3
All other codes are reserved
DS1162F1
CS42L92
4.12 External Accessory Detection
Table 4-87. Microphone Detect Control (Cont.)
Register Address Bit
Label
R691 (0x02B3)
15:12 MICD2_BIAS_
STARTTIME[3:0]
Mic_Detect_2_
Control_1
11:8 MICD2_
RATE[3:0]
7:4
MICD2_BIAS_
SRC[3:0]
1
MICD2_DBTIME
0
MICD2_ENA
R692 (0x02B4)
Mic_Detect_2_
Control_2
7:0
MICD2_LVL_
SEL[7:0]
R693 (0x02B5)
Mic_Detect_2_
Control_3
10:2 MICD2_LVL[8:0]
R699 (0x02BB)
Mic_Detect_2_
Control_4
1
MICD2_VALID
0
MICD2_STS
15:8 MICD2_
ADCVAL_
DIFF[7:0]
6:0 MICD2_
ADCVAL[6:0]
Default
Description
0001 Mic Detect 2 Bias Start-up Delay (Selects the delay time between enabling the
MICBIASnx reference and performing the MICDET function.)
0000 = 0 ms (continuous) 0101 = 4 ms
1010 = 128 ms
0110 = 8 ms
1011 = 256 ms
0001 = 0.25 ms
0010 = 0.5 ms
0111 = 16 ms
1100 = 512 ms
0011 = 1 ms
1000 = 32 ms
1101 = 24 ms
0100 = 2 ms
1001 = 64 ms
1110 to 1111 = 512 ms
0001 Mic Detect 2 Rate (Selects the delay between successive MICDET measurements.)
0000 = 0 ms (continuous)
0101 = 4 ms
1010 = 128 ms
0001 = 0.25 ms
0110 = 8 ms
1011 = 256 ms
0010 = 0.5 ms
0111 = 16 ms
1100 = 512 ms
1000 = 32 ms
1101 = 24 ms
0011 = 1 ms
0100 = 2 ms
1001 = 64 ms
1110 to 1111 = 512 ms
0000 Mic Detect 2 Reference Select
0000 = MICBIAS1A
0011 = MICBIAS1D
1111 = MICVDD
0001 = MICBIAS1B
0100 = MICBIAS2A
All other codes are
reserved
0010 = MICBIAS1C
0101 = MICBIAS2B
1
Mic Detect 2 Debounce
0 = 2 measurements
1 = 4 measurements
Only valid when MICD2_ADC_MODE = 0.
0
Mic Detect 2 Enable
0 = Disabled
1 = Enabled
1001_ Mic Detect 2 Level Select (enables mic/accessory detection in specific impedance ranges)
1111 [7] = Enable 1–30 k detection
[3] = Not used
[2] = Enable 360–680 detection
[6] = Not used
[5] = Not used
[1] = Enable 210–290 detection
[4] = Not used
[0] = Enable 110–180 detection
Only valid when MICD2_ADC_MODE = 0.
0_0000_ Mic Detect 2 Level (indicates the measured impedance)
0000 [8] = 1–30 k
[3] = 360–680
[2] = 210–290
[7] = Not used
[6] = Not used
[1] = 110–180
[0] = 0–70
[5] = Not used
[4] = Not used
Accessory detection is assured within the specified impedance limits. Note that other
impedance conditions, including loads >30 k, may also be indicated using these
bits. Only valid when MICD2_ADC_MODE = 0.
0
Mic Detect 2 Data Valid
0 = Not Valid
1 = Valid
0
Mic Detect 2 Status
0 = Mic/accessory not detected
1 = Mic/accessory detected
Mic/accessory detection is assured for load impedance up to 30 k.
Only valid when MICD2_ADC_MODE = 0.
0x00 Mic Detect 2 ADC Level (Difference)
Only valid when MICD2_ADC_MODE = 1.
0x00
Mic Detect 2 ADC Level
Only valid when MICD2_ADC_MODE = 1.
The external connections for the microphone detect circuit are shown in Fig. 4-61. In typical applications, it can be used
to detect a microphone or button press.
Note that, when using the microphone detect circuit, it is recommended to use the IN1ALx, IN1BLx, or IN1BR analog
microphone input paths to ensure best immunity to electrical transients arising from the external accessory.
DS1162F1
181
CS42L92
4.12 External Accessory Detection
Note that the IN1ALx, IN1BLx, or IN1BR analog mic
channels are recommended for use with the external
accessory detect function.
MICVDD
If measuring the impedance on a MICBIAS-powered
pin, one of the MICDETn inputs must always be used
as the sense pin, as shown.
MICBIAS1A
MICBIAS1B
MICBIAS1C
MICBIAS1D
LDO2
Regulator
MICBIAS2A
MICBIAS2B
Accessory-detect reference supply
selected by MICD1_BIAS_SRC (MICVDD or MICBIASnx)
2.2 k
(±2%)
External accessories
C
INnx
Analog Input
MICDETn
HPDETn
JACKDETn
Sense pin selected by
MICD1_SENSE_SEL
Accessory /
Button Detect
MICDETn
Button 2
Hookswitch
/ Button 1
Microphone
Ground pin selected
by MICD1_GND_SEL
Figure 4-61. Microphone- and Accessory-Detect Interface
4.12.3.2 MICBIAS Reference Control
The voltage reference for the microphone detection is configured using the MICDn_BIAS_SRC field, as described in
Table 4-87. The microphone detection function automatically enables the applicable reference when required for
impedance measurement.
If the selected reference (MICBIASxy) is not already enabled, the microphone detect circuit automatically enables the
respective MICBIAS output for short periods of time only, every time the impedance measurement is scheduled. To allow
time for the associated circuitry to stabilize, a time delay is applied before the measurement is performed; this is configured
using MICDn_BIAS_STARTTIME, as described in Table 4-87. If the measurement rate setting (MICDn_RATE) is greater
than 0x0, the delay (MICDn_BIAS_STARTTIME) should be set to 0.25 ms or more.
Note:
The microphone detection automatically enables the applicable MICBIASxy output switch, every time the
impedance measurement is scheduled. The respective MICBIAS generator (MICBIAS1 or MICBIAS2) is not
controlled automatically—the applicable generators must be enabled using the MICB1_ENA and MICB2_ENA
bits, as described in Table 4-124.
The timing of the microphone detect function is shown in Fig. 4-62. Two different cases are shown, according to whether
MICBIASxy is enabled periodically by the impedance measurement function, or is enabled at all times.
If the selected reference (MICBIASxy) is not enabled continuously, the respective MICBIASxy discharge bits should be
cleared. The MICBIAS control registers are described in Section 4.19.
182
DS1162F1
CS42L92
4.12 External Accessory Detection
MICBx_ENA = 1, MICBxy_ENA = 0:
MICBIASxy is enabled periodically for
measurement function
Measurement time
(100 s to 500 s)
time
MICDn_BIAS_STARTTIME
(0 ms to 512 ms; 0.25 ms default)
MICDn_RATE
(0 ms to 512 ms; 0.25 ms default)
MICBx_ENA = 1, MICBxy_ENA = 1:
MICBIASxy is enabled constantly
Measurement time
(100 s to 500 s)
time
MICDn_RATE
(0 ms to 512 ms; 0.25 ms default)
Figure 4-62. Microphone- and Accessory-Detect Timing
4.12.3.3 Measurement Range Control
When the discrete measurement mode is selected (MICDn_ADC_MODE = 0), the MICDn_LVL_SEL[7:0] bits allow each
impedance measurement level to be enabled or disabled independently. This allows the function to be tailored to the
particular application requirements.
If one or more bits within MICDn_LVL_SEL is cleared, the corresponding impedance level is disabled. Any measured
impedance which lies in a disabled level is reported as the next lowest, enabled level.
For example, the MICDn_LVL_SEL[2] bit enables the detection of a 360–680 impedance. If MICDn_LVL_SEL[2] = 0,
an external impedance in this range is indicated in the next lowest detection range (210–290 ); this would be reported in
the MICDn_LVL field as MICDn_LVL[2] = 1.
With default register configuration, and all measurement levels enabled, the CS42L92 can detect the presence of a typical
microphone and up to four push buttons. It is possible to configure the detection circuit for up to eight push buttons, by
adjusting the impedance detection thresholds. However, adjustment of the detection thresholds is outside the scope of
this data sheet—please contact your local Cirrus Logic representative for further information, if required.
The measurement time varies between 100–500 s, depending on the impedance of the external load, and depending on
how many impedance measurement levels are enabled. A high impedance is measured faster than a low impedance.
4.12.3.4 External Components
The external connections for the microphone detect circuit are shown in Fig. 4-61. Examples of suitable external
components are described in Section 5.1.7.
The accuracy of the microphone detect function is assured whenever the connected load is within the applicable limits
specified in Table 3-11. It is required that a 2.2-k (2%) resistor must also be connected between the measurement
(SENSE) pin and the selected MICBIAS reference—different resistor values lead to inaccuracy in the impedance
measurement.
Note that, for typical headset detection, the choice of external resistance values must take into account the impedance of
the microphone—the detected impedance corresponds to the combined parallel resistance of the microphone and any
asserted push button.
DS1162F1
183
CS42L92
4.12 External Accessory Detection
4.12.4 Headphone Detect
The CS42L92 headphone detection circuit measures the impedance of an external headphone load. This feature can be
used to set different gain levels or to apply other configuration settings according to the type of load connected. Separate
monitor pins are provided for headphone detection on the left and right channels of HPOUTn.
4.12.4.1 Headphone Detection Control
The headphone detection circuit measures the external impedance connected to the HPDETn pins. In typical usage, this
provides measurement of the load impedance on one or more of the headphone outputs (HPOUT1–4).
Note that impedance measurement is also possible via the MICDETn and JACKDETn pins, subject to some additional
constraints. If the measurement (sense) pin is connected to one of the headphone outputs, then HPDET1, HPDET2, or
JACKDET1 must always be used. The valid measurement range and the measurement accuracy are reduced, if using the
MICDETn or JACKDETn pins.
To configure the headphone detection circuit, the applicable pin connections for the intended measurement must be
written to the HPD_SENSE_SEL and HPD_GND_SEL fields. The headphone detection circuit measures the external
impedance between the pins selected by these two fields; the valid selections for each are defined in Table 4-90.
When measuring the load impedance on one the HPOUTn output paths, the HPD_GND_SEL selection should be the
same MICDETn/HPOUTFBn pin as the ground feedback pin for the applicable headphone output. See Section 4.11.8 to
configure the ground feedback pin for the HPOUTn outputs.
The HPD_FRC_SEL field must also be configured, to select where the measurement current is applied. As a general rule,
this should be the same as the HPD_SENSE_SEL pin. Other configurations can be used if required—for example, to
improve measurement accuracy in cases where the SENSE input path includes significant unwanted resistance.
Note:
There is no requirement for the SENSE and GND pin selections to be uniquely assigned between the microphone
detect and headphone detect functions—the same pin may be used as a SENSE or GND connection for more
than one of the detection functions. If multiple microphone/headphone detections are enabled, the respective
measurements are automatically scheduled in isolation to each other. See Section 4.12.3 for details of the
microphone detect function.
Headphone detection is commanded by writing 1 to HPD_POLL.
The impedance measurement range is configured using HPD_IMPEDANCE_RANGE. This field should be set in
accordance with the expected load impedance. Note that a number of separate measurements are typically required to
determine the load impedance; the recommended control requirements are described in Section 4.12.4.2.
Note:
Setting HPD_IMPEDANCE_RANGE is not required for detection on the MICDETn or JACKDETn pins. The
impedance measurement range, and measurement accuracy, in these cases are different to the HPDET1 and
HPDET2 measurements.
If headphone detection is performed using a measurement pin connected to one of the headphone outputs, the respective
output driver must be disabled before the measurement is commanded. The required settings are shown in Table 4-88.
Table 4-88. Output Configuration for Headphone Detect
Description
Requirement
HPOUT1L Impedance measurement
HPD_OVD_ENA = 1, HPD_OUT_SEL = 000, HP1L_ENA = 0
HPOUT1R Impedance measurement
HPD_OVD_ENA = 1, HPD_OUT_SEL = 001, HP1R_ENA = 0
HPOUT2L Impedance measurement
HPD_OVD_ENA = 1, HPD_OUT_SEL = 010, HP2L_ENA = 0
HPOUT2R Impedance measurement
HPD_OVD_ENA = 1, HPD_OUT_SEL = 011, HP2R_ENA = 0
HPOUT3L or HPOUT4L Impedance measurement
HPD_OVD_ENA = 1, HPD_OUT_SEL = 100, HP3L_ENA = 0
HPOUT3R or HPOUT4R Impedance measurement
HPD_OVD_ENA = 1, HPD_OUT_SEL = 101, HP3R_ENA = 0
Note: The applicable headphone outputs configuration must be maintained until after the headphone detection has
completed. See Table 4-71 for details of the HPnx_ENA bits.
If headphone detection is performed using a measurement pin that is not connected to one of the headphone outputs, the
HPD_OVD_ENA bit should be cleared.
184
DS1162F1
CS42L92
4.12 External Accessory Detection
If headphone detection is performed using a measurement pin that is also connected to one of the MICBIAS outputs, the
respective MICBIAS output must be disabled and floating (MICBnx_ENA = 0, MICBnx_DISCH = 0).
When headphone detection is commanded, the CS42L92 uses an adjustable current source to determine the connected
impedance. A sweep of measurement currents is applied. The rate of this sweep can be adjusted using HPD_CLK_DIV
and HPD_RATE.
4.12.4.2 Measurement Output
The headphone detection process typically comprises a number of separate measurements (for different impedance
ranges). Completion of each measurement is indicated by HPD_DONE. When this bit is set, the measurement result can
be read from the HPD_DACVAL field, and decoded as described in Eq. 4-3.
Impedance
C 0 + C 1 Offset
- – C5
= -----------------------------------------------------------------------------------------------------------------------------------------------------------------HPD_DACVAL + 0.5
1
– ------------------------------------------------------C2
C 3 1 + C 4 Gradient
Equation 4-3. Headphone Impedance Calculation
The associated parameters for decoding the measurement result are defined Table 4-89. The applicable values are
dependent on the HPD_IMPEDANCE_RANGE setting in each case. The Offset and Gradient values are derived from
register fields that are factory-calibrated for each device.
Table 4-89. Headphone Measurement Decode Parameters
Parameter
C0
C1
C2
C3
C4
C5
Offset
Gradient
HPD_IMPEDANCE_
RANGE = 00
1.007
–0.0072
4005
69.3
0.0055
0.6
HP_OFFSET_00
HP_GRADIENT_0X
HPD_IMPEDANCE_
RANGE = 01
1.007
–0.0072
7975
69.6
0.0055
0.6
HP_OFFSET_01
HP_GRADIENT_0X
HPD_IMPEDANCE_
RANGE = 10
9.744
–0.0795
7300
62.9
0.0055
0.6
HP_OFFSET_10
HP_GRADIENT_1X
HPD_IMPEDANCE_
RANGE = 11
100.684
–0.9494
7300
63.2
0.0055
0.6
HP_OFFSET_11
HP_GRADIENT_1X
Note that, to achieve the specified measurement accuracy, the above equation must be calculated to an accuracy of at
least 5 decimal places throughout.
The impedance measurement result is valid if 169 HPD_DACVAL 1019. (In case of any contradiction with the HPD_
IMPEDANCE_RANGE description, the HPD_DACVAL validity takes precedence.)
If the external impedance is entirely unknown (i.e., it could lie in any of the HPD_IMPEDANCE_RANGE regions), it is
recommended to test initially with HPD_IMPEDANCE_RANGE = 00. If the resultant HPD_DACVAL is < 169, the
impedance is higher than the selected measurement range, so the test should be scheduled again, after incrementing
HPD_IMPEDANCE_RANGE.
Each measurement is triggered by writing 1 to HPD_POLL. Completion of each measurement is indicated by HPD_DONE.
Note that, after HPD_DONE bit has been asserted, it remains asserted until the next measurement has been commanded.
Note:
A simpler, but less accurate, procedure for headphone impedance measurement is also supported, using the
HPD_LVL field. When the HPD_DONE bit is set, indicating completion of a measurement, the impedance can be
read directly from the HPD_LVL field, provided that the value lies within the range of the applicable HPD_
IMPEDANCE_RANGE setting.
Note that, for detection using the MICDETn or JACKDETn pins, the HPD_LVL field is the only supported
measurement output option. The HPD_IMPEDANCE_RANGE field is not valid for detection on the MICDETn or
JACKDETn pins. See Table 4-90 for further description of the HPD_LVL field.
The headphone detection function is an input to the interrupt control circuit and can be used to trigger an interrupt event
on completion of the headphone detection; see Section 4.15.
DS1162F1
185
CS42L92
4.12 External Accessory Detection
The fields associated with headphone detection are described in Table 4-90. The external circuit configuration is shown
Fig. 4-63.
Note that 32-bit register addressing is used from R12888 (0x3000) upwards; 16-bit format is used otherwise. The registers
noted in Table 4-90 contain a mixture of 16- and 32-bit register addresses.
Table 4-90. Headphone Detect Control
Register Address
R665 (0x0299)
Headphone_
Detect_0
Bit
15
Label
HPD_OVD_ENA
14:12 HPD_OUT_SEL[2:0]
186
Default
0
000
11:8
HPD_FRC_SEL[3:0]
0000
7:4
HPD_SENSE_SEL[3:0]
0000
2:0
HPD_GND_SEL[2:0]
000
Description
Headphone Detect Output Override Enable
This bit, when set, causes the HPD_OUT_SEL headphone output
channel to be automatically configured for headphone detection each
time headphone detection is scheduled. Note that the respective output
driver must also be disabled (HPnx_ENA = 0) for the duration of a
headphone output impedance measurement.
0 = Disabled
1 = Enabled
Headphone Detect Output Channel Select
000 = HPOUT1L
100 = HPOUT3L
001 = HPOUT1R
101 = HPOUT3R
010 = HPOUT2L
All other codes are reserved
011 = HPOUT2R
Headphone Detect Measurement Current Pin Select
0000 = MICDET1
0110 = JACKDET1
0001 = MICDET2
0111 = JACKDET2
0010 = MICDET3
1000 = MICDET5
0011 = MICDET4
1001 = JACKDET3
0100 = HPDET1
All other codes are reserved
0101 = HPDET2
Headphone Detect Sense Pin Select
0000 = MICDET1
0110 = JACKDET1
0111 = JACKDET2
0001 = MICDET2
0010 = MICDET3
1000 = MICDET5
0011 = MICDET4
1001 = JACKDET3
0100 = HPDET1
All other codes are reserved
0101 = HPDET2
Headphone Detect Ground Pin Select
000 = MICDET1/HPOUTFB1
011 = MICDET4/HPOUTFB4
001 = MICDET2/HPOUTFB2
100 = MICDET5/HPOUTFB5
010 = MICDET3/HPOUTFB3
All other codes are reserved
DS1162F1
CS42L92
4.12 External Accessory Detection
Table 4-90. Headphone Detect Control (Cont.)
Register Address
R667 (0x029B)
Headphone_
Detect_1
R668 (0x029C)
Headphone_
Detect_2
R669 (0x029D)
Headphone_
Detect_3
DS1162F1
Bit
Label
10:9 HPD_IMPEDANCE_
RANGE[1:0]
Default
00
4:3
HPD_CLK_DIV[1:0]
00
2:1
HPD_RATE[1:0]
00
0
HPD_POLL
0
15
HPD_DONE
0
14:0 HPD_LVL[14:0]
0x0000
9:0
0x000
HPD_DACVAL[9:0]
Description
Headphone Detect Range
00 = 4 to 30
01 = 8 to 100
10 = 100 to 1 k
11 = 1 k to 10 k
Only valid when HPD_SENSE_SEL = 0100 or 0101.
Headphone Detect Clock Rate (Selects the clocking rate of the
headphone detect adjustable current source. Decreasing the clock rate
gives a slower measurement time.)
00 = 32 kHz
01 = 16 kHz
10 = 8 kHz
11 = 4 kHz
Headphone Detect Sweep Rate
(Selects the step size between successive measurements. Increasing
the step size gives a faster measurement time.)
00 = 1
01 = 2
10 = 4
11 = Reserved
Headphone Detect Enable
Write 1 to start HP Detect function
Headphone Detect Status
0 = HP Detect not complete
1 = HP Detect done
Headphone Detect Level
LSB = 0.5
8 = 4 or less
9 = 4.5
10 = 5
11 = 5.5
…
20,000 = 10 k or more
For HPDET1 or HPDET2 measurement (HPD_SENSE_SEL = 0100 or
0101), HPD_LVL is valid from 4 to10 k, within the range selected by
HPD_IMPEDANCE_RANGE.
For other measurements, HPD_LVL is valid from 400 to 6 k only.
If HPD_LVL reports a value outside the valid range, the range should be
adjusted and the measurement repeated. A 0- result may be reported
if the measurement is less than the minimum value for the selected
range.
Headphone Detect Level (Coded as integer, LSB = 1).
See separate description for full decode information.
187
CS42L92
4.12 External Accessory Detection
Table 4-90. Headphone Detect Control (Cont.)
Register Address
Bit
Label
R131076
31:24 HP_OFFSET_11[7:0]
(0x20004)
OTP_HPDET_Cal_
1
23:16 HP_OFFSET_10[7:0]
15:8 HP_OFFSET_01[7:0]
7:0
R131078
(0x20006)
OTP_HPDET_Cal_
2
HP_OFFSET_00[7:0]
15:8 HP_GRADIENT_1X[7:0]
7:0
HP_GRADIENT_0X[7:0]
Default
Description
See
Headphone Detect Calibration field.
Footnote 1 Signed number, LSB = 0.25.
Range is –31.75 to +31.75.
Default value is factory-set per device.
See
Headphone Detect Calibration field.
Footnote 1 Signed number, LSB = 0.25.
Range is –31.75 to +31.75.
Default value is factory-set per device.
See
Headphone Detect Calibration field.
Footnote 1 Signed number, LSB = 0.25.
Range is –31.75 to +31.75.
Default value is factory-set per device.
See
Headphone Detect Calibration field.
Footnote 1 Signed number, LSB = 0.25.
Range is –31.75 to +31.75.
Default value is factory-set per device.
See
Headphone Detect Calibration field.
Footnote 1 Signed number, LSB = 0.25.
Range is –31.75 to +31.75.
Default value is factory-set per device.
See
Headphone Detect Calibration field.
Footnote 1 Signed number, LSB = 0.25.
Range is –31.75 to +31.75.
Default value is factory-set per device.
1. Default value is factory-set per device.
The external connections for the headphone detect circuit are shown in Fig. 4-63.
Note that the HPOUTFB ground connection should
be close to headset jack.
HPDETn
MICDETn
JACKDETn
If measuring the impedance on a headphone output
path, HPDET1, HPDET2, or JACKDET1 must be
used as the sense pin.
Sense pin selected by
HPD_SENSE_SEL
Measurement current pin
selected by HPD_FRC_SEL
(optional
series resistors)
HPOUT1L
HPOUT1R
MICDETn/HPOUTFBn
Ground feedback pin
selected by HP1_GND_SEL
Ground measurement pin
selected by HPD_GND_SEL
Figure 4-63. Headphone Detect Interface
Note that, where external resistors are connected in series with the headphone load, as shown, it is recommended that
the HPDETn connection is to the headphone side of the resistors. If the HPDETn connection is made to the CS42L92 end
of these resistors, this leads to a corresponding offset in the measured impedance.
Under default conditions, the measurement time varies between 17–244 ms, depending on the impedance of the external
load. A high impedance is measured faster than a low impedance.
188
DS1162F1
CS42L92
4.13 Low Power Sleep Configuration
4.13 Low Power Sleep Configuration
The CS42L92 supports a low-power Sleep Mode, in which most functions are disabled and power consumption is
minimized. The CS42L92 enters Sleep Mode when the DCVDD supply is removed. Note that the AVDD and DBVDD
supplies must be present throughout the Sleep Mode duration.
In Sleep Mode, the CS42L92 can generate an interrupt event in response to a change in voltage on the JACKDET1,
JACKDET2, or JACKDET3 pins. This enables a jack insertion event (or other digital logic transition) to be used to trigger
a wake-up of the CS42L92.
In Sleep Mode, the CS42L92 can provide an unregulated voltage output on the MICBIAS1A pin. This can be used to power
an external microphone during Sleep Mode—see Section 4.19.
The system clocks (SYSCLK, ASYNCCLK, DSPCLK) should be disabled before selecting Sleep Mode. The external clock
input (MCLKn) may also be stopped, if desired.
The functionality and control fields associated with Sleep Mode are supported via an internal always-on supply domain.
The always-on control registers are listed in Table 4-91. These fields are maintained (i.e., not reset) in Sleep Mode.
Note that the control interface is not supported in Sleep Mode; read/write access to the always-on registers is not possible.
Access to the register map using any of the control interfaces should be ceased before selecting Sleep Mode.
Table 4-91. Sleep Mode Always-On Control Registers
Register Address
Label
R710 (0x02C6)
MICD_CLAMP2_OVD
MICD_CLAMP2_MODE[2:0]
MICD_CLAMP1_OVD
MICD_CLAMP1_MODE[3:0]
R723 (0x02D3)
MICB1A_AOD_ENA
JD3_ENA
JD2_ENA
JD1_ENA
R6150 (0x1806)
MICD_CLAMP2_FALL_EINT1
MICD_CLAMP2_RISE_EINT1
JD3_FALL_EINT1
JD3_RISE_EINT1
MICD_CLAMP1_FALL_EINT1
MICD_CLAMP1_RISE_EINT1
JD2_FALL_EINT1
JD2_RISE_EINT1
JD1_FALL_EINT1
JD1_RISE_EINT1
R6214 (0x1846)
IM_MICD_CLAMP2_FALL_EINT1
IM_MICD_CLAMP2_RISE_EINT1
IM_JD3_FALL_EINT1
IM_JD3_RISE_EINT1
IM_MICD_CLAMP1_FALL_EINT1
IM_MICD_CLAMP1_RISE_EINT1
IM_JD2_FALL_EINT1
IM_JD2_RISE_EINT1
IM_JD1_FALL_EINT1
IM_JD1_RISE_EINT1
R6784 (0x1A80)
IM_IRQ1
IRQ_POL
IRQ_OP_CFG
R6864 (0x1AD0)
RESET_PU
RESET_PD
Reference
See Section 4.12
See Section 4.19
See Section 4.12
See Section 4.15
See Section 4.23
The always-on digital I/O pins are listed in Table 4-92. All other digital input pins have no effect in Sleep Mode; all other
digital output pins are undriven (floating).
DS1162F1
189
CS42L92
4.14 General-Purpose I/O
Note:
The INnx/DMICx connections are isolated from the CS42L92 circuits in Sleep Mode. This enables a microphone
that is connected to the CS42L92 to be used by another circuit while Sleep Mode is selected.
The IRQ output is normally deasserted in Sleep Mode. In Sleep Mode, the IRQ output can be asserted only in response
to the JACKDET1, JACKDET2, or JACKDET3 inputs. If the IRQ output is asserted in Sleep Mode, it can be deasserted
only after a wake-up transition.
Output drivers and bus keepers are disabled in Sleep Mode, for all pins not on the always-on domain; this means that the
logic level on these pins is undefined. If a defined logic state is required during Sleep Mode (e.g., as input to another
device), an external pull resistor may be required. If an external pull resistor is connected to a pin that also supports a bus
keeper function, the pull resistance should be chosen carefully, taking into account the resistance of the bus keeper. See
Section 4.14.1 for specific notes concerning the GPIO pins.
Table 4-92. Sleep Mode Always-On Digital Input/Output Pins
Pin Name
Description
Reference
IRQ
Interrupt Request output
See Section 4.15
JACKDET1
Jack Detect input 1
See Section 4.12
JACKDET2
Jack Detect input 2
JACKDET3
Jack Detect input 3
RESET
Digital Reset input (active low)
See Section 4.23
The always-on functionality includes the JD1, JD2, and JD3 control signals, which provide support for the low-power Sleep
Mode. The MICDET clamp status signal is also supported; this is controlled by a selectable logic function, derived from
JD1, JD2, or JD3.
The JD1, JD2, JD3, and MICDET clamp status signals are derived from the JACKDET1, JACKDET2, and JACKDET3
inputs, and can be used to trigger the interrupt controller.
•
The JD1, JD2, and JD3 signals are derived from the jack detect function (see Section 4.12). These inputs can be
used to trigger a response to a jack insertion or jack removal detection.
If these signals are enabled, the JD1, JD2, and JD3 signals indicate the status of the JACKDET1, JACKDET2, and
JACKDET3 input pins respectively. See Table 4-84 for details of the associated control fields.
•
The MICDET clamp status is controlled by the JD1, JD2, or JD3 signals (see Section 4.12). The configurable logic
provides flexibility in selecting the appropriate conditions for activating the MICDET clamp. The clamp status can
be used to trigger a response to a jack insertion or jack removal detection.
The MICDET clamp function is configured using MICD_CLAMP1_MODE and MICD_CLAMP2_MODE, as
described in Table 4-85. Note that, due to control logic that is shared between the two clamps, the option to control
both clamps in response to the JDn signals cannot be supported at the same time. It is assumed that a maximum
of one clamp is active at any time—the MICDET clamp status provides an indication for the active clamp only.
The interrupt functionality associated with these signals is part of the always-on functionality, enabling the CS42L92 to
provide indication of jack insertion or jack removal to the host processor in Sleep Mode; see Section 4.15.
Note that the JACKDETn inputs do not result in a wake-up transition directly; a wake-up transition only occurs by
reapplication of DCVDD. In a typical application, the JACKDETn inputs provide a signal to the applications processor, via
the IRQ output; if a wake-up transition is required, this is triggered by the applications processor enabling the DCVDD
supply.
4.14 General-Purpose I/O
The CS42L92 supports up to 16 GPIO pins, which can be assigned to application-specific functions. The GPIOs enable
interfacing and detection of external hardware and can provide logic outputs to other devices. The GPIO input functions
can be used to generate an interrupt (IRQ) event.
190
DS1162F1
CS42L92
4.14 General-Purpose I/O
There are 2 dedicated GPIO pins; the remaining 14 GPIOs are implemented as alternate functions to a pin-specific
capability. The GPIO and interrupt circuits support the following functions:
•
Pin-specific alternative functions for external interfaces (AIF, PDM)
•
Logic input/button detect (GPIO input)
•
Logic 1 and Logic 0 output (GPIO output)
•
Interrupt (IRQ) status output
•
Clock output
•
Frequency-locked loop (FLL) status output
•
FLL clock output
•
IEC-60958-3–compatible S/PDIF output
•
Pulse-width modulation (PWM) signal output
•
ASRC lock status
•
General-purpose timer status output
•
Event logger FIFO buffer status output
•
Alarm generator status output
•
Auxiliary PDM interface
Logic input and output (GPIO) can be supported in two different ways on the CS42L92. The standard mechanism
described in this section provides a comprehensive suite of options including input debounce, and selectable output drive
configuration. The DSP GPIO circuit is tailored towards more advanced requirements typically demanded by DSP software
features. The DSP GPIO functions are described in Section 4.5.4.
The CS42L92 also incorporates two general-purpose switches; these are analog switches, described in Section 4.14.18.
If the JTAG interface is enabled, the GPIO13–15 pins are configured as a JTAG interface that provides test and debug
access to the CS42L92. The respective GPIO configuration registers have no effect in this case, and the GPIO pins cannot
be assigned any other function. See Section 4.20 for details of the JTAG interface.
4.14.1 GPIO Control
For each GPIO, the selected function is determined by the GPn_FN field, where n identifies the GPIO pin (1–16). The pin
direction, set by GPn_DIR, must be set according to function selected by GPn_FN.
If a pin is configured as a GPIO input (GPn_DIR = 1, GPn_FN = 0x001), the logic level at the pin can be read from the
respective GPn_LVL bit. Note that GPn_LVL is not affected by the GPn_POL bit.
A debounce circuit can be enabled on any GPIO input, to avoid false event triggers. This is enabled on each pin by setting
the respective GPn_DB bit. The debounce circuit uses the 32-kHz clock, which must be enabled whenever input debounce
functions are required. The debounce time is configurable using the GP_DBTIME field. See Section 4.16 for further details
of the CS42L92 clocking configuration.
Each GPIO pin is an input to the interrupt control circuit and can be used to trigger an interrupt event. An interrupt event
is triggered on the rising and falling edges of the GPIO input. The associated interrupt bit is latched once set; it can be
polled at any time or used to control the IRQ signal. See Section 4.15 for details of the interrupt event handling.
Integrated pull-up and pull-down resistors are provided on each GPIO pin; these can be configured independently using
the GPn_PU and GPn_PD fields. When the pull-up and pull-down control bits are both enabled, the CS42L92 provides a
bus keeper function on the respective pin. The bus keeper function holds the logic level unchanged whenever the pin is
undriven (e.g., if the signal is tristated).
Note:
The bus keeper is enabled by default on all GPIO pins and, if not actively driven, may result in either a Logic 0 or
Logic 1 at the respective input on start-up. If an external pull resistor is connected (e.g., to control the logic level
in Sleep Mode), the chosen resistance should take account of the bus keeper resistance (see Table 3-10). A
strong pull resistor (e.g., 10 k) is required, if a specific start-up condition is to be forced by the external pull
component.
DS1162F1
191
CS42L92
4.14 General-Purpose I/O
If a pin is configured as a GPIO output (GPn_DIR = 0, GPn_FN = 0x001), its level can be set to Logic 0 or Logic 1 using
the GPn_LVL field. Note that the GPn_LVL bits are write-only when the respective GPIO pin is configured as an output.
If a pin is configured as an output (GPn_DIR = 0), the polarity can be inverted using the GPn_POL bit. When GPn_
POL = 1, the selected output function is inverted. In the case of logic level output (GPn_FN = 0x001), the external output
is the opposite logic level to GPn_LVL when GPn_POL = 1. Note that, if GPn_FN = 0x000 or 0x002, the GPn_POL bit has
no effect on the respective GPIO pin.
A GPIO output can be either CMOS driven or open drain. This is selected on each pin using the respective GPn_OP_CFG
bit. Note that if GPn_FN = 0x000 the GPn_OP_CFG bit has no effect on the respective GPIO pin—see Table 4-93 for
further details. If GPn_FN = 0x002, the respective pin output is CMOS.
The register fields that control the GPIO pins are described in Table 4-93.
Table 4-93. GPIO Control
Register Address
R5888 (0x1700)
GPIO1_CTRL_1
to
R5918 (0x171E)
GPIO16_CTRL1
192
Bit
15
Label
GPn_LVL
14
GPn_OP_CFG
13
GPn_DB
12
GPn_POL
9:0
GPn_FN[9:0]
Default
Description
See
GPIOn level. Write to this bit to set a GPIO output. Read from this bit to read GPIO
Footnote 2 input level.
For output functions only, if GPn_POL is set, the GPn_LVL bit is the opposite logic
level to the external pin.
Note that, if GPn_DIR = 0, the GPn_LVL bit is write-only.
0
GPIOn Output Configuration
0 = CMOS
1 = Open drain
Note that, if GPn_FN = 0x000 or 0x002, this bit has no effect on the GPIOn output.
If GPn_FN = 0x000, the pin configuration is set according to the applicable
pin-specific function (see Table 4-95). If GPn_FN = 0x002, the pin configuration is
CMOS.
1
GPIOn Input Debounce
0 = Disabled
1 = Enabled
0
GPIOn Output Polarity Select
0 = Noninverted (Active High)
1 = Inverted (Active Low)
Note that, if GPn_FN = 0x000 or 0x002, this bit has no effect on the GPIOn output.
0x001 GPIOn Pin Function
(see Table 4-94 for details)
DS1162F1
CS42L92
4.14 General-Purpose I/O
Table 4-93. GPIO Control (Cont.)
Register Address
R5889 (0x1701)
GPIO1_CTRL_2
to
R5919 (0x171F)
GPIO16_CTRL2
Bit
15
Label
GPn_DIR
Default
1
Description
GPIOn Pin Direction
0 = Output
1 = Input
Note that, if GPn_FN = 0x000 or 0x002, this bit has no effect on the GPIOn pin. If
GPn_FN = 0x000, the pin direction is set according to the applicable pin-specific
function (see Table 4-95). If GPn_FN = 0x002, the pin direction is set according to
the DSP GPIO configuration.
14 GPn_PU
1
GPIOn Pull-Up Enable
0 = Disabled
1 = Enabled
Note: If GPn_PD and GPn_PU are both set, a bus keeper function is enabled on
the respective GPIOn pin.
13 GPn_PD
1
GPIOn Pull-Down Enable
0 = Disabled
1 = Enabled
Note: If GPn_PD and GPn_PU are both set, a bus keeper function is enabled on
the respective GPIOn pin.
R6848 (0x1AC0)
3:0 GP_DBTIME[3:0]
0x0
GPIO Input debounce time
GPIO_Debounce_
0x0 = 100 s
Config
0x1 = 1.5 ms
0x2 = 3 ms
0x3 = 6 ms
0x4 = 12 ms
0x5 = 24 ms
0x6 = 48 ms
0x7 = 96 ms
0x8 = 192 ms
0x9 = 384 ms
0xA = 768 ms
0xB to 0xF = Reserved
1. n is a number (1–16) that identifies the individual GPIO.
2. The default value of GPn_LVL depends upon whether the pin is actively driven by another device. If the pin is actively driven, the bus keeper
maintains this logic level. If the pin is not actively driven, the bus keeper may establish either a Logic 1 or Logic 0 as the initial input level.
4.14.2 GPIO Function Select
The available GPIO functions are described in Table 4-94. The function of each GPIO is set using GPn_FN, where n
identifies the GPIO pin (1–16). Note that the respective GPn_DIR must also be set according to whether the function is an
input or output.
Table 4-94. GPIO Function Select
GPn_FN
Valid On
0x000 GPIO3–16 only
0x001
All GPIOs (1–16)
0x002
0x003
All GPIOs (1–16)
All GPIOs (1–16)
0x004
All GPIOs (1–16)
0x010
0x011
GPIO1–4 only
GPIO1–4 only
DS1162F1
Description
Pin-specific alternate function
Comments
Alternate functions supporting digital microphone, digital audio
interface, master control interface, and PDM output functions.
Button-detect input/logic-level output GPn_DIR = 0: GPIO pin logic level is set by GPn_LVL.
GPn_DIR = 1: Button detect or logic level input.
DSP GPIO
Low latency input/output for DSP functions.
IRQ1 output
Interrupt (IRQ1) output
0 = IRQ1 not asserted
1 = IRQ1 asserted
IRQ2 output
Interrupt (IRQ2) output
0 = IRQ2 not asserted
1 = IRQ2 asserted
FLL1 clock
Clock output from FLL1
FLL2 clock
Clock output from FLL2
193
CS42L92
4.14 General-Purpose I/O
Table 4-94. GPIO Function Select (Cont.)
GPn_FN
Valid On
0x018 GPIO1–4 only
Description
FLL1 lock
0x019
GPIO1–4 only
FLL2 lock
0x040
0x041
0x048
0x049
0x04C
0x088
GPIO1–4 only
GPIO1–4 only
All GPIOs (1–16)
All GPIOs (1–16)
All GPIOs (1–16)
GPIO1–4 only
OPCLK clock output
OPCLK async clock output
PWM1 output
PWM2 output
S/PDIF output
ASRC1 IN1 lock
0x089
GPIO1–4 only
ASRC1 IN2 lock
0x140
All GPIOs (1–16)
Timer 1 status
0x150
GPIO1–4 only
Event Log 1 FIFO not-empty status
0x230
All GPIOs (1–16)
Alarm 1 Channel 1 status
0x231
All GPIOs (1–16)
Alarm 1 Channel 2 status
0x232
All GPIOs (1–16)
Alarm 1 Channel 3 status
0x233
All GPIOs (1–16)
Alarm 1 Channel 4 status
0x280
0x281
GPIO3 or GPIO10
GPIO4 or GPIO9
Auxiliary PDM clock input/output
Auxiliary PDM data output
Comments
Indicates FLL1 lock status
0 = Not locked
1 = Locked
Indicates FLL2 lock status
0 = Not locked
1 = Locked
Configurable clock output derived from SYSCLK
Configurable clock output derived from ASYNCCLK
Configurable PWM output PWM1
Configurable PWM output PWM2
IEC-60958-3–compatible S/PDIF output
Indicates ASRC1 IN1 Lock status
(ASRC IN1 paths convert from the ASRC1_RATE1 sample rate to the
ASRC1_RATE2 sample rate.)
0 = Not locked
1 = Locked
Indicates ASRC1 IN2 Lock status
(ASRC IN2 paths convert from the ASRC1_RATE2 sample rate to the
ASRC1_RATE1 sample rate.)
0 = Not locked
1 = Locked
Timer 1 Status
A pulse is output after the respective timer reaches its final count value.
Event Log 1 FIFO Not-Empty status
0 = FIFO Empty
1 = FIFO Not Empty
Alarm 1 Channel 1 Status
A pulse is output when the respective alarm-trigger conditions are met.
The pulse duration is configurable.
Alarm 1 Channel 2 Status
A pulse is output when the respective alarm-trigger conditions are met.
The pulse duration is configurable.
Alarm 1 Channel 3 Status
A pulse is output when the respective alarm-trigger conditions are met.
The pulse duration is configurable.
Alarm 1 Channel 4 Status
A pulse is output when the respective alarm-trigger conditions are met.
The pulse duration is configurable.
Auxiliary PDM interface clock
Auxiliary PDM interface data
4.14.3 Pin-Specific Alternate Function—GPn_FN = 0x000
The CS42L92 provides two dedicated GPIO pins (1–2). The remaining 14 GPIOs are multiplexed with the pin-specific
functions listed in Table 4-95. The alternate functions are selected by setting the respective GPn_FN fields to 0x000, as
described in Section 4.14.1. Note that each function is unique to the associated pin and can be supported only on that pin.
If the alternate function is selected on a GPIO pin, the pin direction (input or output) and the output driver configuration
(CMOS or open drain) are set automatically as described in Table 4-95. The respective GPn_DIR and GPn_OP_CFG bits
have no effect in this case.
Table 4-95. GPIO Alternate Functions
Name
AIF1BCLK/GPIO6
AIF1LRCLK/GPIO8
AIF1RXDAT/GPIO7
194
Condition
GP6_FN = 0x000
GP8_FN = 0x000
GP7_FN = 0x000
Description
Direction
Audio Interface 1 bit clock
Digital I/O
Audio Interface 1 left/right clock
Digital I/O
Audio Interface 1 RX digital audio data Digital input
Output Driver
Configuration
CMOS
CMOS
—
DS1162F1
CS42L92
4.14 General-Purpose I/O
Table 4-95. GPIO Alternate Functions (Cont.)
Name
AIF1TXDAT/GPIO5
AIF2BCLK/GPIO10
AIF2LRCLK/GPIO12
AIF2RXDAT/GPIO11
AIF2TXDAT/GPIO9
AIF3BCLK/GPIO14
AIF3LRCLK/GPIO16
AIF3RXDAT/GPIO15
AIF3TXDAT/GPIO13
SPKCLK/GPIO3
SPKDAT/GPIO4
Condition
GP5_FN = 0x000
GP10_FN = 0x000
GP12_FN = 0x000
GP11_FN = 0x000
GP9_FN = 0x000
GP14_FN = 0x000
GP16_FN = 0x000
GP15_FN = 0x000
GP13_FN = 0x000
GP3_FN = 0x000
GP4_FN = 0x000
Description
Audio Interface 1 TX digital audio data
Audio Interface 2 bit clock
Audio Interface 2 left/right clock
Audio Interface 2 RX digital audio data
Audio Interface 2 TX digital audio data
Audio Interface 3 bit clock
Audio Interface 3 left/right clock
Audio Interface 3 RX digital audio data
Audio Interface 3 TX digital audio data
Digital speaker (PDM) clock
Digital speaker (PDM) data
Direction
Digital output
Digital I/O
Digital I/O
Digital input
Digital output
Digital I/O
Digital I/O
Digital input
Digital output
Digital output
Digital output
Output Driver
Configuration
CMOS
CMOS
CMOS
—
CMOS
CMOS
CMOS
—
CMOS
CMOS
CMOS
Note that if the JTAG interface is enabled, the GPIO13–15 pins are configured as a JTAG interface. Under these
conditions, the respective GPIO configuration registers have no effect, and the GPIO pins cannot be assigned any other
function. See Section 4.20 for details of the JTAG interface.
4.14.4 Button Detect (GPIO Input)—GPn_FN = 0x001
Button-detect functionality can be selected on a GPIO pin by setting the respective GPIO fields as described in
Section 4.14.1. The same functionality can be used to support a jack-detect input function.
It is recommended to enable the GPIO input debounce feature when using GPIOs as button input or jack-detect input.
The GPn_LVL fields may be read to determine the logic levels on a GPIO input, after the selectable debounce controls.
Note that GPn_LVL is not affected by the GPn_POL bit.
The debounced GPIO signals are also inputs to the interrupt-control circuit. An interrupt event is triggered on the rising
and falling edges of the GPIO input. The associated interrupt bits are latched once set; they can be polled at any time or
used to control the IRQ signal. See Section 4.15 for details of the interrupt event handling.
4.14.5 Logic 1 and Logic 0 Output (GPIO Output)—GPn_FN = 0x001
The CS42L92 can be programmed to drive a logic high or logic low level on a GPIO pin by selecting the GPIO Output
function as described in Section 4.14.1.
The output logic level is selected using the respective GPn_LVL bit. Note that, if a GPIO pin is configured as an output,
the respective GPn_LVL bits are write-only.
The polarity of the GPIO output can be inverted using the GPn_POL bits. If GPn_POL = 1, the external output is the
opposite logic level to GPn_LVL.
4.14.6 DSP GPIO (Low-Latency DSP Input/Output)—GPn_FN = 0x002
The DSP GPIO function provides an advanced I/O capability for signal-processing applications. The DSP GPIO pins are
accessed using maskable sets of I/O control registers; this allows the selected combinations of GPIOs to be controlled
with ease, regardless of how the allocation of GPIO pins has been implemented in hardware.
The DSP GPIO function is selected by setting the respective GPIO fields as described in Section 4.14.1.
A full description of the DSP GPIO function is provided in Section 4.5.4.
Note that, if GPn_FN is set to 0x002, the respective pin direction (input or output) is set according to the DSP GPIO
configuration for that pin—the GPn_DIR control bit has no effect in this case.
DS1162F1
195
CS42L92
4.14 General-Purpose I/O
4.14.7 Interrupt (IRQ) Status Output—GPn_FN = 0x003, 0x004
The CS42L92 has an interrupt controller, which can be used to indicate when any selected interrupt events occur.
Individual interrupts may be masked in order to configure the interrupt as required. See Section 4.15 for a full definition of
all supported interrupt events.
The interrupt controller supports two separate interrupt request (IRQ) outputs. The IRQ1 or IRQ2 status may be output
directly on a GPIO pin by setting the respective GPIO fields as described in Section 4.14.1.
Note that the IRQ1 status is output on the IRQ pin at all times.
4.14.8 Frequency-Locked Loop (FLL) Clock Output—GPn_FN = 0x010, 0x011
Clock outputs derived from the FLLs may be output on a GPIO pin. The GPIO output from each FLLn (FLL1 or FLL2) is
controlled by the respective FLLn_GPCLK_DIV and FLLn_GPCLK_ENA fields, as described in Table 4-96.
It is recommended to disable the clock output (FLLn_GPCLK_ENA = 0) before making any change to the respective
FLLn_GPCLK_DIV field.
Note that FLLn_GPCLK_DIV and FLLn_GPCLK_ENA affect the GPIO outputs only; they do not affect the FLL frequency.
The maximum output frequency supported for GPIO output is noted in Table 3-10.
The FLL clock outputs may be output directly on a GPIO pin by setting the respective GPIO fields as described in
Section 4.14.1.
See Section 4.16 for details of the CS42L92 system clocking and how to configure the FLLs.
Table 4-96. FLL Clock Output Control
Register Address
R398 (0x018E)
FLL1_GPIO_Clock
R430 (0x01AE)
FLL2_GPIO_Clock
Bit
7:1
Label
FLL1_GPCLK_
DIV[6:0]
Default
0x02
0
FLL1_GPCLK_
ENA
0
7:1
FLL2_GPCLK_
DIV[6:0]
0x02
0
FLL2_GPCLK_
ENA
0
Description
FLL1 GPIO Clock Divider
0x00 = Reserved
0x01 = Reserved
0x02 = Divide by 2
0x03 = Divide by 3
0x04 = Divide by 4
…
0x7F = Divide by 127
(FGPIO = FFLL/FLL1_GPCLK_DIV)
FLL1 GPIO Clock Enable
0 = Disabled
1 = Enabled
FLL2 GPIO Clock Divider
0x00 = Reserved
0x01 = Reserved
0x02 = Divide by 2
0x03 = Divide by 3
0x04 = Divide by 4
…
0x7F = Divide by 127
(FGPIO = FFLL/FLL2_GPCLK_DIV)
FLL2 GPIO Clock Enable
0 = Disabled
1 = Enabled
4.14.9 Frequency-Locked Loop (FLL) Status Output—GPn_FN = 0x018, 0x019
The CS42L92 provides FLL status flags, which may be used to control other events. The FLL lock signals indicate whether
FLL lock has been achieved. See Section 4.16.8 for details of the FLLs.
The FLL lock signals may be output directly on a GPIO pin by setting the respective GPIO fields as described in
Section 4.14.1.
196
DS1162F1
CS42L92
4.14 General-Purpose I/O
The FLL lock signals are inputs to the interrupt controller circuit. An interrupt event is triggered on the rising and falling
edges of these signals. The associated interrupt bits are latched once set; they can be polled at any time or used to control
the IRQ signal. See Section 4.15 for details of the interrupt event handling.
4.14.10 OPCLK and OPCLK_ASYNC Clock Output—GPn_FN = 0x040, 0x041
A clock output (OPCLK) derived from SYSCLK can be output on a GPIO pin. The OPCLK frequency is controlled by
OPCLK_DIV and OPCLK_SEL. The OPCLK output is enabled by setting OPCLK_ENA, as described in Table 4-97.
A clock output (OPCLK_ASYNC) derived from ASYNCCLK can be output on a GPIO pin. The OPCLK_ASYNC frequency
is controlled by OPCLK_ASYNC_DIV and OPCLK_ASYNC_SEL. The OPCLK_ASYNC output is enabled by setting
OPCLK_ASYNC_ENA.
It is recommended to disable the clock output (OPCLK_ENA = 0 or OPCLK_ASYNC_ENA = 0) before making any change
to the respective OPCLK_DIV, OPCLK_SEL, OPCLK_ASYNC_DIV, or OPCLK_ASYNC_SEL fields.
The OPCLK or OPCLK_ASYNC clock can be output directly on a GPIO pin by setting the respective GPIO fields as
described in Section 4.14.1.
Note that the OPCLK source frequency cannot be higher than the SYSCLK frequency. The OPCLK_ASYNC source
frequency cannot be higher than the ASYNCCLK frequency. The maximum output frequency supported for GPIO output
is noted in Table 3-10.
See Section 4.16 for details of the system clocks (SYSCLK and ASYNCCLK).
Table 4-97. OPCLK Control
Register Address Bit
Label
R329 (0x0149)
15 OPCLK_ENA
Output_system_
clock
7:3 OPCLK_DIV[4:0]
2:0 OPCLK_SEL[2:0]
DS1162F1
Default
Description
0
OPCLK Enable
0 = Disabled
1 = Enabled
0x00 OPCLK Divider
0x02 = Divide by 2
0x04 = Divide by 4
0x06 = Divide by 6
… (even numbers only)
0x1E = Divide by 30
Note that only even numbered divisions (2, 4, 6, etc.) are valid selections.
All other codes are reserved when the OPCLK signal is enabled.
000 OPCLK Source Frequency
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
011 = 49.152 MHz (45.1584 MHz)
All other codes are reserved
The frequencies in brackets apply for 44.1 kHz–related SYSCLK rates only (i.e.,
SAMPLE_RATE_n = 01XXX).
The OPCLK Source Frequency must be less than or equal to the SYSCLK frequency.
197
CS42L92
4.14 General-Purpose I/O
Table 4-97. OPCLK Control (Cont.)
Register Address Bit
Label
R330 (0x014A)
15 OPCLK_ASYNC_
ENA
Output_async_
lock
7:3 OPCLK_ASYNC_
DIV[4:0]
2:0 OPCLK_ASYNC_
SEL[2:0]
Default
Description
0
OPCLK_ASYNC Enable
0 = Disabled
1 = Enabled
0x00 OPCLK_ASYNC Divider
0x02 = Divide by 2
0x04 = Divide by 4
0x06 = Divide by 6
… (even numbers only)
0x1E = Divide by 30
Note that only even numbered divisions (2, 4, 6, etc.) are valid selections.
All other codes are reserved when the OPCLK_ASYNC signal is enabled.
000 OPCLK_ASYNC Source Frequency
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
011 = 49.152 MHz (45.1584 MHz)
All other codes are reserved
The frequencies in brackets apply for 44.1 kHz–related ASYNCCLK rates only (i.e.,
ASYNC_SAMPLE_RATE_n = 01XXX).
The OPCLK_ASYNC Source Frequency must be less than or equal to the ASYNCCLK
frequency.
4.14.11 Pulse-Width Modulation (PWM) Signal Output—GPn_FN = 0x048, 0x049
The CS42L92 incorporates two PWM signal generators, which can be enabled as GPIO outputs. The duty cycle of each
PWM signal can be modulated by an audio source, or can be set to a fixed value using a control register setting.
The PWM outputs may be output directly on a GPIO pin by setting the respective GPIO fields as described in
Section 4.14.1.
See Section 4.3.12 for details of how to configure the PWM signal generators.
4.14.12 S/PDIF Audio Output—GPn_FN = 0x04C
The CS42L92 incorporates an IEC-60958-3–compatible S/PDIF transmitter, which can be selected as a GPIO output. The
S/PDIF transmitter supports stereo audio channels and allows full control over the S/PDIF validity bits and channel status
information.
The S/PDIF signal may be output directly on a GPIO pin by setting the respective GPIO fields as described in
Section 4.14.1.
See Section 4.3.8 for details of how to configure the S/PDIF output generator.
4.14.13 ASRC Lock Status Output—GPn_FN = 0x088, 0x089
The CS42L92 provides ASRC status flags, which may be used to control other events. The ASRC-lock signals indicate
whether ASRC lock has been achieved. See Section 4.3.15 for details of the ASRCs.
The ASRC lock signals may be output directly on a GPIO pin by setting the respective GPIO fields as described in
Section 4.14.1.
The ASRC lock signals are inputs to the interrupt control circuit. An interrupt event is triggered on the rising and falling
edges of the ASRC lock signals. The associated interrupt bits are latched once set; they can be polled at any time or used
to control the IRQ signal. See Section 4.15 for details of the interrupt event handling.
198
DS1162F1
CS42L92
4.14 General-Purpose I/O
4.14.14 General-Purpose Timer Status Output—GPn_FN = 0x140
The general-purpose timer can count up or down, and supports continuous or single count modes. A status output,
indicating the progress of the timer, is provided. See Section 4.5.3 for details of the general-purpose timer.
A logic signal from the general-purpose timer may be output directly on a GPIO pin by setting the respective GPIO fields
as described in Section 4.14.1. This logic signal is pulsed high whenever the timer reaches its final count value.
The general-purpose timer also provides input to the interrupt control circuit. An interrupt event is triggered whenever the
timer reaches its final count value. The associated interrupt bit is latched once set; it can be polled at any time or used to
control the IRQ signal. See Section 4.15 for details of the interrupt event handling.
4.14.15 Event Logger FIFO Buffer Status Output—GPn_FN = 0x150
The event logger incorporates a 16-stage FIFO buffer, in which any detected events (signal transitions) are recorded. A
status output for the FIFO buffer is provided. See Section 4.5.1 for details of the event logger.
A logic signal from the event logger may be output directly on a GPIO pin by setting the respective GPIO fields as
described in Section 4.14.1. This logic signal is set high whenever the FIFO not-empty condition is true.
The event logger also provides input to the interrupt control circuit. An interrupt event is triggered whenever the FIFO
condition occurs. The associated interrupt bit is latched once set; it can be polled at any time or used to control the IRQ
signal. See Section 4.15 for details of the interrupt event handling.
4.14.16 Alarm Generator Status Output—GPn_FN = 0x230, 0x231, 0x232, 0x233
The CS42L92 incorporates four alarm-generator circuits that are associated with the general-purpose timer. A status
output is provided by each alarm; these can be used to indicate one-off events, or can be configured for cyclic (repeated)
triggers. See Section 4.5.2 for details of the alarm-control circuits.
The alarm status may be output directly on a GPIO pin by setting the respective GPIO fields as described in
Section 4.14.1. The alarm status is asserted when the respective alarm-trigger conditions are met. The signal is asserted
for a duration that is configurable as described in Section 4.5.2.1.
The alarm generators also provide input to the interrupt control circuit. An interrupt event is triggered whenever the
alarm-trigger conditions are met. The associated interrupt bit is latched once set; it can be polled at any time or used to
control the IRQ signal. See Section 4.15 for details of the interrupt event handling.
4.14.17 Auxiliary PDM Interface—GPn_FN = 0x280, 0x281
The CS42L92 provides an auxiliary PDM interface that can be used to provide an audio path between an analog
microphone connected to the CS42L92 and a digital input to an external audio processor. The external connections to the
auxiliary PDM interface are supported on GPIO pins as follows:
•
In Master Mode (AUXPDM1_MSTR = 1), the CLK output can be configured on the GPIO3 or GPIO10 pins. The DAT
output can be configured on GPIO4 or GPIO9.
•
In Slave Mode (AUXPDM1_MSTR = 0), the CLK input is supported on GPIO10 only. The DAT output is supported
on GPIO9 only.
The applicable GPIO pins are configured by setting the respective GPIO fields as described in Section 4.14.1.
See Section 4.2.10 for details of how to configure the auxiliary PDM interface.
4.14.18 General-Purpose Switch
The CS42L92 provides two general-purpose switches, which can be used as controllable analog switches for external
functions. The switches support bidirectional analog operation, offering flexibility in the potential circuit applications. Refer
to Table 3-2 and Table 3-10 for further details. Note that this feature is entirely independent of the GPIOn pins.
•
The GP1 switch is implemented between the GPSW1P and GPSW1N pins; it is configured using SW1_MODE.
•
The GP2 switch is implemented between the GPSW2P and GPSW2N pins; it is configured using SW2_MODE.
DS1162F1
199
CS42L92
4.15 Interrupts
The SWn_MODE fields allow the switches to be disabled, enabled, or synchronized to the MICDET clamp status, as
described in Table 4-98.
The switches can be used in conjunction with the MICDET clamp function to suppress pops and clicks associated with
jack insertion and removal. An example circuit is shown in Fig. 4-60 within Section 4.12.2. Note that the MICDET clamp
function must also be configured appropriately when using this method of pop suppression.
Table 4-98. General-Purpose Switch Control
Register Address
R712 (0x02C8)
GP_Switch_1
Bit
3:2
Label
SW2_MODE[1:0]
Default
00
1:0
SW1_MODE[1:0]
00
Description
General-purpose Switch 2 control
00 = Disabled (switch open)
01 = Enabled (switch closed)
10 = Enabled if MICDET clamp status is set
11 = Enabled if MICDET clamp status is clear
General-purpose Switch 1 control
00 = Disabled (switch open)
01 = Enabled (switch closed)
10 = Enabled if MICDET clamp status is set
11 = Enabled if MICDET clamp status is clear
4.15 Interrupts
The interrupt controller has multiple inputs. These include the jack detect and GPIO input pins, DSP_IRQn flags,
headphone/accessory detection, FLL/ASRC lock detection, and status flags from DSP peripheral functions. See
Table 4-99 and Table 4-100 for a full definition of the interrupt controller inputs. Any combination of these inputs can be
used to trigger an interrupt request event.
The interrupt controller supports two sets of interrupt registers. This allows two separate interrupt request (IRQ) outputs
to be generated, and for each IRQ to report a different set of input or status conditions.
For each interrupt request (IRQ1 and IRQ2) output, there is an interrupt register field associated with each interrupt input.
These fields are asserted whenever a logic edge is detected on the respective input. Some inputs are triggered on rising
edges only; some are triggered on both edges. Separate rising and falling interrupt bits are provided for the JD1 and JD2
signals. The interrupt register fields for IRQ1 are described in Table 4-99. The interrupt register fields for IRQ2 are
described in Table 4-100. The interrupt flags can be polled at any time or in response to the interrupt request output being
signaled via the IRQ pin or a GPIO pin.
All interrupts are edge triggered, as noted above. Many are triggered on both the rising and falling edges and, therefore,
the interrupt bits cannot indicate which edge has been detected. The raw status fields described in Table 4-99 and
Table 4-100 indicate the current value of the corresponding inputs to the interrupt controller. Note that the raw status bits
associated with IRQ1 and IRQ2 provide the same information. The status of any GPIO (or DSP GPIO) inputs can also be
read using the GPIO (or DSP GPIO) control fields, as described in Table 4-93 and Table 4-41.
Individual mask bits can enable or disable different functions from the interrupt controller. The mask bits are described in
Table 4-99 (for IRQ1) and Table 4-100 (for IRQ2). Note that a masked interrupt input does not assert the corresponding
interrupt register field and does not cause the associated interrupt request output to be asserted.
The interrupt request outputs represent the logical OR of the associated interrupt registers. IRQ1 is derived from the x_
EINT1 registers; IRQ2 is derived from the x_EINT2 registers. The interrupt register fields are latching fields and, once they
are set, they are not reset until a 1 is written to the respective bits. The interrupt request outputs are not reset until each
of the associated interrupts has been reset.
A debounce circuit can be enabled on any GPIO input, to avoid false event triggers. This is enabled on each pin using the
fields described in Table 4-93. The GPIO debounce circuit uses the 32-kHz clock, which must be enabled whenever the
GPIO debounce function is required.
A debounce circuit is always enabled on the FLL status inputs—either the 32-kHz clock or the SYSCLK signal must be
enabled to trigger an interrupt from the FLL status inputs. Note that the raw status fields (described in Table 4-99 and
Table 4-100) are valid without clocking; these fields can be used to provide FLL status readback if system clocks are not
available.
200
DS1162F1
CS42L92
4.15 Interrupts
The IRQ outputs can be globally masked using the IM_IRQ1 and IM_IRQ2 bits. When not masked, the IRQ status can be
read from IRQ1_STS and IRQ2_STS for the respective IRQ outputs.
The IRQ1 output is provided externally on the IRQ pin. Under default conditions, this output is active low. The polarity can
be inverted using IRQ_POL. The IRQ output can be either CMOS driven or open drain; this is selected using the IRQ_
OP_CFG bit. The IRQ output is active low and is referenced to the DBVDD power domain.
The IRQ2 status can be used to trigger DSP firmware execution; see Section 4.4. This allows the DSP firmware execution
to be linked to external events (e.g., jack detection, or GPIO input), or to any of the status conditions flagged by the
interrupt registers.
The IRQ1 and IRQ2 signals may be output on a GPIO pin; see Section 4.14.
The CS42L92 interrupt controller circuit is shown in Fig. 4-64. (Note that not all interrupt inputs are shown.) The control
fields associated with IRQ1 and IRQ2 are described in Table 4-99 and Table 4-100 respectively. The global interrupt mask
bits, status bits, and output configuration fields are described Table 4-101.
xxx_STSn
xxx_STSn
GP1_STSn
FLL1_LOCK_STSn
DRC1_SIG_DET_STSn
INPUTS_SIG_DET_STSn
De-bouncing & Edge detection
Note that, under default register conditions, the boot done status is the only unmasked interrupt source; a falling edge on
the IRQ pin indicates completion of the boot sequence.
xxx_EINT1
IM_xxx_EINT1
xxx_EINT1
IM_xxx_EINT1
GP1_EINT1
IM_GP1_EINT1
IRQ1_STS
FLL1_LOCK_EINT1
IM_IRQ1
IM_FLL1_LOCK_EINT1
DRC1_SIG_DET_EINT1
IM_DRC1_SIG_DET_EINT1
INPUTS_SIG_DET_EINT1
IM_INPUTS_SIG_DET_EINT1
xxx_EINT2
IM_xxx_EINT2
xxx_EINT2
IM_xxx_EINT2
GP1_EINT2
IM_GP1_EINT2
IRQ2_STS
FLL1_LOCK_EINT2
IM_IRQ2
IM_FLL1_LOCK_EINT2
DRC1_SIG_DET_EINT2
IM_DRC1_SIG_DET_EINT2
INPUTS_SIG_DET_EINT2
IM_INPUTS_SIG_DET_EINT2
Note: not all available interrupt sources are shown
Figure 4-64. Interrupt Controller
DS1162F1
201
CS42L92
4.15 Interrupts
The IRQ1 interrupt, mask, and status control registers are described in Table 4-99.
Table 4-99. Interrupt 1 Control Registers
Register Address
R6144 (0x1800)
IRQ1_Status_1
R6145 (0x1801)
IRQ1_Status_2
R6149 (0x1805)
IRQ1_Status_6
R6150 (0x1806)
IRQ1_Status_7
202
Bit
12
Label
CTRLIF_ERR_EINT1
Default
0
9
SYSCLK_FAIL_EINT1
0
7
BOOT_DONE_EINT1
0
14
DSPCLK_ERR_EINT1
0
13
ASYNCCLK_ERR_EINT1
0
12
SYSCLK_ERR_EINT1
0
9
FLL2_LOCK_EINT1
0
8
FLL1_LOCK_EINT1
0
6
FLL2_REF_LOST_EINT1
0
5
FLL1_REF_LOST_EINT1
0
9
MICDET2_EINT1
0
8
MICDET1_EINT1
0
0
HPDET_EINT1
0
11
MICD_CLAMP2_FALL_EINT1
0
10
MICD_CLAMP2_RISE_EINT1
0
9
JD3_FALL_EINT1
0
8
JD3_RISE_EINT1
0
5
MICD_CLAMP1_FALL_EINT1
0
4
MICD_CLAMP1_RISE_EINT1
0
3
JD2_FALL_EINT1
0
2
JD2_RISE_EINT1
0
1
JD1_FALL_EINT1
0
0
JD1_RISE_EINT1
0
Description
Control Interface Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
SYSCLK Fail Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Boot Done Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSPCLK Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
ASYNCCLK Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
SYSCLK Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
FLL2 Lock Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
FLL1 Lock Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
FLL2 Reference Lost Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
FLL1 Reference Lost Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Mic/Accessory Detect 2 Interrupt (Detection event triggered)
Note: Cleared when a 1 is written.
Mic/Accessory Detect 1 Interrupt (Detection event triggered)
Note: Cleared when a 1 is written.
Headphone Detect Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
MICDET Clamp 2 Interrupt (Falling edge triggered)
Note: Cleared when a 1 is written.
MICDET Clamp 2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
JD3 Interrupt (Falling edge triggered)
Note: Cleared when a 1 is written.
JD3 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
MICDET Clamp 1 Interrupt (Falling edge triggered)
Note: Cleared when a 1 is written.
MICDET Clamp 1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
JD2 Interrupt (Falling edge triggered)
Note: Cleared when a 1 is written.
JD2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
JD1 Interrupt (Falling edge triggered)
Note: Cleared when a 1 is written.
JD1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DS1162F1
CS42L92
4.15 Interrupts
Table 4-99. Interrupt 1 Control Registers (Cont.)
Register Address
R6152 (0x1808)
IRQ1_Status_9
R6154 (0x180A)
IRQ1_Status_11
DS1162F1
Bit
9
Label
ASRC1_IN2_LOCK_EINT1
Default
0
8
ASRC1_IN1_LOCK_EINT1
0
2
INPUTS_SIG_DET_EINT1
0
1
DRC2_SIG_DET_EINT1
0
0
DRC1_SIG_DET_EINT1
0
15
DSP_IRQ16_EINT1
0
14
DSP_IRQ15_EINT1
0
13
DSP_IRQ14_EINT1
0
12
DSP_IRQ13_EINT1
0
11
DSP_IRQ12_EINT1
0
10
DSP_IRQ11_EINT1
0
9
DSP_IRQ10_EINT1
0
8
DSP_IRQ9_EINT1
0
7
DSP_IRQ8_EINT1
0
6
DSP_IRQ7_EINT1
0
5
DSP_IRQ6_EINT1
0
4
DSP_IRQ5_EINT1
0
3
DSP_IRQ4_EINT1
0
2
DSP_IRQ3_EINT1
0
1
DSP_IRQ2_EINT1
0
0
DSP_IRQ1_EINT1
0
Description
ASRC1 IN2 Lock Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
ASRC1 IN1 Lock Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
Input Path Signal-Detect Interrupt (Rising and falling edge
triggered)
Note: Cleared when a 1 is written.
DRC2 Signal-Detect Interrupt (Rising and falling edge
triggered)
Note: Cleared when a 1 is written.
DRC1 Signal-Detect Interrupt (Rising and falling edge
triggered)
Note: Cleared when a 1 is written.
DSP IRQ16 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ15 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ14 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ13 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ12 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ11 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ10 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ9 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ8 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ7 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ6 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ5 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ4 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ3 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
203
CS42L92
4.15 Interrupts
Table 4-99. Interrupt 1 Control Registers (Cont.)
Register Address
R6155 (0x180B)
IRQ1_Status_12
R6156 (0x180C)
IRQ1_Status_13
R6157 (0x180D)
IRQ1_Status_14
R6158 (0x180E)
IRQ1_Status_15
204
Bit
9
Label
HP4R_SC_EINT1
Default
0
8
HP4L_SC_EINT1
0
5
HP3R_SC_EINT1
0
4
HP3L_SC_EINT1
0
3
HP2R_SC_EINT1
0
2
HP2L_SC_EINT1
0
1
HP1R_SC_EINT1
0
0
HP1L_SC_EINT1
0
5
HP3R_ENABLE_DONE_EINT1
0
4
HP3L_ENABLE_DONE_EINT1
0
3
HP2R_ENABLE_DONE_EINT1
0
2
HP2L_ENABLE_DONE_EINT1
0
1
HP1R_ENABLE_DONE_EINT1
0
0
HP1L_ENABLE_DONE_EINT1
0
5
HP3R_DISABLE_DONE_EINT1
0
4
HP3L_DISABLE_DONE_EINT1
0
3
HP2R_DISABLE_DONE_EINT1
0
2
HP2L_DISABLE_DONE_EINT1
0
1
HP1R_DISABLE_DONE_EINT1
0
0
HP1L_DISABLE_DONE_EINT1
0
12
DFC_SATURATE_EINT1
0
Description
HPOUT4R Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT4L Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3R Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3L Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2R Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2L Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1R Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1L Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3R/HPOUT4R Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3L/HPOUT4L Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2R Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2L Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1R Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1L Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3R/HPOUT4R Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3L/HPOUT4L Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2R Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2L Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1R Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1L Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DFC Saturate Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DS1162F1
CS42L92
4.15 Interrupts
Table 4-99. Interrupt 1 Control Registers (Cont.)
Register Address
R6160 (0x1810)
IRQ1_Status_17
Bit
15
GP16_EINT1
Default
0
14
GP15_EINT1
0
13
GP14_EINT1
0
12
GP13_EINT1
0
11
GP12_EINT1
0
10
GP11_EINT1
0
9
GP10_EINT1
0
8
GP9_EINT1
0
7
GP8_EINT1
0
6
GP7_EINT1
0
5
GP6_EINT1
0
4
GP5_EINT1
0
3
GP4_EINT1
0
2
GP3_EINT1
0
1
GP2_EINT1
0
0
GP1_EINT1
0
R6164 (0x1814)
0
TIMER1_EINT1
0
IRQ1_Status_21
R6165 (0x1815)
0
EVENT1_NOT_EMPTY_EINT1
0
IRQ1_Status_22
R6166 (0x1816)
0
EVENT1_FULL_EINT1
0
IRQ1_Status_23
R6167 (0x1817)
0
EVENT1_WMARK_EINT1
0
IRQ1_Status_24
R6168 (0x1818)
0
DSP1_DMA_EINT1
0
IRQ1_Status_25
R6170 (0x181A)
0
DSP1_START1_EINT1
0
IRQ1_Status_27
R6171 (0x181B)
0
DSP1_START2_EINT1
0
IRQ1_Status_28
R6173 (0x181D)
0
DSP1_BUSY_EINT1
0
0
DSP1_BUS_ERR_EINT1
0
IRQ1_Status_30
R6176 (0x1820)
IRQ1_Status_33
DS1162F1
Label
Description
GPIO16 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO15 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO14 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO13 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO12 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO11 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO10 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO9 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO8 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO7 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO6 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO5 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO4 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO3 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO2 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO1 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
Timer 1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Event Log 1 FIFO Not Empty Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Event Log 1 FIFO Full Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Event Log 1 FIFO Watermark Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 DMA Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 Start 1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 Start 2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 Busy Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 Bus Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
205
CS42L92
4.15 Interrupts
Table 4-99. Interrupt 1 Control Registers (Cont.)
Register Address
R6179 (0x1823)
IRQ1_Status_36
Bit
3
Label
TIMER_ALM1_CH4_EINT1
2
TIMER_ALM1_CH3_EINT1
1
TIMER_ALM1_CH2_EINT1
0
TIMER_ALM1_CH1_EINT1
R6208 (0x1840)
to
R6243 (0x1863)
R6272 (0x1880)
IRQ1_Raw_
Status_1
R6273 (0x1881)
IRQ1_Raw_
Status_2
206
IM_*
12
CTRLIF_ERR_STS1
7
BOOT_DONE_STS1
14
DSPCLK_ERR_STS1
13
ASYNCCLK_ERR_STS1
12
SYSCLK_ERR_STS1
9
FLL2_LOCK_STS1
8
FLL1_LOCK_STS1
6
FLL2_REF_LOST_STS1
5
FLL1_REF_LOST_STS1
Default
0
Description
Alarm 1 Channel 4 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
0
Alarm 1 Channel 3 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
0
Alarm 1 Channel 2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
0
Alarm 1 Channel 1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
See
For each x_EINT1 interrupt bit in R6144 to R6179, a
Footnote 1 corresponding mask bit (IM_*) is provided in R6208 to R6243.
The mask bits are coded as follows:
0 = Do not mask interrupt
1 = Mask interrupt
0
Control Interface Error Status
0 = Normal
1 = Control Interface Error
0
Boot Status
0 = Busy (boot sequence in progress)
1 = Idle (boot sequence completed)
Control register writes should not be attempted until Boot
Sequence has completed.
0
DSPCLK Error Interrupt Status
0 = Normal
1 = Insufficient DSPCLK cycles for one or more of the
requested DSP1 clock frequencies
0
ASYNCCLK Error Interrupt Status
0 = Normal
1 = Insufficient ASYNCCLK cycles for the requested signal path
functionality
0
SYSCLK Error Interrupt Status
0 = Normal
1 = Insufficient SYSCLK cycles for the requested signal path
functionality
0
FLL2 Lock Status
0 = Not locked
1 = Locked
0
FLL1 Lock Status
0 = Not locked
1 = Locked
0
FLL2 Reference Lost Status
0 = Normal
1 = Reference Lost
0
FLL1 Reference Lost Status
0 = Normal
1 = Reference Lost
DS1162F1
CS42L92
4.15 Interrupts
Table 4-99. Interrupt 1 Control Registers (Cont.)
Register Address
R6278 (0x1886)
IRQ1_Raw_
Status_7
R6280 (0x1888)
IRQ1_Raw_
Status_9
DS1162F1
Bit
8
Label
JD3_STS1
Default
0
4
MICD_CLAMP_STS1
0
2
JD2_STS1
0
0
JD1_STS1
0
9
ASRC1_IN2_LOCK_STS1
0
8
ASRC1_IN1_LOCK_STS1
0
2
INPUTS_SIG_DET_STS1
0
1
DRC2_SIG_DET_STS1
0
0
DRC1_SIG_DET_STS1
0
Description
JACKDET3 input status
0 = Jack not detected
1 = Jack is detected
(Assumes the JACKDET3 pin is pulled low on jack insertion.)
MICDET Clamp status
0 = Clamp disabled
1 = Clamp enabled
Separate _STS bits are not provided for each clamp—it is
assumed that a maximum of one clamp is active at any time.
The clamp override condition (MICD_CLAMPn_OVD = 1) is not
indicated.
JACKDET2 input status
0 = Jack not detected
1 = Jack is detected
(Assumes the JACKDET2 pin is pulled low on jack insertion.)
JACKDET1 input status
0 = Jack not detected
1 = Jack is detected
(Assumes the JACKDET1 pin is pulled low on jack insertion.)
ASRC1 IN2 Lock Status
0 = Not locked
1 = Locked
ASRC1 IN1 Lock Status
0 = Not locked
1 = Locked
Input Path Signal-Detect Status
0 = Normal
1 = Signal detected
DRC2 Signal-Detect Status
0 = Normal
1 = Signal detected
DRC1 Signal-Detect Status
0 = Normal
1 = Signal detected
207
CS42L92
4.15 Interrupts
Table 4-99. Interrupt 1 Control Registers (Cont.)
Register Address
R6283 (0x188B)
IRQ1_Raw_
Status_12
R6284 (0x188C)
IRQ1_Raw_
Status_13
208
Bit
9
Label
HP4R_SC_STS1
Default
0
8
HP4L_SC_STS1
0
5
HP3R_SC_STS1
0
4
HP3L_SC_STS1
0
3
HP2R_SC_STS1
0
2
HP2L_SC_STS1
0
1
HP1R_SC_STS1
0
0
HP1L_SC_STS1
0
5
HP3R_ENABLE_DONE_STS1
0
4
HP3L_ENABLE_DONE_STS1
0
3
HP2R_ENABLE_DONE_STS1
0
2
HP2L_ENABLE_DONE_STS1
0
1
HP1R_ENABLE_DONE_STS1
0
0
HP1L_ENABLE_DONE_STS1
0
Description
HPOUT4R Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT4L Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT3R Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT3L Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT2R Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT2L Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT1R Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT1L Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT3R/HPOUT4R Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT3L/HPOUT4L Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT2R Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT2L Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT1R Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT1L Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
DS1162F1
CS42L92
4.15 Interrupts
Table 4-99. Interrupt 1 Control Registers (Cont.)
Register Address
R6285 (0x188D)
IRQ1_Raw_
Status_14
Bit
5
Label
HP3R_DISABLE_DONE_STS1
Default
0
4
HP3L_DISABLE_DONE_STS1
0
3
HP2R_DISABLE_DONE_STS1
0
2
HP2L_DISABLE_DONE_STS1
0
1
HP1R_DISABLE_DONE_STS1
0
0
HP1L_DISABLE_DONE_STS1
0
R6293 (0x1895)
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
0
GP16_STS1
GP15_STS1
GP14_STS1
GP13_STS1
GP12_STS1
GP11_STS1
GP10_STS1
GP9_STS1
GP8_STS1
GP7_STS1
GP6_STS1
GP5_STS1
GP4_STS1
GP3_STS1
GP2_STS1
GP1_STS1
EVENT1_NOT_EMPTY_STS1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
IRQ1_Raw_
Status_22
R6294 (0x1896)
0
EVENT1_FULL_STS1
0
IRQ1_Raw_
Status_23
R6295 (0x1897)
0
EVENT1_WMARK_STS1
0
IRQ1_Raw_
Status_24
R6296 (0x1898)
0
DSP1_DMA_STS1
0
0
DSP1_BUSY_STS1
0
R6288 (0x1890)
IRQ1_Raw_
Status_17
IRQ1_Raw_
Status_25
R6301 (0x189D)
IRQ1_Raw_
Status_30
DS1162F1
Description
HPOUT3R/HPOUT4R Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT3L/HPOUT4L Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT2R Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT2L Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT1R Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT1L Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
GPIOn Input status. Reads back the logic level of GPIOn.
Only valid for pins configured as GPIO input (does not include
DSPGPIO inputs).
Event Log 1 FIFO Not-Empty status
0 = FIFO Empty
1 = FIFO Not Empty
Event Log 1 FIFO Full status
0 = FIFO Not Full
1 = FIFO Full
Event Log 1 FIFO Watermark status
0 = FIFO Watermark not reached
1 = FIFO Watermark reached
DSP1 DMA status
0 = Normal
1 = All enabled WDMA buffers filled, and all enabled RDMA
buffers emptied
DSP1 Busy status
0 = DSP Idle
1 = DSP Busy
209
CS42L92
4.15 Interrupts
Table 4-99. Interrupt 1 Control Registers (Cont.)
Register Address
R6307 (0x18A3)
IRQ1_Raw_
Status_36
Bit
3
Label
TIMER_ALM1_CH4_STS1
Default
0
2
TIMER_ALM1_CH3_STS1
0
1
TIMER_ALM1_CH2_STS1
0
0
TIMER_ALM1_CH1_STS1
0
Description
Alarm 1 Channel 4 status
0 = Alarm idle
1 = Alarm output asserted
Alarm 1 Channel 3 status
0 = Alarm idle
1 = Alarm output asserted
Alarm 1 Channel 2 status
0 = Alarm idle
1 = Alarm output asserted
Alarm 1 Channel 1 status
0 = Alarm idle
1 = Alarm output asserted
1.The BOOT_DONE_EINT1 interrupt is 0 (unmasked) by default; all other interrupts are 1 (masked) by default.
The IRQ2 interrupt, mask, and status control registers are described in Table 4-100.
Table 4-100. Interrupt 2 Control Registers
Register Address
R6400 (0x1900)
IRQ2_Status_1
R6401 (0x1901)
IRQ2_Status_2
R6405 (0x1905)
IRQ2_Status_6
210
Bit
12
Label
CTRLIF_ERR_EINT2
Default
0
9
SYSCLK_FAIL_EINT2
0
7
BOOT_DONE_EINT2
0
14
DSPCLK_ERR_EINT2
0
13
ASYNCCLK_ERR_EINT2
0
12
SYSCLK_ERR_EINT2
0
9
FLL2_LOCK_EINT2
0
8
FLL1_LOCK_EINT2
0
6
FLL2_REF_LOST_EINT2
0
5
FLL1_REF_LOST_EINT2
0
9
MICDET2_EINT2
0
8
MICDET1_EINT2
0
0
HPDET_EINT2
0
Description
Control Interface Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
SYSCLK Fail Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Boot Done Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSPCLK Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
ASYNCCLK Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
SYSCLK Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
FLL2 Lock Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
FLL1 Lock Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
FLL2 Reference Lost Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
FLL1 Reference Lost Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Mic/Accessory Detect 2 Interrupt (Detection event triggered)
Note: Cleared when a 1 is written.
Mic/Accessory Detect 1 Interrupt (Detection event triggered)
Note: Cleared when a 1 is written.
Headphone Detect Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DS1162F1
CS42L92
4.15 Interrupts
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6406 (0x1906)
IRQ2_Status_7
R6408 (0x1908)
IRQ2_Status_9
DS1162F1
Bit
3
Label
JD3_FALL_EINT2
Default
0
2
JD3_RISE_EINT2
0
5
MICD_CLAMP_FALL_EINT2
0
4
MICD_CLAMP_RISE_EINT2
0
3
JD2_FALL_EINT2
0
2
JD2_RISE_EINT2
0
1
JD1_FALL_EINT2
0
0
JD1_RISE_EINT2
0
9
ASRC1_IN2_LOCK_EINT2
0
8
ASRC1_IN1_LOCK_EINT2
0
2
INPUTS_SIG_DET_EINT2
0
1
DRC2_SIG_DET_EINT2
0
0
DRC1_SIG_DET_EINT2
0
Description
JD3 Interrupt (Falling edge triggered)
Note: Cleared when a 1 is written.
JD3 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
MICDET Clamp Interrupt (Falling edge triggered)
Indicates a falling edge transition on MICDET Clamp 1 or
MICDET Clamp 2. Separate x_EINT2 bits are not provided—it
is assumed that a maximum of one clamp is active at any time.
Note: Cleared when a 1 is written.
MICDET Clamp Interrupt (Rising edge triggered)
Indicates a rising edge transition on MICDET Clamp 1 or
MICDET Clamp 2. Separate x_EINT2 bits are not provided—it
is assumed that a maximum of one clamp is active at any time.
Note: Cleared when a 1 is written.
JD2 Interrupt (Falling edge triggered)
Note: Cleared when a 1 is written.
JD2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
JD1 Interrupt (Falling edge triggered)
Note: Cleared when a 1 is written.
JD1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
ASRC1 IN2 Lock Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
ASRC1 IN1 Lock Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
Input Path Signal-Detect Interrupt (Rising and falling edge
triggered)
Note: Cleared when a 1 is written.
DRC2 Signal-Detect Interrupt (Rising and falling edge
triggered)
Note: Cleared when a 1 is written.
DRC1 Signal-Detect Interrupt (Rising and falling edge
triggered)
Note: Cleared when a 1 is written.
211
CS42L92
4.15 Interrupts
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6410 (0x190A)
IRQ2_Status_11
R6411 (0x190B)
IRQ2_Status_12
212
Bit
15
Label
DSP_IRQ16_EINT2
Default
0
14
DSP_IRQ15_EINT2
0
13
DSP_IRQ14_EINT2
0
12
DSP_IRQ13_EINT2
0
11
DSP_IRQ12_EINT2
0
10
DSP_IRQ11_EINT2
0
9
DSP_IRQ10_EINT2
0
8
DSP_IRQ9_EINT2
0
7
DSP_IRQ8_EINT2
0
6
DSP_IRQ7_EINT2
0
5
DSP_IRQ6_EINT2
0
4
DSP_IRQ5_EINT2
0
3
DSP_IRQ4_EINT2
0
2
DSP_IRQ3_EINT2
0
1
DSP_IRQ2_EINT2
0
0
DSP_IRQ1_EINT2
0
9
HP4R_SC_EINT2
0
8
HP4L_SC_EINT2
0
5
HP3R_SC_EINT2
0
4
HP3L_SC_EINT2
0
3
HP2R_SC_EINT2
0
2
HP2L_SC_EINT2
0
1
HP1R_SC_EINT2
0
0
HP1L_SC_EINT2
0
Description
DSP IRQ16 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ15 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ14 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ13 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ12 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ11 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ10 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ9 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ8 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ7 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ6 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ5 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ4 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ3 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP IRQ1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT4R Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT4L Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3R Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3L Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2R Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2L Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1R Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1L Short Circuit Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DS1162F1
CS42L92
4.15 Interrupts
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6412 (0x190C)
IRQ2_Status_13
R6413 (0x190D)
IRQ2_Status_14
R6414 (0x190E)
IRQ2_Status_15
DS1162F1
Bit
5
Label
HP3R_ENABLE_DONE_EINT2
Default
0
4
HP3L_ENABLE_DONE_EINT2
0
3
HP2R_ENABLE_DONE_EINT2
0
2
HP2L_ENABLE_DONE_EINT2
0
1
HP1R_ENABLE_DONE_EINT2
0
0
HP1L_ENABLE_DONE_EINT2
0
5
HP3R_DISABLE_DONE_EINT2
0
4
HP3L_DISABLE_DONE_EINT2
0
3
HP2R_DISABLE_DONE_EINT2
0
2
HP2L_DISABLE_DONE_EINT2
0
1
HP1R_DISABLE_DONE_EINT2
0
0
HP1L_DISABLE_DONE_EINT2
0
12
DFC_SATURATE_EINT2
0
Description
HPOUT3R/HPOUT4R Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3L/HPOUT4L Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2R Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2L Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1R Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1L Enable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3R/HPOUT4R Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT3L/HPOUT4L Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2R Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT2L Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1R Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
HPOUT1L Disable Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DFC Saturate Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
213
CS42L92
4.15 Interrupts
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6416 (0x1910)
IRQ2_Status_17
Bit
15
GP16_EINT2
Default
0
14
GP15_EINT2
0
13
GP14_EINT2
0
12
GP13_EINT2
0
11
GP12_EINT2
0
10
GP11_EINT2
0
9
GP10_EINT2
0
8
GP9_EINT2
0
7
GP8_EINT2
0
6
GP7_EINT2
0
5
GP6_EINT2
0
4
GP5_EINT2
0
3
GP4_EINT2
0
2
GP3_EINT2
0
1
GP2_EINT2
0
0
GP1_EINT2
0
R6420 (0x1914)
0
TIMER1_EINT2
0
IRQ2_Status_21
R6421 (0x1915)
0
EVENT1_NOT_EMPTY_EINT2
0
IRQ2_Status_22
R6422 (0x1916)
0
EVENT1_FULL_EINT2
0
IRQ2_Status_23
R6423 (0x1917)
0
EVENT1_WMARK_EINT2
0
IRQ2_Status_24
R6424 (0x1918)
0
DSP1_DMA_EINT2
0
IRQ2_Status_25
R6426 (0x191A)
0
DSP1_START1_EINT2
0
IRQ2_Status_27
R6427 (0x191B)
0
DSP1_START2_EINT2
0
IRQ2_Status_28
R6429 (0x191D)
0
DSP1_BUSY_EINT2
0
0
DSP1_BUS_ERR_EINT2
0
IRQ2_Status_30
R6432 (0x1920)
IRQ2_Status_33
214
Label
Description
GPIO16 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO15 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO14 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO13 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO12 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO11 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO10 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO9 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO8 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO7 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO6 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO5 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO4 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO3 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO2 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
GPIO1 Interrupt (Rising and falling edge triggered)
Note: Cleared when a 1 is written.
Timer 1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Event Log 1 FIFO Not Empty Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Event Log 1 FIFO Full Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Event Log 1 FIFO Watermark Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 DMA Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 Start 1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 Start 2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 Busy Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DSP1 Bus Error Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
DS1162F1
CS42L92
4.15 Interrupts
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6435 (0x1923)
IRQ2_Status_36
Bit
3
Label
TIMER_ALM1_CH4_EINT2
Default
0
2
TIMER_ALM1_CH3_EINT2
0
1
TIMER_ALM1_CH2_EINT2
0
0
TIMER_ALM1_CH1_EINT2
0
IM_*
1
12
CTRLIF_ERR_STS2
0
7
BOOT_DONE_STS2
0
14
DSPCLK_ERR_STS2
0
13
ASYNCCLK_ERR_STS2
0
12
SYSCLK_ERR_STS2
0
9
FLL2_LOCK_STS2
0
8
FLL1_LOCK_STS2
0
6
FLL2_REF_LOST_STS2
0
5
FLL1_REF_LOST_STS2
0
R6464 (0x1940)
to
R6499 (0x1963)
R6528 (0x1980)
IRQ2_Raw_
Status_1
R6529 (0x1981)
IRQ2_Raw_
Status_2
DS1162F1
Description
Alarm 1 Channel 4 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Alarm 1 Channel 3 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Alarm 1 Channel 2 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
Alarm 1 Channel 1 Interrupt (Rising edge triggered)
Note: Cleared when a 1 is written.
For each x_EINT2 interrupt bit in R6400 to R6435, a
corresponding mask bit (IM_*) is provided in R6464 to R6499.
The mask bits are coded as follows:
0 = Do not mask interrupt
1 = Mask interrupt
Control Interface Error Status
0 = Normal
1 = Control Interface Error
Boot Status
0 = Busy (boot sequence in progress)
1 = Idle (boot sequence completed)
Control register writes should not be attempted until Boot
Sequence has completed.
DSPCLK Error Interrupt Status
0 = Normal
1 = Insufficient DSPCLK cycles for one or more of the
requested DSP1 clock frequencies
ASYNCCLK Error Interrupt Status
0 = Normal
1 = Insufficient ASYNCCLK cycles for the requested signal path
functionality
SYSCLK Error Interrupt Status
0 = Normal
1 = Insufficient SYSCLK cycles for the requested signal path
functionality
FLL2 Lock Status
0 = Not locked
1 = Locked
FLL1 Lock Status
0 = Not locked
1 = Locked
FLL2 Reference Lost Status
0 = Normal
1 = Reference Lost
FLL1 Reference Lost Status
0 = Normal
1 = Reference Lost
215
CS42L92
4.15 Interrupts
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6534 (0x1986)
IRQ2_Raw_
Status_7
R6536 (0x1988)
IRQ2_Raw_
Status_9
216
Bit
8
Label
JD3_STS2
Default
0
4
MICD_CLAMP_STS2
0
2
JD2_STS2
0
0
JD1_STS2
0
9
ASRC1_IN2_LOCK_STS2
0
8
ASRC1_IN1_LOCK_STS2
0
2
INPUTS_SIG_DET_STS2
0
1
DRC2_SIG_DET_STS2
0
0
DRC1_SIG_DET_STS2
0
Description
JACKDET3 input status
0 = Jack not detected
1 = Jack is detected
(Assumes the JACKDET3 pin is pulled low on jack insertion.)
MICDET Clamp status
0 = Clamp disabled
1 = Clamp enabled
0 = Clamp disabled
1 = Clamp enabled
Separate _STS bits are not provided for each clamp—it is
assumed that a maximum of one clamp is active at any time.
The clamp override condition (MICD_CLAMPn_OVD = 1) is not
indicated.
JACKDET2 input status
0 = Jack not detected
1 = Jack is detected
(Assumes the JACKDET2 pin is pulled low on jack insertion.)
JACKDET1 input status
0 = Jack not detected
1 = Jack is detected
(Assumes the JACKDET1 pin is pulled low on jack insertion.)
ASRC1 IN2 Lock Status
0 = Not locked
1 = Locked
ASRC1 IN1 Lock Status
0 = Not locked
1 = Locked
Input Path Signal-Detect Status
0 = Normal
1 = Signal detected
DRC2 Signal-Detect Status
0 = Normal
1 = Signal detected
DRC1 Signal-Detect Status
0 = Normal
1 = Signal detected
DS1162F1
CS42L92
4.15 Interrupts
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6539 (0x198B)
IRQ2_Raw_
Status_12
R6540 (0x198C)
IRQ2_Raw_
Status_13
DS1162F1
Bit
9
Label
HP4R_SC_STS2
Default
0
8
HP4L_SC_STS2
0
5
HP3R_SC_STS2
0
4
HP3L_SC_STS2
0
3
HP2R_SC_STS2
0
2
HP2L_SC_STS2
0
1
HP1R_SC_STS2
0
0
HP1L_SC_STS2
0
5
HP3R_ENABLE_DONE_STS2
0
4
HP3L_ENABLE_DONE_STS2
0
3
HP2R_ENABLE_DONE_STS2
0
2
HP2L_ENABLE_DONE_STS2
0
1
HP1R_ENABLE_DONE_STS2
0
0
HP1L_ENABLE_DONE_STS2
0
Description
HPOUT4R Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT4L Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT3R Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT3L Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT2R Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT2L Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT1R Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT1L Short Circuit Status
0 = Normal
1 = Short Circuit detected
HPOUT3R/HPOUT4R Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT3L/HPOUT4L Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT2R Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT2L Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT1R Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT1L Enable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
217
CS42L92
4.15 Interrupts
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6541 (0x198D)
IRQ2_Raw_
Status_14
Bit
5
Label
HP3R_DISABLE_DONE_STS2
Default
0
4
HP3L_DISABLE_DONE_STS2
0
3
HP2R_DISABLE_DONE_STS2
0
2
HP2L_DISABLE_DONE_STS2
0
1
HP1R_DISABLE_DONE_STS2
0
0
HP1L_DISABLE_DONE_STS2
0
R6549 (0x1995)
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
0
GP16_STS2
GP15_STS2
GP14_STS2
GP13_STS2
GP12_STS2
GP11_STS2
GP10_STS2
GP9_STS2
GP8_STS2
GP7_STS2
GP6_STS2
GP5_STS2
GP4_STS2
GP3_STS2
GP2_STS2
GP1_STS2
EVENT1_NOT_EMPTY_STS2
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
IRQ2_Raw_
Status_22
R6550 (0x1996)
0
EVENT1_FULL_STS2
0
IRQ2_Raw_
Status_23
R6551 (0x1997)
0
EVENT1_WMARK_STS2
0
IRQ2_Raw_
Status_24
R6552 (0x1998)
0
DSP1_DMA_STS2
0
0
DSP1_BUSY_STS2
0
R6544 (0x1990)
IRQ2_Raw_
Status_17
IRQ2_Raw_
Status_25
R6557 (0x199D)
IRQ2_Raw_
Status_30
218
Description
HPOUT3R/HPOUT4R Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT3L/HPOUT4L Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT2R Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT2L Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT1R Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
HPOUT1L Disable Status
0 = Busy (sequence in progress)
1 = Idle (sequence completed)
GPIOn Input status
Reads back the logic level of GPIOn.
Only valid for pins configured as GPIO input (does not include
DSPGPIO inputs).
Event Log 1 FIFO Not-Empty status
0 = FIFO Empty
1 = FIFO Not Empty
Event Log n FIFO Full status
0 = FIFO Not Full
1 = FIFO Full
Event Log 1 FIFO Watermark status
0 = FIFO Watermark not reached
1 = FIFO Watermark reached
DSP1 DMA status
0 = Normal
1 = All enabled WDMA buffers filled, and all enabled RDMA
buffers emptied
DSP1 Busy status
0 = DSP Idle
1 = DSP Busy
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
Table 4-100. Interrupt 2 Control Registers (Cont.)
Register Address
R6563 (0x19A3)
IRQ2_Raw_
Status_36
Bit
3
Label
TIMER_ALM1_CH4_STS2
Default
0
2
TIMER_ALM1_CH3_STS2
0
1
TIMER_ALM1_CH2_STS2
0
0
TIMER_ALM1_CH1_STS2
0
Description
Alarm 1 Channel 4 status
0 = Alarm idle
1 = Alarm output asserted
Alarm 1 Channel 3 status
0 = Alarm idle
1 = Alarm output asserted
Alarm 1 Channel 2 status
0 = Alarm idle
1 = Alarm output asserted
Alarm 1 Channel 1 status
0 = Alarm idle
1 = Alarm output asserted
The IRQ output and polarity control registers are described in Table 4-101.
Table 4-101. Interrupt Control Registers
Register Address
R6784 (0x1A80)
IRQ1_CTRL
Bit
11
Label
IM_IRQ1
Default
0
10
IRQ_POL
1
9
IRQ_OP_CFG
0
R6786 (0x1A82)
IRQ2_CTRL
11
IM_IRQ2
0
R6816 (0x1AA0)
Interrupt_Raw_
Status_1
1
IRQ2_STS
0
0
IRQ1_STS
0
Description
IRQ1 Output Interrupt mask.
0 = Do not mask interrupt.
1 = Mask interrupt.
IRQ Output Polarity Select
0 = Noninverted (Active High)
1 = Inverted (Active Low)
IRQ Output Configuration
0 = CMOS
1 = Open drain
IRQ2 Output Interrupt mask.
0 = Do not mask interrupt.
1 = Mask interrupt.
IRQ2 Status. IRQ2_STS is the logical OR of all unmasked x_EINT2 interrupts.
0 = Not asserted
1 = Asserted
IRQ1 Status. IRQ1_STS is the logical OR of all unmasked x_EINT1 interrupts.
0 = Not asserted
1 = Asserted
4.16 Clocking and Sample Rates
The CS42L92 requires a clock reference for its internal functions and also for the input (ADC) paths, output (DAC) paths,
and digital audio interfaces. Under typical clocking configurations, all commonly used audio sample rates can be derived
directly from the external reference; for additional flexibility, the CS42L92 incorporates two FLL circuits to perform
frequency conversion and filtering.
External clock signals may be connected via the MCLK1, MCLK2, and MCLK3 input pins. In AIF Slave Modes, the BCLK
signals may be used as a reference for the system clocks. The SLIMbus interface can provide the clock reference, when
used as the input to one of the FLLs. To avoid audible glitches, all clock configurations must be set up before enabling
playback.
4.16.1 System Clocking Overview
The CS42L92 supports three primary clock domains—SYSCLK, ASYNCCLK, and DSPCLK.
The SYSCLK and ASYNCCLK clock domains are the reference clocks for all the audio signal paths on the CS42L92. Up
to five different sample rates may be independently selected for specific audio interfaces and other input/output signal
paths; each selected sample rate must be synchronized either to SYSCLK or to ASYNCCLK, as described in
Section 4.16.2.
DS1162F1
219
CS42L92
4.16 Clocking and Sample Rates
The SYSCLK and ASYNCCLK clock domains are independent (i.e., not synchronized). Stereo full-duplex sample-rate
conversion is supported, allowing asynchronous audio data to be mixed and to be routed between independent interfaces.
See Section 4.3 for further details.
The DSPCLK clock domain is the reference clock for the programmable DSP core on the CS42L92. A wide range of
DSPCLK frequencies can be supported, and a programmable clock divider is provided for the DSP core, allowing the DSP
clocking (and power consumption) to be optimized according to the applicable processing requirements. See Section 4.3
for further details.
Note that there is no requirement for DSPCLK to be synchronized to SYSCLK or ASYNCCLK. The DSPCLK controls the
software execution in the DSP core; audio outputs from the DSP are synchronized either to SYSCLK or ASYNCCLK,
regardless of the applicable DSPCLK rate.
Excluding the DSP core, each subsystem within the CS42L92 digital core is clocked at a dynamically controlled rate,
limited by the SYSCLK (or ASYNCCLK) frequency, as applicable. For maximum signal mixing and processing capacity, it
is recommended that the highest possible SYSCLK and ASYNCCLK frequencies are configured.
The DSP core is clocked at the DSPCLK rate (or supported divisions of the DSPCLK frequency). The DSPCLK
configuration must ensure that sufficient clock cycles are available for the processing requirements of the DSP core. The
requirements vary, according to the particular software that is in use.
4.16.2 Sample-Rate Control
The CS42L92 supports two independent clock domains for the audio signal paths, referenced to SYSCLK and ASYNCCLK
respectively.
Different sample rates may be selected for each of the audio interfaces (AIF1, AIF2, AIF3, SLIMbus), and for the input
(ADC) and output (DAC) paths. Each of these must be referenced either to SYSCLK or to ASYNCCLK. (Note that the
SLIMbus interface supports multiple sample rates, selected independently for each input or output channel.)
Up to three different sample rates can be selected using SAMPLE_RATE_1, SAMPLE_RATE_2 and SAMPLE_RATE_3.
These must each be numerically related to each other and to the SYSCLK frequency (further details of these requirements
are provided in Table 4-102 and the accompanying text).
The remaining two sample rates can be selected using ASYNC_SAMPLE_RATE_1 and ASYNC_SAMPLE_RATE_2.
These sample rates must be numerically related to each other and to the ASYNCCLK frequency (further details of these
requirements are provided in Table 4-103 and the accompanying text),
Each of the audio interfaces, input paths, and output paths is associated with one of the sample rates selected by the
SAMPLE_RATE_n or ASYNC_SAMPLE_RATE_n fields.
Note that if any two interfaces are operating at the same sample rate, but are not synchronized, one of these must be
referenced to the ASYNCCLK domain, and the other to the SYSCLK domain.
When any of the SAMPLE_RATE_n or ASYNC_SAMPLE_RATE_n fields is written to, the activation of the new setting is
automatically synchronized by the CS42L92 to ensure continuity of all active signal paths. The SAMPLE_RATE_n_STS
and ASYNC_SAMPLE_RATE_n_STS bits provide indication of the sample rate selections that have been implemented.
220
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
The following restrictions must be observed regarding the sample-rate control configuration:
•
Unless otherwise noted, the sample rate selection for all functions is valid from 8–192 kHz.
•
The input (ADC/DMIC) signal paths must always be associated with the SYSCLK clocking domain.
•
If 384- or 768-kHz DMICCLK clock rate is selected, the supported sample rate for the respective input paths is
restricted as described in Table 4-1. The sample rate for the input signal paths can be set globally, or can be
configured independently for each input channel—see Section 4.2.5.
•
The S/PDIF sample rate is valid from 32–192 kHz. The output (DAC), digital audio interface (AIF), DSP core, and
SLIMbus input/output sample rates are valid from 8–384 kHz.
•
The asynchronous sample-rate converter (ASRC) supports sample rates 8–192 kHz. The ratio of the two sample
rates must not exceed 6.
•
The isochronous sample-rate converters (ISRCs) support sample rates 8–384 kHz. For each ISRC, the ratio of the
applicable SAMPLE_RATE_n or ASYNC_SAMPLE_RATE_n fields must not exceed 24. The sample-rate
conversion ratio must be an integer (1–24) or equal to 1.5.
•
All external clock references (MCLK input or Slave Mode AIF input) must be within 1% of the applicable register
field settings.
4.16.3 Automatic Sample-Rate Detection
The CS42L92 supports automatic sample-rate detection on the digital audio interfaces (AIF1–AIF3). Note that this is only
possible when the respective interface is operating in Slave Mode (i.e., when LRCLK and BCLK are inputs to the
CS42L92).
Automatic sample-rate detection is enabled by setting RATE_EST_ENA. The LRCLK input pin selected for sample-rate
detection is set using LRCLK_SRC.
As many as four audio sample rates can be configured for automatic detection; these sample rates are selected using the
SAMPLE_RATE_DETECT_n fields. Note that the function only detects sample rates that match one of the SAMPLE_
RATE_DETECT_n fields.
If one of the selected audio sample rates is detected on the selected LRCLK input, the control-write sequencer is triggered.
A unique sequence of actions may be programmed for each detected sample rate. Note that the applicable control
sequences must be programmed by the user for each detection outcome; see Section 4.18.
The TRIG_ON_STARTUP bit controls whether the sample-rate detection circuit responds to the initial detection of the
applicable interface (i.e., when the AIFn interface starts up).
•
If TRIG_ON_STARTUP = 0, the detection circuit only responds (i.e., trigger the control-write sequencer) to a
change in the detected sample rate—the initial sample-rate detection is ignored. (Note that the initial sample-rate
detection is the first detection of a sample rate that matches one of the SAMPLE_RATE_DETECT_n fields.)
•
If TRIG_ON_STARTUP = 1, the detection circuit triggers the control-write sequencer whenever a selected sample
rate is detected, including when the AIF interface starts up, or when the sample-rate detection is first enabled.
As described above, setting TRIG_ON_STARTUP = 0 is designed to inhibit any response to the initial detection of a
sample rate that matches one of the SAMPLE_RATE_DETECT_n fields. Note that, if the LRCLK_SRC setting is changed,
or if the detection function is disabled and reenabled, a subsequent detection of a matching sample rate may trigger the
control-write sequencer, regardless of the TRIG_ON_STARTUP setting.
There are some restrictions to be observed regarding the automatic sample-rate detection configuration, as noted in the
following:
•
The same sample rate must not be selected on more than one of the SAMPLE_RATE_DETECT_n fields.
•
Sample rates 384 kHz and 352.8 kHz must not be selected concurrently.
•
Sample rates 192 kHz and 176.4 kHz must not be selected concurrently.
•
Sample rates 96 kHz and 88.2 kHz must not be selected concurrently.
The control registers associated with the automatic sample-rate detection function are described in Table 4-104.
DS1162F1
221
CS42L92
4.16 Clocking and Sample Rates
4.16.4 System Clock Configuration
The system clocks (SYSCLK, ASYNCCLK and DSPCLK) may be provided directly from external inputs (MCLK, or Slave
Mode BCLK inputs). Alternatively, these clocks can be derived using the integrated FLLs, with MCLK, BCLK, LRCLK or
SLIMCLK as a reference. Each clock is configured independently, as described in the following sections.
The SYSCLK (and ASYNCCLK, when applicable) clocks must be configured and enabled before any audio path is
enabled. The DSPCLK clock must be configured and enabled, if running firmware applications on the DSP core.
4.16.4.1 SYSCLK Configuration
The required SYSCLK frequency is dependent on the SAMPLE_RATE_n fields. Table 4-102 illustrates the valid SYSCLK
frequencies for every supported sample rate.
The SYSCLK frequency must be valid for all of the SAMPLE_RATE_n fields. It follows that all of the SAMPLE_RATE_n
fields must select numerically-related values, that is, all from the same group of sample rates as represented in
Table 4-102.
Table 4-102. SYSCLK Frequency Selection
SYSCLK Frequency (MHz)
6.144
12.288
24.576
49.152
98.304
SYSCLK_FREQ
000
001
010
011
100
SYSCLK_FRAC
0
Sample Rate (kHz)
SAMPLE_RATE_n
12
0x01
24
0x02
48
0x03
96
0x04
192
0x05
384
0x06
8
0x11
16
0x12
32
0x13
5.6448
000
1
11.025
0x09
11.2896
001
22.05
0x0A
22.5792
010
44.1
0x0B
45.1584
011
88.2
0x0C
90.3168
100
176.4
0x0D
352.8
0x0E
Note: The SAMPLE_RATE_n fields must each be set to a value from the same group of sample rates, and from the same
group as the SYSCLK frequency.
SYSCLK_SRC is used to select the SYSCLK source, as described in Table 4-104. The source may be MCLKn,
AIFnBCLK, or FLLn. If an FLL circuit is selected as the source, the relevant FLL must be enabled and configured, as
described in Section 4.16.8.
Notes: If FLL1 is selected as SYSCLK source, two different clock frequencies are available. Typical use cases should
select a SYSCLK frequency equal to FFLL1 × 2 (i.e., in the range 90–100 MHz). A lower frequency selection, equal
to FFLL1, is provided to support low-power always-on use cases.
If FLL2 is selected as SYSCLK source, the SYSCLK frequency is FFLL2 × 2 (i.e., 90–100 MHz).
SYSCLK_FREQ and SYSCLK_FRAC must be set according to the frequency of the selected SYSCLK source.
The SYSCLK-referenced circuits within the digital core are clocked at a dynamically controlled rate this is limited by the
SYSCLK frequency. For maximum signal mixing and processing capacity, the highest possible SYSCLK frequency should
be used.
The SAMPLE_RATE_n fields are set according to the sample rates that are required by one or more of the CS42L92 audio
interfaces. The CS42L92 supports sample rates ranging from 8–384 kHz. See Section 4.16.2 for further details of the
supported sample rates for each of the digital-core functions.
The SYSCLK signal is enabled by setting SYSCLK_ENA. The applicable clock source (MCLKn, AIFnBCLK, or FLLn) must
be enabled before setting SYSCLK_ENA. This bit should be cleared before stopping or removing the applicable clock
source.
222
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
The CS42L92 supports seamless switching between clock sources. To change the SYSCLK configuration while SYSCLK
is enabled, the SYSCLK_FRAC, SYSCLK_FREQ, and SYSCLK_SRC fields must be updated together in one register
write operation. Note that, if changing the frequency only (not the source), SYSCLK_ENA should be cleared before the
clock frequency is updated. The current SYSCLK frequency and source can be read from the SYSCLK_FREQ_STS and
SYSCLK_SRC_STS fields respectively.
The CS42L92 performs automatic checks to confirm that the SYSCLK frequency is high enough to support the
commanded signal paths and processing functions. If the frequency is too low, an attempt to enable a signal path or
processing function fails. Note that active signal paths are not affected under such circumstances.
The SYSCLK frequency check provides input to the interrupt-control circuit and can be used to trigger an interrupt event
if the frequency is not high enough to support the commanded functionality; see Section 4.15.
4.16.4.2 ASYNCCLK Configuration
The required ASYNCCLK frequency is dependent on the ASYNC_SAMPLE_RATE_n fields. Table 4-103 illustrates the
valid ASYNCCLK frequencies for every supported sample rate.
Note that, if all the sample rates in the system are synchronized to SYSCLK, the ASYNCCLK should be disabled (see
Table 4-104). The associated register field values are not important in this case.
Table 4-103. ASYNCCLK Frequency Selection
ASYNCCLK Frequency (MHz)
6.144
12.288
24.576
49.152
98.304
ASYNC_CLK_FREQ
000
001
010
011
100
Sample Rate (kHz)
ASYNC_SAMPLE_RATE_n
12
0x01
24
0x02
48
0x03
96
0x04
192
0x05
384
0x06
8
0x11
16
0x12
32
0x13
5.6448
000
11.025
0x09
11.2896
001
22.05
0x0A
22.5792
010
44.1
0x0B
45.1584
011
88.2
0x0C
90.3168
100
176.4
0x0D
352.8
0x0E
Note: The ASYNC_SAMPLE_RATE_n fields must each be set to a value from the same group of sample rates, and
from the same group as the ASYNCCLK frequency.
ASYNC_CLK_SRC is used to select the ASYNCCLK source, as described in Table 4-104. The source may be MCLKn,
AIFnBCLK, or FLLn. If an FLL circuit is selected as the source, the relevant FLL must be enabled and configured, as
described in Section 4.16.8.
Notes: If FLL1 is selected as ASYNCCLK source, two different clock frequencies are available. Typical use cases should
select a SYSCLK frequency equal to FFLL1 × 2 (i.e., in the range 90–100 MHz). A lower frequency selection, equal
to FFLL1, is provided to support low-power always-on use cases.
If FLL2 is selected as ASYNCCLK source, the ASYNCCLK frequency is FFLL2 × 2 (i.e., 90–100 MHz).
ASYNC_CLK_FREQ is set according to the frequency of the selected ASYNCCLK source.
The ASYNCCLK-referenced circuits within the digital core are clocked at a dynamically controlled rate that is limited by
the ASYNCCLK frequency. For maximum signal mixing and processing capacity, the highest possible ASYNCCLK
frequency should be used.
The ASYNC_SAMPLE_RATE_n fields are set according to the sample rates of any audio interface that is not
synchronized to the SYSCLK clock domain.
DS1162F1
223
CS42L92
4.16 Clocking and Sample Rates
The ASYNCCLK signal is enabled by setting ASYNC_CLK_ENA. The applicable clock source (MCLKn, AIFnBCLK, or
FLLn) must be enabled before setting ASYNC_CLK_ENA. This bit should be cleared before stopping or removing the
applicable clock source.
The CS42L92 supports seamless switching between clock sources. To change the ASYNCCLK configuration while
ASYNCCLK is enabled, the ASYNC_CLK_FREQ and ASYNC_CLK_SRC fields must be updated together in one register
write operation. Note that, if changing the frequency only (not the source), ASYNC_CLK_ENA should be cleared before
the clock frequency is updated. The current ASYNCCLK frequency and source can be read from the ASYNC_CLK_
FREQ_STS and ASYNC_CLK_SRC_STS fields respectively.
The CS42L92 performs automatic checks to confirm that the ASYNCCLK frequency is high enough to support the
commanded signal paths and processing functions. If the frequency is too low, an attempt to enable a signal path or
processing function fails. Note that active signal paths are not affected under such circumstances.
The ASYNCCLK frequency check provides input to the interrupt-control circuit and can be used to trigger an interrupt event
if the frequency is not high enough to support the commanded functionality; see Section 4.15.
4.16.4.3 DSPCLK Configuration
The required DSPCLK frequency depends on the requirements of firmware loaded on the DSP core. The DSP is clocked
at the DSPCLK rate or at supported divisions of the DSPCLK frequency; the DSPCLK configuration must ensure that
sufficient clock cycles are available for the processing requirements. The requirements vary, according to the particular
firmware that is in use.
A configurable clock divider is provided for the DSP core, allowing the DSP clocking (and power consumption) to be
optimized according to the applicable processing requirements; see Section 4.4 for details.
DSP_CLK_FREQ must be configured for the applicable DSPCLK frequency. This field is coded in LSB units of 1/64 MHz.
Note that, if the field coding cannot represent the DSPCLK frequency exactly, the DSPCLK frequency must be rounded
down in the DSP_CLK_FREQ field.
The suggested method for calculating DSP_CLK_FREQ is to multiply the DSPCLK frequency by 64, round down to the
nearest integer, and use the resulting integer as DSP_CLK_FREQ (LSB = 1).
DSP_CLK_SRC is used to select the DSPCLK source, as described in Table 4-104. The source may be MCLKn,
AIFnBCLK, or FLLn. If an FLL circuit is selected as the source, the relevant FLL must be enabled and configured, as
described in Section 4.16.8.
Notes: If FLL1 is selected as DSPCLK source, two different clock frequencies are available. Typical use cases should
select a DSPCLK frequency equal to FFLL1 × 3 (i.e., in the range 135–150 MHz). A lower frequency selection,
equal to FFLL1, is provided to support low-power always-on use cases.
If FLL2 is selected as DSPCLK source, the DSPCLK frequency is FFLL2 × 3 (i.e., 135–150 MHz).
The DSPCLK signal is enabled by setting DSP_CLK_ENA. The applicable clock source (MCLKn, AIFnBCLK, or FLLn)
must be enabled before setting DSP_CLK_ENA. This bit should be cleared when reconfiguring the clock sources.
The CS42L92 supports seamless switching between clock sources. To change the DSPCLK configuration while DSPCLK
is enabled, the DSP_CLK_FREQ field must be updated before DSP_CLK_SRC. The new configuration becomes effective
when the DSP_CLK_SRC field is written. Note that, if changing the frequency only (not the source), the DSP_CLK_ENA
bit should be cleared before the clock frequency is updated. The current DSPCLK frequency and source can be read from
the DSP_CLK_FREQ_STS and DSP_CLK_SRC_STS fields respectively.
In a typical application, DSPCLK and SYSCLK are derived from a single FLL source. Note that there is no requirement for
DSPCLK to be synchronized to SYSCLK or ASYNCCLK. The DSPCLK controls the software execution in the DSP core;
audio outputs from the DSP core are synchronized either to SYSCLK or ASYNCCLK, regardless of the applicable
DSPCLK rate.
224
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
4.16.5 Miscellaneous Clock Controls
The CS42L92 incorporates a 32-kHz clock circuit, which is required for input signal debounce, microphone/accessory
detect, and for the Charge Pump 2 (CP2) circuits. The 32-kHz clock must be configured and enabled whenever any of
these features are used.
The 32-kHz clock can be generated automatically from SYSCLK, or may be provided externally via the MCLK1 or MCLK2
input pins. The 32-kHz clock source is selected using CLK_32K_SRC. The 32-kHz clock is enabled by setting CLK_32K_
ENA.
A clock output (OPCLK) derived from SYSCLK can be output on a GPIO pin. A clock output (OPCLK_ASYNC) derived
from ASYNCCLK can be output on a GPIO pin. See Section 4.14 for details on configuring a GPIO pin for these functions.
The CS42L92 provides integrated pull-down resistors on the MCLK1, MCLK2, and MCLK3 pins. This provides a flexible
capability for interfacing with other devices.
The clocking scheme for the CS42L92 is shown in Fig. 4-65.
DS1162F1
225
CS42L92
4.16 Clocking and Sample Rates
32k Clock
CLK_32K_ENA p. 227
CLK_32K_SRC[1:0] p. 227
Divider
(Auto)
OPCLK
OPCLK_ENA p. 231
MCLK1
MCLK2
MCLK3
Divider
OPCLK_SEL[2:0] p. 231
OPCLK_DIV[4:0] p. 231
AIF1BCLK
AIF2BCLK
AIF3BCLK
SYSCLK
SYSCLK_ENA p. 227
x2
x2
OPCLK_
ASYNC
SYSCLK_SRC[3:0] p. 227
OPCLK_ASYNC_ENA p. 231
Divider
OPCLK_ASYNC_SEL[2:0] p. 231
OPCLK_ASYNC_DIV[4:0] p. 231
ASYNCCLK
ASYNC_CLK_ENA p. 229
x2
x2
ASYNC_CLK_SRC[3:0] p. 229
DSPCLK
DSP_CLK_ENA p. 230
x3
x3
DSP_CLK_SRC[3:0] p. 230
FLL1
GPIO
Divider
FLL1_GPCLK_ENA p. 196
FLL1_REFCLK_SRC[3:0] p. 239
FLL1_GPCLK_DIV[6:0] p. 196
(see note )
FLL2
GPIO
Divider
FLL2_GPCLK_ENA p. 196
FLL2_REFCLK_SRC[3:0] p. 241
FLL2_GPCLK_DIV[6:0] p. 196
(see note )
Automatic Clocking Control
Note:
AIFnLRCLK and SLIMCLK can also be
selected as FLLn input reference .
SYSCLK_FREQ[2:0] p. 227
SYSCLK_FRAC p. 227
ASYNC_CLK_FREQ[2:0] p. 229
DSP_CLK_FREQ[15:0] p. 230
SAMPLE_RATE_1[4:0] p. 228
SAMPLE_RATE_2[4:0] p. 228
SAMPLE_RATE_3[4:0] p. 228
ASYNC_SAMPLE_RATE_1[4:0] p. 229
ASYNC_SAMPLE_RATE_2[4:0] p. 229
Figure 4-65. System Clocking
226
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
The CS42L92 clocking control registers are described in Table 4-104.
Table 4-104. Clocking Control
Register Address
R256 (0x0100)
Clock_32k_1
R257 (0x0101)
System_Clock_1
Bit
6
Label
CLK_32K_ENA
1:0
CLK_32K_
SRC[1:0]
10
15
SYSCLK_FRAC
0
10:8 SYSCLK_
FREQ[2:0]
6
3:0
DS1162F1
SYSCLK_ENA
SYSCLK_
SRC[3:0]
Default
0
100
0
0100
Description
32kHz Clock Enable
0 = Disabled
1 = Enabled
32kHz Clock Source
00 = MCLK1 (direct)
01 = MCLK2 (direct)
10 = SYSCLK (automatically divided)
11 = Reserved
SYSCLK Frequency
0 = SYSCLK is a multiple of 6.144MHz
1 = SYSCLK is a multiple of 5.6448MHz
SYSCLK Frequency
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
011 = 49.152 MHz (45.1584 MHz)
100 = 98.304 MHz (90.3168 MHz)
All other codes are reserved
The frequencies in brackets apply for 44.1 kHz–related sample rates only (i.e.,
SAMPLE_RATE_n = 01XXX).
SYSCLK Control
0 = Disabled
1 = Enabled
SYSCLK should only be enabled after the applicable clock source has been
configured and enabled.
Clear this bit before stopping the reference clock or changing the reference clock
frequency. Note that the SYSCLK frequency can be changed without disabling,
provided the clock source is also changed at the same time.
SYSCLK Source
0000 = MCLK1
0001 = MCLK2
0010 = MCLK3
0100 = FLL1 × 2
0101 = FLL2 × 2
1000 = AIF1BCLK
1001 = AIF2BCLK
1010 = AIF3BCLK
1111 = FLL1
All other codes are reserved
227
CS42L92
4.16 Clocking and Sample Rates
Table 4-104. Clocking Control (Cont.)
Register Address
R258 (0x0102)
Sample_rate_1
Bit
4:0
Label
SAMPLE_RATE_
1[4:0]
Default
0x11
R259 (0x0103)
Sample_rate_2
R260 (0x0104)
Sample_rate_3
R266 (0x010A)
Sample_rate_1_
status
R267 (0x010B)
Sample_rate_2_
status
R268 (0x010C)
Sample_rate_3_
status
4:0
SAMPLE_RATE_
2[4:0]
0x11
4:0
SAMPLE_RATE_
3[4:0]
0x11
4:0
SAMPLE_RATE_
1_STS[4:0]
0x00
4:0
SAMPLE_RATE_
2_STS[4:0]
0x00
Sample Rate 2 Status (Read only)
Field coding is same as SAMPLE_RATE_1.
4:0
SAMPLE_RATE_
3_STS[4:0]
0x00
Sample Rate 3 Status (Read only)
Field coding is same as SAMPLE_RATE_1.
228
Description
Sample Rate 1 Select
0x00 = None
0x01 = 12 kHz
0x02 = 24 kHz
0x03 = 48 kHz
0x04 = 96 kHz
0x05 = 192 kHz
0x06 = 384 kHz
0x09 = 11.025 kHz
0x0A = 22.05 kHz
0x0B = 44.1 kHz
0x0C = 88.2 kHz
0x0D = 176.4 kHz
0x0E = 352.8 kHz
0x11 = 8 kHz
0x12 = 16 kHz
0x13 = 32 kHz
All other codes are reserved
Sample Rate 2 Select
Field coding is same as SAMPLE_RATE_1.
Sample Rate 3 Select
Field coding is same as SAMPLE_RATE_1.
Sample Rate 1 Status (Read only)
Field coding is same as SAMPLE_RATE_1.
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
Table 4-104. Clocking Control (Cont.)
Register Address Bit
Label
R274 (0x0112)
10:8 ASYNC_CLK_
FREQ[2:0]
Async_clock_1
Default
011
Description
ASYNCCLK Frequency
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
011 = 49.152 MHz (45.1584 MHz)
100 = 98.304 MHz (90.3168 MHz)
All other codes are reserved
The frequencies in brackets apply for 44.1 kHz–related sample rates only (i.e.,
ASYNC_SAMPLE_RATE_n = 01XXX).
ASYNCCLK Control
0 = Disabled
1 = Enabled
ASYNCCLK should only be enabled after the applicable clock source has been
configured and enabled.
Clear this bit before stopping the reference clock or changing the reference clock
frequency. Note that the ASYNCCLK frequency can be changed without disabling,
provided the clock source is also changed at the same time.
ASYNCCLK Source
0000 = MCLK1
0001 = MCLK2
0010 = MCLK3
0100 = FLL1 × 2
0101 = FLL2 × 2
1000 = AIF1BCLK
1001 = AIF2BCLK
1010 = AIF3BCLK
1111 = FLL1
All other codes are reserved
ASYNC Sample Rate 1 Select
0x00 = None
0x01 = 12 kHz
0x02 = 24 kHz
0x03 = 48 kHz
0x04 = 96 kHz
0x05 = 192 kHz
0x06 = 384 kHz
0x09 = 11.025 kHz
0x0A = 22.05 kHz
0x0B = 44.1 kHz
0x0C = 88.2 kHz
0x0D = 176.4 kHz
0x0E = 352.8 kHz
0x11 = 8 kHz
0x12 = 16 kHz
0x13 = 32 kHz
All other codes are reserved
ASYNC Sample Rate 2 Select
Field coding is same as ASYNC_SAMPLE_RATE_1.
6
ASYNC_CLK_
ENA
0
3:0
ASYNC_CLK_
SRC[3:0]
0101
R275 (0x0113)
Async_sample_
rate_1
4:0
ASYNC_
SAMPLE_RATE_
1[4:0]
0x11
R276 (0x0114)
Async_sample_
rate_2
R283 (0x011B)
Async_sample_
rate_1_status
R284 (0x011C)
Async_sample_
rate_2_status
4:0
ASYNC_
SAMPLE_RATE_
2[4:0]
0x11
4:0
ASYNC_
SAMPLE_RATE_
1_STS[4:0]
0x00
ASYNC Sample Rate 1 Status (Read only)
Field coding is same as ASYNC_SAMPLE_RATE_1.
4:0
ASYNC_
SAMPLE_RATE_
2_STS[4:0]
0x00
ASYNC Sample Rate 2 Status (Read only)
Field coding is same as ASYNC_SAMPLE_RATE_1.
DS1162F1
229
CS42L92
4.16 Clocking and Sample Rates
Table 4-104. Clocking Control (Cont.)
Register Address
R288 (0x0120)
DSP_Clock_1
Bit
6
Label
DSP_CLK_ENA
3:0
DSP_CLK_
SRC[3:0]
Default
0
0101
R290 (0x0122)
DSP_Clock_2
15:0 DSP_CLK_
FREQ[15:0]
0x0000
R294 (0x0126)
DSP_Clock_4
R295 (0x0127)
DSP_Clock_5
15:0 DSP_CLK_
FREQ_STS[15:0]
0x0000
230
3:0
DSP_CLK_SRC_
STS[3:0]
0101
Description
DSPCLK Control
0 = Disabled
1 = Enabled
DSPCLK should only be enabled after the applicable clock source has been
configured and enabled.
Clear this bit before stopping the reference clock or changing the reference clock
frequency. Note that the DSPCLK frequency can be changed without disabling,
provided the clock source is also changed at the same time.
DSPCLK Source
0000 = MCLK1
0001 = MCLK2
0010 = MCLK3
0100 = FLL1 × 3
0101 = FLL2 × 3
1000 = AIF1BCLK
1001 = AIF2BCLK
1010 = AIF3BCLK
1111 = FLL1
All other codes are reserved
DSPCLK Frequency
Coded as LSB = 1/64 MHz, Valid from 5.6 MHz to 148 MHz.
Note that, if this field is written while DSPCLK is enabled, the new frequency does
not become effective until DSP_CLK_SRC is updated. To reconfigure DSPCLK
while DSPCLK is enabled, the DSP_CLK_FREQ field must be updated before
DSP_CLK_SRC.
DSPCLK Frequency (Read only)
Coded as LSB = 1/64 MHz.
DSPCLK Source (Read only)
0000 = MCLK1
0001 = MCLK2
0010 = MCLK3
0100 = FLL1 × 3
0101 = FLL2 × 3
1000 = AIF1BCLK
1001 = AIF2BCLK
1010 = AIF3BCLK
1111 = FLL1
All other codes are reserved
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
Table 4-104. Clocking Control (Cont.)
Register Address
R329 (0x0149)
Output_system_
clock
R330 (0x014A)
Output_async_
clock
R334 (0x014E)
Clock_Gen_Pad_
Ctrl
DS1162F1
Bit
15
Label
OPCLK_ENA
Default
0
7:3
OPCLK_DIV[4:0]
0x00
2:0
OPCLK_SEL[2:0]
000
15
OPCLK_ASYNC_
ENA
0
7:3
OPCLK_ASYNC_
DIV[4:0]
0x00
2:0
OPCLK_ASYNC_
SEL[2:0]
000
9
MCLK3_PD
0
8
MCLK2_PD
0
7
MCLK1_PD
0
Description
OPCLK Enable
0 = Disabled
1 = Enabled
OPCLK Divider
0x02 = Divide by 2
0x04 = Divide by 4
0x06 = Divide by 6
… (even numbers only)
0x1E = Divide by 30
Note that only even numbered divisions (2, 4, 6, etc.) are valid selections.
All other codes are reserved when the OPCLK signal is enabled.
OPCLK Source Frequency
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
011 = 49.152 MHz (45.1584 MHz)
All other codes are reserved
The frequencies in brackets apply for 44.1 kHz–related SYSCLK rates only (i.e.,
SAMPLE_RATE_n = 01XXX).
The OPCLK Source Frequency must be less than or equal to the SYSCLK
frequency.
OPCLK_ASYNC Enable
0 = Disabled
1 = Enabled
OPCLK_ASYNC Divider
0x02 = Divide by 2
0x04 = Divide by 4
0x06 = Divide by 6
… (even numbers only)
0x1E = Divide by 30
Note that only even numbered divisions (2, 4, 6, etc.) are valid selections.
All other codes are reserved when the OPCLK_ASYNC signal is enabled.
OPCLK_ASYNC Source Frequency
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
011 = 49.152 MHz (45.1584 MHz)
All other codes are reserved
The frequencies in brackets apply for 44.1 kHz–related ASYNCCLK rates only
(i.e., ASYNC_SAMPLE_RATE_n = 01XXX).
The OPCLK_ASYNC Source Frequency must be less than or equal to the
ASYNCCLK frequency.
MCLK3 Pull-Down Control
0 = Disabled
1 = Enabled
MCLK2 Pull-Down Control
0 = Disabled
1 = Enabled
MCLK1 Pull-Down Control
0 = Disabled
1 = Enabled
231
CS42L92
4.16 Clocking and Sample Rates
Table 4-104. Clocking Control (Cont.)
Register Address
R338 (0x0152)
Rate_Estimator_1
Bit
4
Label
TRIG_ON_
STARTUP
3:1
LRCLK_SRC[2:0]
000
0
RATE_EST_ENA
0
R339 (0x0153)
Rate_Estimator_2
4:0
SAMPLE_RATE_
DETECT_A[4:0]
0x00
R340 (0x0154)
Rate_Estimator_3
4:0
SAMPLE_RATE_
DETECT_B[4:0]
0x00
R341 (0x0155)
Rate_Estimator_4
4:0
SAMPLE_RATE_
DETECT_C[4:0]
0x00
R342 (0x0156)
Rate_Estimator_5
4:0
SAMPLE_RATE_
DETECT_D[4:0]
0x00
232
Default
0
Description
Automatic Sample-Rate Detection Start-Up select
0 = Do not trigger Write Sequencer on initial detection
1 = Always trigger the Write Sequencer on sample-rate detection
Automatic Sample-Rate Detection source
000 = AIF1LRCLK
010 = AIF2LRCLK
100 = AIF3LRCLK
All other codes are reserved
Automatic Sample-Rate Detection control
0 = Disabled
1 = Enabled
Automatic Detection Sample Rate A
(Up to four different sample rates can be configured for automatic detection.)
Field coding is same as SAMPLE_RATE_n.
Automatic Detection Sample Rate B
(Up to four different sample rates can be configured for automatic detection.)
Field coding is same as SAMPLE_RATE_n.
Automatic Detection Sample Rate C
(Up to four different sample rates can be configured for automatic detection.)
Field coding is same as SAMPLE_RATE_n.
Automatic Detection Sample Rate D
(Up to four different sample rates can be configured for automatic detection.)
Field coding is same as SAMPLE_RATE_n.
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
Table 4-104. Clocking Control (Cont.)
Register Address Bit
Label
R352 (0x0160)
15:13 ASYNC_CLK_
FREQ_STS[2:0]
Clocking_debug_5
Default
000
12:9 ASYNC_CLK_
SRC_STS[3:0]
0000
6:4
SYSCLK_FREQ_
STS[2:0]
000
3:0
SYSCLK_SRC_
STS[3:0]
0000
Description
ASYNCCLK Frequency (Read only)
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
011 = 49.152 MHz (45.1584 MHz)
100 = 98.304 MHz (90.3168 MHz)
All other codes are reserved
The frequencies in brackets apply for 44.1 kHz–related sample rates only (i.e.,
ASYNC_SAMPLE_RATE_n = 01XXX).
ASYNCCLK Source (Read only)
0000 = MCLK1
0001 = MCLK2
0010 = MCLK3
0100 = FLL1 × 2
0101 = FLL2 × 2
1000 = AIF1BCLK
1001 = AIF2BCLK
1010 = AIF3BCLK
1111 = FLL1
All other codes are reserved
SYSCLK Frequency (Read only)
000 = 6.144 MHz (5.6448 MHz)
001 = 12.288 MHz (11.2896 MHz)
010 = 24.576 MHz (22.5792 MHz)
011 = 49.152 MHz (45.1584 MHz)
100 = 98.304 MHz (90.3168 MHz)
All other codes are reserved
The frequencies in brackets apply for 44.1 kHz–related sample rates only (i.e.,
SAMPLE_RATE_n = 01XXX).
SYSCLK Source (Read only)
0000 = MCLK1
0001 = MCLK2
0010 = MCLK3
0100 = FLL1 × 2
0101 = FLL2 × 2
1000 = AIF1BCLK
1001 = AIF2BCLK
1010 = AIF3BCLK
1111 = FLL1
All other codes are reserved
In AIF Slave Modes, it is important to ensure that the applicable clock domain (SYSCLK or ASYNCCLK) is synchronized
with the associated external LRCLK. This can be achieved by selecting an MCLKn input that is derived from the same
reference as the LRCLK, or can be achieved by selecting the external BCLK or LRCLK signal as a reference input to one
of the FLLs, as a source for SYSCLK or ASYNCCLK.
If the AIF clock domain is not synchronized with the LRCLK, clicks arising from dropped or repeated audio samples occur,
due to the inherent tolerances of multiple, asynchronous, system clocks. See Section 5.4 for further details on valid
clocking configurations.
4.16.6 BCLK and LRCLK Control
The digital audio interfaces (AIF1–AIF3) use BCLK and LRCLK signals for synchronization. In Master Mode, these are
output signals, generated by the CS42L92. In Slave Mode, these are input signals to the CS42L92. It is also possible to
support mixed master/slave operation.
DS1162F1
233
CS42L92
4.16 Clocking and Sample Rates
The BCLK and LRCLK signals are controlled as shown in Fig. 4-66. See Section 4.7 for details of the associated control
fields.
Note that the BCLK and LRCLK signals are synchronized to SYSCLK or ASYNCCLK, depending upon the applicable clock
domain for the respective interface. See Section 4.3.14 for further details.
SYSCLK
AIF1_BCLK_MSTR p. 131
AIF1_LRCLK_MSTR p. 132
AIF1_BCLK_FREQ[4:0] p. 135
ASYNCCLK
AIF1_BCPF[12:0] p. 135
f/N
Master
Mode
Clock
Outputs
f/N
(see note)
AIF1BCLK
AIF1LRCLK
AIF2_BCLK_MSTR p. 132
AIF2_LRCLK_MSTR p. 132
AIF2_BCLK_FREQ[4:0] p. 136
AIF2_BCPF[12:0] p. 136
f/N
Master
Mode
Clock
Outputs
f/N
(see note)
AIF2BCLK
AIF2LRCLK
AIF3_BCLK_MSTR p. 132
AIF3_LRCLK_MSTR p. 133
AIF3_BCLK_FREQ[4:0] p. 136
AIF3_BCPF[12:0] p. 136
f/N
f/N
(see note)
Master
Mode
Clock
Outputs
AIF3BCLK
AIF3LRCLK
Note:
The clock reference for each AIF is SYSCLK or ASYNCCLK
AIFn is clocked from SYSCLK if AIFn_RATE < 1000
AIFn is clocked from ASYNCCLK if AIFn_RATE >= 1000
Figure 4-66. BCLK and LRCLK Control
4.16.7 Control Interface Clocking
Register map access is possible with or without a system clock—there is no requirement for SYSCLK, or any other system
clock, to be enabled when accessing the register map. See Section 4.17 for details of control register access.
Timing specifications for each of the control interfaces are provided in Table 3-19–Table 3-21. In some applications,
additional system-wide constraints must be observed to ensure control interface limits are not exceeded. These
constraints need to be considered if any of the following conditions is true.
•
SYSCLK is enabled and is < 22.5792 MHz
•
Control-register access is scheduled at register address 0x8_0000 or above
•
Control-register access is scheduled on more than one of the control interfaces simultaneously
The control interface limits vary depending on the system clock (SYSCLK or DSPCLK) configuration, the address of the
control register access, and on which control interfaces are being used.
234
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
Table 4-105 describes valid system conditions for accessing the codec registers (below 0x8_0000). The control interfaces
must operate within the limits represented by one of the permitted configurations shown, in accordance with the applicable
SYSCLK frequency.
Table 4-105. Maximum SPI/SLIMbus Clock Speeds—Codec Register Access
SYSCLK Condition
SYSCLK is disabled, or
SYSCLK 22.5792 MHz
SYSCLK = 12.288 MHz
SYSCLK = 11.2896 MHz
SYSCLK < 11.2896 MHz
SPI
26 MHz
SLIMbus
27 MHz
26 MHz
—
13 MHz
12 MHz
26 MHz
—
12 MHz
9 MHz
13 MHz
—
—
27 MHz
24.576 MHz
27 MHz
—
27 MHz
22.5792 MHz
27 MHz
—
27 MHz
Description
Full concurrent SPI/SLIMbus capability for
codec register access.
SPI and SLIMbus operating in isolation.
SPI and SLIMbus operating concurrently.
SPI and SLIMbus operating in isolation.
SPI and SLIMbus operating concurrently.
SPI and SLIMbus operating in isolation.
Notes:
• If SYSCLK < 11.2896 MHz, simultaneous register access via SPI/SLIMbus control interfaces should not be attempted.
• If SYSCLK is disabled, full concurrent SPI/SLIMbus capability for codec register access is supported.
• The SPI interface limits noted above are only applicable if the SPI interface is accessing codec registers. Options shown with
“—” in the SPI column represent use cases where the SPI interface is either unused, or is being used to access the DSP
registers.
• The SLIMbus interface limits noted above are only applicable if multibyte burst transfers of more than 8 bytes are scheduled.
Options shown with “—” in the SLIMbus column represent use cases where SLIMbus is either unused, or is configured to
support any combination of audio channels, and burst transfers 8 bytes.
• Register access via the I2C interface is supported at all times, regardless of the SLIMbus loading.
Table 4-106 describes valid system conditions for accessing the DSP firmware registers (0x8_0000 and above). The
control interfaces must operate within the limits represented by one of the permitted configurations shown, in accordance
with the applicable DSPCLK frequency.
Table 4-106. Maximum SPI/SLIMbus Clock Speeds—DSP Firmware Register Access
DSPCLK Condition
DSPCLK is disabled, or
DSPCLK 45 MHz
24.576 MHz DSPCLK < 45 MHz
12.288 MHz DSPCLK < 24.576 MHz
SPI
26 MHz
—
26 MHz
21 MHz
26 MHz
—
13 MHz
—
SLIMbus
—
27 MHz
24.576 MHz
27 MHz
—
24.576 MHz
—
12.288 MHz
Description
One high speed interface.
SPI and SLIMbus operating concurrently.
SPI and SLIMbus operating in isolation.
SPI and SLIMbus operating in isolation.
Notes:
• If DSPCLK < 24.576MHz, simultaneous register access via SPI/SLIMbus control interfaces should not be attempted.
• If DSPCLK is disabled, the valid configurations are the same as for DSPCLK 45MHz.
• The SPI interface limits noted above are only applicable if the SPI interface is accessing DSP registers. Options shown with
“—” in the SPI column represent use cases where the SPI interface is either unused, or is being used to access the codec
registers.
• The SLIMbus interface limits noted above are only applicable if multibyte burst transfers of more than 8 bytes are scheduled.
Options shown with “—” in the SLIMbus column represent use cases where SLIMbus is either unused, or is configured to
support any combination of audio channels, and burst transfers 8 bytes.
• Register access via the I2C interface is supported at all times, regardless of the SLIMbus loading.
4.16.8 Frequency-Locked Loop (FLL1, FLL2)
Two integrated FLLs are provided to support the clocking requirements of the CS42L92. These can be configured
according to the available reference clocks and the application requirements. The reference clock may use a high
frequency (e.g., 12.288 MHz) or low frequency (e.g., 32.768 kHz). The FLL is tolerant of jitter and may be used to generate
a stable output clock from a less stable input reference.
DS1162F1
235
CS42L92
4.16 Clocking and Sample Rates
4.16.8.1 Overview
The FLL characteristics are summarized in Table 3-11. In normal operation, the FLL output is frequency locked to an input
clock reference. The FLL can be used to generate a free-running clock in the absence of any external reference, as
described in Section 4.16.8.6.
4.16.8.2 FLL Enable
The FLL is enabled by setting FLLn_ENA (where n = 1 or 2 for the corresponding FLL). Note that the other FLL fields
should be configured before enabling the FLL; the FLLn_ENA bit should be set as the final step of the FLLn enable
sequence.
The FLL supports configurable free-running operation in FLL Hold Mode, using the FLLn_HOLD bit described in
Section 4.16.8.6. If the FLL is enabled and FLL Hold Mode is selected, the configured output frequency is maintained
without any input reference required. Note that, once the FLL output has been established, the FLL is always free running
if the input reference clock is stopped, regardless of the FLLn_HOLD bit.
Note that, to disable the FLL while the input reference clock has stopped, FLLn_HOLD must be set before clearing FLLn_
ENA.
When changing FLL settings, it is recommended to disable the FLL by clearing FLLn_ENA before updating the other
register fields. It is possible to configure the FLL while the FLL is enabled, as described in Section 4.16.8.4. As a general
rule, however, it is recommended to configure the FLL before setting FLLn_ENA.
The procedure for configuring the FLL is described in the following subsections. The description is applicable to FLL1 and
FLL2; the associated control fields are described in Table 4-108 and Table 4-109 respectively.
4.16.8.3 Input Frequency Control
The main input reference is selected using FLLn_REFCLK_SRC. The available options are MCLKn, SLIMCLK,
AIFnBCLK, or AIFnLRCLK.
The SLIMCLK reference is controlled by an adaptive divider on the external SLIMCLK input. The divider automatically
adapts to the SLIMbus clock gear, to provide a constant reference frequency for the FLL—see Section 4.10.3.
The FLLn_REFCLK_DIV field controls a programmable divider on the input reference. The input can be divided by 1, 2, 4
or 8. The divider should be configured to bring each reference down to 13 MHz or below. For best performance, it is
recommended that the highest possible frequency—within the 13 MHz limit—should be selected.
The FLL incorporates a reference-detection circuit for the main input clock. This ensures best FLL performance in the
event of the main input clock being interrupted. If there is a possibility of the main input being interrupted while the FLL is
enabled, then the reference-detection circuit must be enabled by setting FLLn_REFDET. The reference detection also
provides input to the interrupt control circuit and can be used to trigger an interrupt event when the input reference is
stopped—see Section 4.15.
4.16.8.4 Output Frequency Control
The FLL output frequency, FFLL, relative to the main input reference FREF, is a function of:
•
The frequency ratio set by FLLn_FB_DIV
•
The real number represented by N.K. (N = integer; K = fractional portion, i.e., < 1)
The output frequency must be in the range 45–50 MHz.
If the FLL is selected as SYSCLK or ASYNCCLK source, the respective FFLL frequency must be exactly 49.152 MHz (for
48 kHz–related sample rates) or 45.1584 MHz (for 44.1 kHz–related sample rates).
•
If FLL2 is selected as SYSCLK or ASYNCCLK source, the respective clock frequency is equal to FFLL × 2.
•
If FLL1 is selected as SYSCLK or ASYNCCLK source, two different frequencies are available. Typical use cases
should select the higher frequency (FFLL × 2); a lower frequency (FFLL) is available to support low-power always-on
use cases.
236
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
If the FLL is selected as DSPCLK source, the following frequency options are supported:
•
If FLL2 is selected as DSPCLK source, the DSPCLK frequency is in the range 135–150 MHz. The frequency is
equal to FFLL × 3.
•
If FLL1 is selected as DSPCLK source, two different frequencies are available. Typical use cases should select the
higher frequency (FFLL × 3); a lower frequency (FFLL) is available to support low-power always-on use cases.
•
Note that the DSPCLK can be divided to lower frequencies for clocking the DSP core.
The FLL clock can be configured as a GPIO output; a programmable divider supports division ratios in the range 2 through
127, enabling a wide range of GPIO clock output frequencies.
Note:
The chosen FFLL frequency can be used to support multiple outputs simultaneously (e.g., SYSCLK, DSPCLK, and
GPIO).
To configure the FLL output frequency, it must be determined whether Integer Mode or Fractional Mode is required.
•
If the ratio FFLL / FREF is an integer, then Integer Mode applies
•
If the ratio FFLL / FREF is not an integer, then Fractional Mode applies
The input reference must be identified in one of three frequency ranges.
•
If FREF < 192 kHz, this is low clock frequency
•
If FREF 192 kHz and FREF < 1.152 MHz, this is mid clock frequency
•
If FREF 1.152 MHz, this is high clock frequency
Note:
FREF is the input frequency, after division by FLLn_REFCLK_DIV, where applicable.
The FLL oscillator frequency, FOSC, is set according to the applicable mode and input reference frequency.
•
If Fractional Mode is used and FREF is high frequency, then FOSC = FFLL × 6
•
Otherwise, FOSC = FFLL
The FLL oscillator frequency, FOSC, is set according to the following equation:
FOSC = (FREF × N.K × FLLn_FB_DIV)
The FLLn_FB_DIV value should be configured according to the applicable mode and input reference frequency.
•
If Integer Mode is used and FREF is low frequency, then FLLn_FB_DIV should be set to 4
•
If Fractional Mode is used and FREF is low frequency, then FLLn_FB_DIV should be set to 256
•
Otherwise, FLLn_FB_DIV should be set to 1
The value of N.K can be determined as follows:
N.K = FOSC / (FLLn_FB_DIV × FREF)
The calculated value of N must lie within a valid range, according to the applicable mode.
•
If Integer Mode is used, N is valid in the range 1–1023
•
If Fractional Mode is used, N is valid in the range 4–255
If the calculated value of N is too high, a higher FLLn_FB_DIV is required. If the calculated value of N is too low, a lower
FLLn_FB_DIV is required. It is recommended to adjust the FLLn_FB_DIV value by multiplying or dividing by 2 until a valid
N is achieved.
The value of N is held in FLLn_N.
The value of K is determined by the ratio FLLn_THETA / FLLn_LAMBDA. In Fractional Mode, the FLLn_THETA and
FLLn_LAMBDA fields can be derived as described in Section 4.16.8.5.
The FLLn_N, FLLn_THETA, and FLLn_LAMBDA fields are all coded as integers (LSB = 1).
DS1162F1
237
CS42L92
4.16 Clocking and Sample Rates
When changing FLL settings, it is recommended to disable the FLL by clearing FLLn_ENA before updating the other
register fields. If the FLL settings or input reference are changed without disabling the FLL, the FLL Hold Mode must be
selected before writing to any other FLL control fields. FLL Hold Mode is selected by setting FLLn_HOLD.
If the FLL control fields are written while the FLL is enabled (FLLn_ENA = 1), the new values are only effective when a 1
is written to FLLn_CTRL_UPD. This makes it possible to update the FLL configuration fields simultaneously, without
disabling the FLL.
To change FLL settings without disabling the FLL, the recommended control sequence is:
•
Select FLL Hold Mode (FLLn_HOLD = 1)
•
Write to the FLL control fields
•
Update the FLL control registers (write 1 to FLLn_CTRL_UPD)
•
Disable FLL Hold Mode (FLLn_HOLD = 0)
Note that, if the FLL is disabled, the FLL control fields can be updated without writing to FLLn_CTRL_UPD.
The FLLn_PD_GAIN_FINE, FLLn_PD_GAIN_COARSE, FLLn_FD_GAIN_FINE, FLLn_FD_GAIN_COARSE, FLLn_HP,
and FLLn_CLK_VCO_FAST_SRC fields should be configured as described in Table 4-107.
Note:
When writing to the FLLn_CLK_VCO_FAST_SRC or FLLn_HP fields, take care not to change other nonzero bits
that are configured at the same register address.
Table 4-107. FLLn Control Field Settings
Condition
Low clock frequency
Mid clock frequency
High clock frequency
Integer Mode
Fractional Mode, Low clock frequency
Fractional Mode, Mid clock frequency
Fractional Mode, High clock frequency
Integer Mode
Fractional Mode
0x2
0x2
0x2
—
FLLn_PD_
GAIN_
COARSE
0x3
0x2
0x1
—
—
—
FLLn_PD_
GAIN_FINE
0xF
0xF
0xF
—
FLLn_FD_
GAIN_
COARSE
0x0
0x2
0x0
—
—
—
FLLn_FD_
GAIN_FINE
FLLn_
FLLn_CLK_
LOCKDET_
VCO_
THR
FAST_SRC
0x2
—
0x8
0x8
—
0x0
0x0
0x0
0x3
—
—
FLLn_HP
—
—
0x0
0x3
4.16.8.5 Calculation of Theta and Lambda
In Fractional Mode, FLLn_THETA and FLLn_LAMBDA are calculated with the following steps:
1. Calculate GCD(FLL) using the Greatest Common Denominator function:
GCD(FLL) = GCD(FLLn_FB_DIV × FREF, FOSC),
where GCD(x, y) is the greatest common denominator of x and y.
FREF is the input frequency, after division by FLLn_REFCLK_DIV, where applicable.
2. Calculate FLLn_THETA and FLLn_LAMBDA using the following equations:
FLLn_THETA = (FOSC – (FLL_N × FLLn_FB_DIV × FREF)) / GCD(FLL)
FLLn_LAMBDA = (FLLn_FB_DIV × FREF) / GCD(FLL)
Notes: The values of GCD(FLL), FLLn_THETA, and FLLn_LAMBDA should be calculated using the applicable frequency
values in Hz (i.e., not kHz or MHz).
In Fractional Mode, the values of FLLn_THETA and FLLn_LAMBDA must be coprime (i.e., not divisible by any
common integer). The calculation above ensures that the values are coprime.
The value of K must be less than 1 (i.e., FLLn_THETA must be less than FLLn_LAMBDA).
238
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
4.16.8.6 FLL Hold Mode
FLL Hold Mode enables the FLL to generate a clock signal even if no external reference is available, such as when the
normal input reference has been interrupted during a standby or start-up period. FLL Hold Mode is selected by setting
FLLn_HOLD.
If the FLL is enabled and FLL Hold Mode is selected, the normal feedback mechanism of the FLL is halted and the FLL
oscillates independently of the external input references—the FLL output frequency remains unchanged if FLL Hold Mode
is enabled.
If the FLL is enabled and the input reference clock is stopped, the loop always runs freely, regardless of the FLLn_HOLD
setting. If FLLn_HOLD = 0, the FLL relocks to the input reference whenever it is available.
If the FLL configuration or input reference are changed without disabling the FLL, the FLL Hold Mode must be selected
before writing to any other FLL control fields—see Section 4.16.8.4.
The free-running FLL clock may be selected as the SYSCLK, ASYNCCLK, or DSPCLK source, as shown in Fig. 4-65.
4.16.8.7 FLL Control Registers
The FLL1 control registers are described in Table 4-108.
Example settings for a variety of reference frequencies and output frequencies are shown in Section 4.16.8.10.
Table 4-108. FLL1 Register Map
Register Address
R369 (0x0171)
FLL1_Control_1
R370 (0x0172)
FLL1_Control_2
R371 (0x0173)
FLL1_Control_3
R372 (0x0174)
FLL1_Control_4
R373 (0x0175)
FLL1_Control_5
R374 (0x0176)
FLL1_Control_6
DS1162F1
Bit
3:0
Label
FLL1_REFCLK_
SRC[3:0]
Default
Description
0000 FLL1 Clock source
0000 = MCLK1
1000 = AIF1BCLK
1101 = AIF2LRCLK
0001 = MCLK2
1001 = AIF2BCLK
1110 = AIF3LRCLK
0010 = MCLK3
1010 = AIF3BCLK
All other codes are
reserved
0011 = SLIMCLK
1100 = AIF1LRCLK
2 FLL1_HOLD
1
FLL1 Hold Mode Enable
0 = Disabled
1 = Enabled
The FLL feedback mechanism is halted in FLL Hold Mode, and the latest integrator
setting is maintained.
0 FLL1_ENA
0
FLL1 Enable
0 = Disabled
1 = Enabled
This should be set as the final step of the FLL1 enable sequence.
15 FLL1_CTRL_UPD
0
FLL1 Control Update
Write 1 to apply the FLL1 configuration field settings. (Only valid if FLL1_ENA = 1)
9:0 FLL1_N[9:0]
0x004 FLL1 Integer multiply for FREF
Coded as LSB = 1.
15:0 FLL1_
0x0000 FLL1 Fractional multiply for FREF.
THETA[15:0]
Sets the numerator (multiply) part of the FLL1_THETA/FLL1_LAMBDA ratio.
Coded as LSB = 1.
15:0 FLL1_
0x0000 FLL1 Fractional multiply for FREF.
LAMBDA[15:0]
Sets the denominator (dividing) part of the FLL1_THETA/FLL1_LAMBDA ratio.
Coded as LSB = 1.
9:0 FLL1_FB_DIV[9:0] 0x0001 FLL1 Clock Feedback ratio
Coded as LSB = 1.
15 FLL1_REFDET
1
FLL1 Reference Detect control
0 = Disabled
1 = Enabled
7:6 FLL1_REFCLK_
00
FLL1 Clock Reference divider
DIV[1:0]
00 = 1
10 = 4
01 = 2
11 = 8
MCLK (or other input reference) must be divided down to 13 MHz.
239
CS42L92
4.16 Clocking and Sample Rates
Table 4-108. FLL1 Register Map (Cont.)
Register Address Bit
Label
R376 (0x0178)
15:12 FLL1_PD_GAIN_
FINE[3:0]
FLL1_Control_8
R378 (0x017A)
FLL1_Control_10
R379 (0x017B)
FLL1_Control_11
R381 (0x017D)
FLL1_Digital_
Test_1
240
Default
Description
0x2
FLL1 Phase Detector Gain 2
Gain is 2–X, where X is FLL1_PD_GAIN_FINE in 2’s complement coding.
0110 = 2–6
0000 = 1
1100 = 16
0001 = 0.5
0111 = 2–7
1101 = 8
0010 = 0.25
1000 = 256
1110 = 4
0011 = 0.125
1001 = 128
1111 = 2
0100 = 2–4
1010 = 64
1011 = 32
0101 = 2–5
11:8 FLL1_PD_GAIN_
0x1
FLL1 Phase Detector Gain 1
COARSE[3:0]
Gain is 2–X, where X is FLL1_PD_GAIN_COARSE in 2’s complement coding.
0000 = 1
0110 = 2–6
1100 = 16
0001 = 0.5
0111 = 2–7
1101 = 8
0010 = 0.25
1000 = 256
1110 = 4
0011 = 0.125
1001 = 128
1111 = 2
0100 = 2–4
1010 = 64
1011 = 32
0101 = 2–5
7:4 FLL1_FD_GAIN_
0xF
FLL1 Frequency Detector Gain 2
FINE[3:0]
Gain is 2–X, where X is FLL1_FD_GAIN_FINE in integer coding.
1110 = 2–14
0000 = 1
0011 = 0.125
0001 = 0.5
...
1111 = Reserved
0010 = 0.25
1101 = 2–13
3:0 FLL1_FD_GAIN_
0x0
FLL1 Frequency Detector Gain 1
COARSE[3:0]
Gain is 2–X, where X is FLL1_FD_GAIN_COARSE in 2’s complement coding.
0000 = 1
0110 = 2–6
1100 = 16
0001 = 0.5
0111 = 2–7
1101 = 8
0010 = 0.25
1000 = 256
1110 = 4
0011 = 0.125
1111 = 2
1001 = 128
0100 = 2–4
1010 = 64
1011 = 32
0101 = 2–5
15:14 FLL1_HP[1:0]
00
FLL1 Fractional Mode control
00 = Integer mode
10 = Reserved
01 = Reserved
11 = Fractional Mode
4:1 FLL1_LOCKDET_
0x8
FLL1 Lock Detect threshold
THR[3:0]
Valid from 0x0 (low threshold) to 0xF (high threshold)
0 FLL1_LOCKDET
1
FLL1 Lock Detect enabled
0 = Disabled
1 = Enabled
1:0 FLL1_CLK_VCO_
0x0
FLL1 Oscillator Frequency Control
FAST_SRC[1:0]
00 = 45–50 MHz
10 = Reserved
01 = Reserved
11 = 270–300 MHz
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
The FLL2 control registers are described in Table 4-109.
Table 4-109. FLL2 Register Map
Register Address
R401 (0x0191)
FLL2_Control_1
R402 (0x0192)
FLL2_Control_2
R403 (0x0193)
FLL2_Control_3
R404 (0x0194)
FLL2_Control_4
R405 (0x0195)
FLL2_Control_5
R406 (0x0196)
FLL2_Control_6
DS1162F1
Bit
3:0
Label
FLL2_REFCLK_
SRC[3:0]
Default
Description
0111 FLL2 Clock source
1000 = AIF1BCLK
1101 = AIF2LRCLK
0000 = MCLK1
0001 = MCLK2
1001 = AIF2BCLK
1110 = AIF3LRCLK
0010 = MCLK3
1010 = AIF3BCLK
All other codes are
reserved
0011 = SLIMCLK
1100 = AIF1LRCLK
2 FLL2_HOLD
1
FLL2 Hold Mode Enable
0 = Disabled
1 = Enabled
The FLL feedback mechanism is halted in FLL Hold Mode, and the latest integrator
setting is maintained.
0 FLL2_ENA
0
FLL2 Enable
0 = Disabled
1 = Enabled
This should be set as the final step of the FLL2 enable sequence.
15 FLL2_CTRL_UPD
0
FLL2 Control Update
Write 1 to apply the FLL2 configuration field settings. (Only valid if FLL2_ENA = 1)
9:0 FLL2_N[9:0]
0x004 FLL2 Integer multiply for FREF
Coded as LSB = 1.
15:0 FLL2_
0x0000 FLL2 Fractional multiply for FREF.
THETA[15:0]
Sets the numerator (multiply) part of the FLL2_THETA/FLL2_LAMBDA ratio.
Coded as LSB = 1.
15:0 FLL2_
0x0000 FLL2 Fractional multiply for FREF.
LAMBDA[15:0]
Sets the denominator (dividing) part of the FLL2_THETA/FLL2_LAMBDA ratio.
Coded as LSB = 1.
9:0 FLL2_FB_DIV[9:0] 0x0001 FLL2 Clock Feedback ratio
Coded as LSB = 1.
15 FLL2_REFDET
1
FLL2 Reference Detect control
0 = Disabled
1 = Enabled
7:6 FLL2_REFCLK_
00
FLL2 Clock Reference divider
DIV[1:0]
00 = 1
10 = 4
01 = 2
11 = 8
MCLK (or other input reference) must be divided down to 13 MHz.
241
CS42L92
4.16 Clocking and Sample Rates
Table 4-109. FLL2 Register Map (Cont.)
Register Address Bit
Label
R408 (0x0198)
15:12 FLL2_PD_GAIN_
FINE[3:0]
FLL2_Control_8
R410 (0x019A)
FLL2_Control_10
R411 (0x019B)
FLL2_Control_11
R413 (0x019D)
FLL2_Digital_
Test_1
Default
Description
0x2
FLL2 Phase Detector Gain 2
Gain is 2–X, where X is FLL2_PD_GAIN_FINE in 2’s complement coding.
0110 = 2–6
0000 = 1
1100 = 16
0001 = 0.5
0111 = 2–7
1101 = 8
0010 = 0.25
1000 = 256
1110 = 4
0011 = 0.125
1001 = 128
1111 = 2
0100 = 2–4
1010 = 64
1011 = 32
0101 = 2–5
11:8 FLL2_PD_GAIN_
0x1
FLL2 Phase Detector Gain 1
COARSE[3:0]
Gain is 2–X, where X is FLL2_PD_GAIN_COARSE in 2’s complement coding.
0000 = 1
0110 = 2–6
1100 = 16
0001 = 0.5
0111 = 2–7
1101 = 8
0010 = 0.25
1000 = 256
1110 = 4
0011 = 0.125
1001 = 128
1111 = 2
0100 = 2–4
1010 = 64
1011 = 32
0101 = 2–5
7:4 FLL2_FD_GAIN_
0xF
FLL2 Frequency Detector Gain 2
FINE[3:0]
Gain is 2–X, where X is FLL2_FD_GAIN_FINE in integer coding.
1110 = 2–14
0000 = 1
0011 = 0.125
0001 = 0.5
...
1111 = Reserved
0010 = 0.25
1101 = 2–13
3:0 FLL2_FD_GAIN_
0x0
FLL2 Frequency Detector Gain 1
COARSE[3:0]
Gain is 2–X, where X is FLL2_FD_GAIN_COARSE in 2’s complement coding.
0000 = 1
0110 = 2–6
1100 = 16
0001 = 0.5
0111 = 2–7
1101 = 8
0010 = 0.25
1000 = 256
1110 = 4
0011 = 0.125
1111 = 2
1001 = 128
0100 = 2–4
1010 = 64
1011 = 32
0101 = 2–5
15:14 FLL2_HP[1:0]
00
FLL2 Fractional Mode control
00 = Integer mode
10 = Reserved
01 = Reserved
11 = Fractional Mode
4:1 FLL2_LOCKDET_
0x8
FLL2 Lock Detect threshold
THR[3:0]
Valid from 0x0 (low threshold) to 0xF (high threshold)
0 FLL2_LOCKDET
1
FLL2 Lock Detect enabled
0 = Disabled
1 = Enabled
1:0 FLL2_CLK_VCO_
0x0
FLL2 Oscillator Frequency Control
FAST_SRC[1:0]
00 = 45–50 MHz
10 = Reserved
01 = Reserved
11 = 270–300 MHz
4.16.8.8 FLL Interrupts and GPIO Output
For each FLL, the CS42L92 provides status signals that indicate whether the input reference is present and whether FLL
lock has been achieved (i.e., the FLL is locked to the input reference signal).
To enable the FLL lock indication, the FLLn_LOCKDET bit must be set. The FLL lock condition is measured with respect
to a configurable threshold that is set using FLLn_LOCKDET_THR. Note that the FLLn_LOCKDET_THR field controls the
lock indication only—it does not control the behavior of the FLL.
To enable the FLL input reference indication, the FLLn_REFDET bit must be set.
The FLL status signals are inputs to the interrupt control circuit and can be used to trigger an interrupt event when the input
reference is stopped or when the FLL lock status changes. See Section 4.15. Note that these interrupt signals are
debounced and require clocking to be present in order to assert the respective interrupt—either the 32-kHz clock or the
SYSCLK signal must be enabled to trigger an interrupt from the FLL signals.
242
DS1162F1
CS42L92
4.16 Clocking and Sample Rates
The FLL lock signal can be output directly on a GPIO pin as an external indication of the FLL status. See Section 4.14 to
configure a GPIO pin for these functions. (These GPIO outputs are not debounced and do not require clocking to be
present.)
Clock output signals derived from the FLL can be output on a GPIO pin. See Section 4.14 to configure a GPIO pin for this
function.
4.16.8.9 Example FLL Calculation
The following example illustrates how to derive the FLL1 register fields to generate an FLL output frequency (FFLL) of
49.152 MHz from a 12.000-MHz reference clock (FREF). This is suitable for generating SYSCLK at 98.304 MHz and
DSPCLK at 147.456 MHz.
1. Set FLL1_REFCLK_DIV to generate FREF 13 MHz:
FLL1_REFCLK_DIV = 00 (divide by 1)
2. Determine if Integer Mode or Fractional Mode is required:
FFLL / FREF is 4.096. Therefore, Fractional Mode applies.
3. Identify the input clock frequency range:
FREF 1.152 MHz. This is high clock frequency.
4. Calculate the FLL oscillator frequency, FOSC:
In Fractional Mode, with high clock frequency input, FOSC = FFLL × 6 = 294.912 MHz
5. Select the required value of FLL1_FB_DIV:
In Fractional Mode, with high clock frequency input, FLL1_FB_DIV = 1
6. Calculate N.K as given by N.K = FOSC / (FLL1_FB_DIV × FREF):
N.K = 294912000 / (1 × 12000000) = 24.576
7. Confirm that the calculated value of N is within the valid range for fractional mode (4–255).
8. Determine FLL1_N from the integer portion of N.K:
FLL1_N = 24 (0x018)
9. Determine GCD(FLL), as given by GCD(FLL) = GCD(FLL1_FB_DIV × FREF, FOSC):
GCD(FLL) = GCD(1 × 12000000, 294912000) = 96000
10.Determine FLL1_THETA, as given by FLL1_THETA = (FOSC – (FLL1_N × FLL1_FB_DIV × FREF)) / GCD(FLL):
FLL1_THETA = (294912000 – (24 × 1 × 12000000)) / 96000
FLL1_THETA = 72 (0x0048)
11. Determine FLL1_LAMBDA, as given by FLL1_LAMBDA = (FLL1_FB_DIV x FREF) / GCD(FLL):
FLL1_LAMBDA = (1 × 12000000) / 96000
FLL1_LAMBDA = 125 (0x007D)
12.Determine other FLL settings as specified in Table 4-107 for Fractional Mode and high clock frequency input:
FLL1_PD_GAIN_FINE = 0x2
FLL1_PD_GAIN_COARSE = 0x1
FLL1_FD_GAIN_FINE = 0xF
FLL1_FD_GAIN_COARSE = 0x0
FLL1_CLK_VCO_FAST_SRC = 0x3
FLL1_HP = 0x3
DS1162F1
243
CS42L92
4.17 Control Interface
4.16.8.10 Example FLL Settings
Table 4-110 shows FLL settings for generating an output frequency (FFLL) of 49.152 MHz from a variety of low- and
high-frequency reference inputs. This is suitable for generating SYSCLK at 98.304 MHz and DSPCLK at 147.456 MHz.
Table 4-110. Example FLL Settings
FSOURCE
FFLL (MHz)
FREF Divider1
FB_DIV1
N.K 2
FLLn_N
32.000 kHz
32.768 kHz
44.100 kHz
48 kHz
128 kHz
9.6 MHz
10 MHz
11.2896 MHz
12.000 MHz
12.288 MHz
13.000 MHz
19.200 MHz
22.5792 MHz
24 MHz
24.576 MHz
26 MHz
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
49.152
1
1
1
1
1
1
1
1
1
1
1
2
2
2
2
2
4
4
256
4
4
1
1
1
1
1
1
1
1
1
1
1
384
375
4.3537415
256
96
30.72
29.4912
26.12245
24.576
4
22.68554
30.72
26.12245
24.576
4
22.68554
0x180
0x177
0x004
0x100
0x060
0x01E
0x01D
0x01A
0x018
0x004
0x016
0x01E
0x01A
0x018
0x004
0x016
FLLn_
THETA
0x0000
0x0000
0x0034
0x0000
0x0000
0x0012
0x0133
0x0006
0x0048
0x0000
0x045A
0x0012
0x0006
0x0048
0x0000
0x045A
FLLn_
LAMBDA
0x0001
0x0001
0x0093
0x0001
0x0001
0x0019
0x0271
0x0031
0x007D
0x0001
0x0659
0x0019
0x0031
0x007D
0x0001
0x0659
1.See Table 4-108 and Table 4-109 for the coding of the FLLn_REFCLK_DIV and FLLn_FB_DIV fields.
2.N.K values are represented in the FLLn_N, FLLn_THETA, and FLLn_LAMBDA fields.
4.17 Control Interface
The CS42L92 is controlled by read/write access to its control registers. The control interface supports 2-wire (I2C) and
4-wire (SPI) modes. Note that the SLIMbus interface also supports read/write access to the CS42L92 control registers;
see Section 4.10.
The CS42L92 executes a boot sequence following power-on reset, hardware reset, software reset, or wake-up from Sleep
Mode. Note that control register writes should not be attempted until the boot sequence has completed. See Section 4.22
for further details.
The control interface function can be supported with or without system clocking—there is no requirement for SYSCLK, or
any other system clock, to be enabled when accessing the register map.
Timing specifications for each of the control interfaces are provided in Table 3-19–Table 3-21. In some applications,
additional system-wide constraints must be observed to ensure control interface limits are not exceeded. Full details of
these requirements are provided in Section 4.16.7. These constraints need to be considered if any of the following
conditions is true.
•
SYSCLK is enabled and is < 22.5792 MHz
•
Control-register access is scheduled at register address 0x80000 or above
•
Control-register access is scheduled on more than one of the control interfaces simultaneously
The control interface can be configured as a 2-wire (I2C) or 4-wire (SPI) interface. The mode is determined by the logic
level on the CIFMODE pin, as described in Table 4-111.
244
DS1162F1
CS42L92
4.17 Control Interface
Table 4-111. CS42L92 Control Interface Summary
CIFMODE
Logic 1
Interface Mode
Four-wire (SPI) interface
Pin Functions
CIFMISO—Data output
CIFMOSI—Data input
CIFSCLK—Interface clock input
CIFSS—Slave select input
Logic 0
Two-wire (I2C) interface
CIFSCLK—Interface clock input
CIFSDA—Data input/output
Note: The CIFMOSI and CIFSDA functions are multiplexed on a dual-function pin.
An integrated pull-down resistor is provided on the CIF1MISO pin. This provides a flexible capability for interfacing with
other devices. The pull-down is configured using the CIF1MISO_PD bit, as described in Table 4-112.
Table 4-112. Control Interface Pull-Down
Register Address
R8 (0x0008)
Ctrl_IF_CFG_1
Bit
7
Label
CIF1MISO_PD
Default
0
Description
CIFMISO Pull-Down Control
0 = Disabled
1 = Enabled
A detailed description of the I2C and SPI interface modes is provided in the following sections.
4.17.1 Four-Wire (SPI) Control Mode
The SPI control interface mode is supported using the CIFSS, CIFSCLK, CIFMOSI, and CIFMISO pins.
In write operations (R/W = 0), the MOSI pin input is driven by the controlling device.
In read operations (R/W = 1), the MOSI pin is ignored following receipt of the valid register address.
If SS is asserted (Logic 0), the MISO output is actively driven when outputting data and is high impedance at other times.
If SS is not asserted, the MISO output is high impedance.
The high-impedance state of the MISO output allows the pin to be shared with other slaves. An internal pull-down resistor
can be enabled on the MISO pin, as described in Table 4-112.
Data transfers on the SPI interface must use the applicable message format, according to the register address space that
is being accessed:
•
When accessing register addresses below R12288 (0x3000), the applicable SPI protocol comprises a 31-bit register
address and 16-bit data words.
•
When accessing register addresses from R12888 (0x3000) upwards, the applicable SPI protocol comprises a 31-bit
register address and 32-bit data words.
•
Note that, in all cases, the complete SPI message protocol also includes a read/write bit and a 16-bit padding phase
(see Fig. 4-67 and Fig. 4-68 below).
Continuous read and write modes enable multiple register operations to be scheduled faster than is possible with single
register operations. In these modes, the CS42L92 automatically increments the register address at the end of each data
word, for as long as SS is held low and SCLK is toggled. Successive data words can be input/output every 16 (or 32) clock
cycles (depending on the applicable register address space).
The SPI protocol is shown in Fig. 4-67 and Fig. 4-68. Note that 16-bit data words are shown, but the equivalent protocol
also applies to 32-bit data words.
DS1162F1
245
CS42L92
4.17 Control Interface
Fig. 4-67 shows a single register write to a specified address.
SS
SCLK
MOSI
R/W A30 A29
A1
A0
X
X
31-bit register address
X
X
B15 B14
16-bit padding
B1
B0
16-bit data word
Figure 4-67. Control Interface SPI Register Write (16-Bit Data Words)
Fig. 4-68 shows a single register read from a specified address.
SS
SCLK
MOSI
R/W A30 A29
A1
A0
X
X
X
MISO
X
X
X
B15 B14
31-bit register address
16-bit padding
X
X
B1
B0
16-bit data word
Figure 4-68. Control Interface SPI Register Read (16-Bit Data Words)
4.17.2 Two-Wire (I2C) Control Mode
The I2C control interface mode is supported using the CIFSCLK and CIFSDA pins.
In I2C Mode, the CS42L92 is a slave device on the control interface; SCLK is a clock input, while SDA is a bidirectional
data pin. To allow arbitration of multiple slaves (and/or multiple masters) on the same interface, the CS42L92 transmits
Logic 1 by tristating the SDA pin, rather than pulling it high. An external pull-up resistor is required to pull the SDA line high
so that the Logic 1 can be recognized by the master.
In order to allow many devices to share a single two-wire control bus, every device on the bus has a unique 8-bit device
ID (this is not the same as the address of each register in the CS42L92).
The CS42L92 device ID is 0011_0100 (0x34). Note that the LSB of the device ID is the read/write bit; this bit is set to Logic
1 for read and Logic 0 for write.
The CS42L92 operates as a slave device only. The controller indicates the start of data transfer with a high-to-low
transition on SDA while SCLK remains high. This indicates that a device ID and subsequent address/data bytes follow.
The CS42L92 responds to the start condition and shifts in the next 8 bits on SDA (8-bit device ID, including read/write bit,
MSB first). If the device ID received matches the device ID of the CS42L92, the CS42L92 responds by pulling SDA low
on the next clock pulse (ACK). If the device ID is not recognized or the R/W bit is set incorrectly, the CS42L92 returns to
the idle condition and waits for a new start condition.
If the device ID matches the device ID of the CS42L92, the data transfer continues. The controller indicates the end of
data transfer with a low-to-high transition on SDA while SCLK remains high. After receiving a complete address and data
sequence the CS42L92 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., SDA changes while SCLK is high), the device returns to the idle
condition.
246
DS1162F1
CS42L92
4.17 Control Interface
Data transfers on the I2C interface must use the applicable message format, according to the register address space that
is being accessed:
•
When accessing register addresses below R12288 (0x3000), the applicable I2C protocol comprises a 32-bit register
address and 16-bit data words.
•
When accessing register addresses from R12888 (0x3000) upwards, the applicable I2C protocol comprises a 32-bit
register address and 32-bit data words.
•
Note that, in all cases, the complete I2C message protocol also includes a device ID, a read/write bit, and other
signaling bits (see Fig. 4-69 and Fig. 4-70).
The CS42L92 supports the following read and write operations:
•
Single write
•
Single read
•
Multiple write
•
Multiple read
Continuous (multiple) read and write modes allow register operations to be scheduled faster than is possible with single
register operations. In these modes, the CS42L92 automatically increments the register address after each data word.
Successive data words can be input/output every 2 (or 4) data bytes, depending on the applicable register address space.
The I2C protocol for a single, 16-bit register write operation is shown in Fig. 4-69.
SCLK
D7
SDA
D1
R/W
A31
A25
A24
A 23
A 17
A16
A15
device ID (Write) ACK register address A31 –A24 ACK register address A23–A 16 ACK
START
A1
A8
A7
register address A15–A8 ACK
A0
register address A7 –A0
A9
B15
ACK
B9
B8
B7
ACK
data bits B15–B 8
B1
B0
data bits B7– B0
ACK
STOP
Note: The SDA pin is used as input for the control register address and data; SDA
is pulled low by the receiving device to provide the acknowledge(ACK ) response
Figure 4-69. Control Interface I2C Register Write (16-Bit Data Words)
The I2C protocol for a single, 16-bit register read operation is shown in Fig. 4-70.
SCLK
D7
SDA
START
D1
R/W
A31
A25
A24
device ID (Write) ACK register address A31 –A24
A1
A0
register address A7–A0
A 23
Rpt
START
A15
A16
register address A23–A 16 ACK
D7
ACK
A 17
D1
R/W
device ID (Read) ACK
A9
A8
A7
register address A15–A8 ACK
B15
B9
data bits B 15–B8
B8
B7
ACK
B1
data bits B7 –B0
B0
ACK
STOP
Note: The SDA pin is driven by both the master and slave devices in turn
to transfer device address, register address, data and ACK responses
Figure 4-70. Control Interface I2C Register Read (16-Bit Data Words)
The control interface also supports other register operations; the interface protocol for these operations is shown in
Fig. 4-71 through Fig. 4-74. The terminology used in the following figures is detailed in Table 4-113.
DS1162F1
247
CS42L92
4.17 Control Interface
Note that 16-bit data words are shown in these illustrations. The equivalent protocol is also applicable to 32-bit words, with
4 data bytes transmitted (or received) instead of 2.
Table 4-113. Control Interface (I2C) Terminology
Terminology
S
Sr
A
Description
Start condition
Repeated start
Acknowledge (SDA low)
Not acknowledge (SDA high)
A
P
Stop condition
Read/not write
0 = Write; 1 = Read
Data flow from bus master to CS42L92
Data flow from CS42L92 to bus master
R/W
[White field]
[Gray field]
Fig. 4-71 shows a single register write to a specified address.
8-Bit Device ID
S
Device ID
8 bits
R/W A
(0)
8 bits
Address Byte [3]
A
8 bits
Address Byte [2]
A
8 bits
Address Byte [1]
A
(Most Significant Byte)
Address Byte [0]
(Least Significant Byte )
8 bits
A
8 bits
MSByte Data
A
LSByte Data
A
P
A
P
A
P
Figure 4-71. Single-Register Write to Specified Address
Fig. 4-72 shows a single register read from a specified address.
S
Device ID
R/W A
(0)
Address Byte [3]
A
Address Byte [2]
A
Address Byte [1]
A
(Most Significant Byte)
Address Byte [0]
(Least Significant Byte )
A
Sr
Device ID
R/W A
MSByte Data
A
LSByte Data
(1)
Figure 4-72. Single-Register Read from Specified Address
Fig. 4-73 shows a multiple register write to a specified address.
S
Device ID
R/W A
Address Byte [3]
A
Address Byte [2]
A
Address Byte [1]
A
Address Byte [0]
(0)
Written to Register Address
A
MSByte Data 0
A
Written to Register Address + 1
LSByte Data 0
A
MSByte Data 1
Written to Register Address + N - 1
A
MSByte Data N-1
A
LSByte Data N-1
A
LSByte Data 1
A
Written to Register Address + N
A
MSByte Data N
A
LSByte Data N
Figure 4-73. Multiple-Register Write to Specified Address
248
DS1162F1
CS42L92
4.18 Control-Write Sequencer
Fig. 4-74 shows a multiple register read from a specified address.
S
Device ID
R/W A
Address Byte [3]
A
Address Byte [2]
A
Address Byte [1]
A
Address Byte [0]
(0)
Read from Register Address
A
Sr
Device ID
R/W A
MSByte Data 0
A
LSByte Data 0
A
(1)
Read from Register Address + N - 1
A
MSByte Data N-1
A
LSByte Data N-1
Read from Register Address + N
A
MSByte Data N
A
LSByte Data N
A
P
Figure 4-74. Multiple-Register Read from Specified Address
4.18 Control-Write Sequencer
The control-write sequencer is a programmable unit that forms part of the CS42L92 control interface logic. It provides the
ability to perform a sequence of register-write operations with the minimum of demands on the host processor—the
sequence may be initiated by a single operation from the host processor and then left to execute independently.
Default sequences for pop-suppressed start-up and shutdown of each headphone/earpiece output driver are provided
(these are scheduled automatically when the respective output paths are enabled or disabled). Other control sequences
can be programmed, and may be associated with sample-rate detection, DRC, MICDET clamp, or event logger status;
these sequences are automatically scheduled whenever a corresponding event is detected.
When a sequence is initiated, the sequencer performs a series of predefined register writes. The start index of a control
sequence within the sequencer’s memory may be commanded directly by the host processor. The applicable start index
for each of the sequences associated with sample-rate detection, DRC, MICDET clamp, or event logger status is held in
a user-programmed control register.
The control-write sequencer may be triggered by a number of different events. Multiple sequences are queued if
necessary, and each is scheduled in turn.
The control-write sequencer can be supported with or without system clocking—there is no requirement for SYSCLK or for
any other system clock to be enabled when using the control-write sequencer. The timing accuracy of the sequencer
operation is improved when SYSCLK is present, but the general functionality is supported with or without SYSCLK.
4.18.1 Initiating a Sequence
The fields associated with running the control-write sequencer are described in Table 4-114.
The CS42L92 provides 16 general-purpose trigger bits for the write sequencer to allow easy triggering of the associated
control sequences. Writing 1 to the trigger bit initiates a control sequence, starting at the respective index position within
the control-write sequencer memory.
The WSEQ_TRG1_INDEX field defines the sequencer start index corresponding to the WSEQ_TRG1 trigger control bit.
Equivalent start index fields are provided for each trigger control bit, as described in Table 4-114. Note that a sequencer
start index of 0x1FF causes the respective sequence to be aborted.
The general-purpose control sequences are undefined following power-on reset, a hardware reset, or a Sleep Mode
transition. The general-purpose control sequences must be reconfigured by the host processor following any of these
events. Note that all control sequences are maintained in the sequencer memory through software reset.
The write sequencer can also be commanded using control bits in register R22 (0x16). In this case, the write sequencer
is enabled using the WSEQ_ENA bit and the index location of the first command in the sequence is held in the WSEQ_
START_INDEX field. Writing 1 to the WSEQ_START bit commands the sequencer to execute a control sequence, starting
at the specified index position. Note that, if the sequencer is already running, the WSEQ_START command is queued and
executed when the sequencer becomes available.
DS1162F1
249
CS42L92
4.18 Control-Write Sequencer
Note:
The mechanism for queuing multiple sequence requests has limitations when the WSEQ_START bit is used to
trigger the write sequencer. If a sequence is initiated using the WSEQ_START bit, no other control sequences
should be triggered until the sequence completes. The WSEQ_BUSY bit (described in Table 4-120) provides an
indication of the sequencer status and can be used to confirm the sequence has completed.
Multiple control sequences triggered by any other method are queued if necessary, and scheduled in turn.
The write sequencer can be interrupted by writing 1 to the WSEQ_ABORT bit. Note that this command only aborts a
sequence that is currently running; if other sequence commands are pending and not yet started, these sequences are
not aborted by writing to the WSEQ_ABORT bit.
The write sequencer stores up to 508 register-write commands. These are defined in registers R12288 (0x3000) through
R13302 (0x33F6). See Table 4-121 for a description of these registers.
Table 4-114. Write Sequencer Control—Initiating a Sequence
Register Address
R22 (0x0016)
Write_Sequencer_
Ctrl_0
Bit
11
10
9
8:0
R66 (0x0042)
Spare_Triggers
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
250
Label
Default
Description
WSEQ_ABORT
0
Writing 1 to this bit aborts the current sequence.
WSEQ_START
0
Writing 1 to this bit starts the write sequencer at the index location selected by WSEQ_
START_INDEX. At the end of the sequence, this bit is reset by the write sequencer.
WSEQ_ENA
0
Write Sequencer Enable
0 = Disabled
1 = Enabled
Only applies to sequences triggered using the WSEQ_START bit.
WSEQ_
0x000 Sequence Start Index. Contains the index location in the sequencer memory of the first
START_
command in the selected sequence.
INDEX[8:0]
Only applies to sequences triggered using the WSEQ_START bit.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG16
0
Write Sequence Trigger 16
Write 1 to trigger
WSEQ_TRG15
0
Write Sequence Trigger 15
Write 1 to trigger
WSEQ_TRG14
0
Write Sequence Trigger 14
Write 1 to trigger
WSEQ_TRG13
0
Write Sequence Trigger 13
Write 1 to trigger
WSEQ_TRG12
0
Write Sequence Trigger 12
Write 1 to trigger
WSEQ_TRG11
0
Write Sequence Trigger 11
Write 1 to trigger
WSEQ_TRG10
0
Write Sequence Trigger 10
Write 1 to trigger
WSEQ_TRG9
0
Write Sequence Trigger 9
Write 1 to trigger
WSEQ_TRG8
0
Write Sequence Trigger 8
Write 1 to trigger
WSEQ_TRG7
0
Write Sequence Trigger 7
Write 1 to trigger
WSEQ_TRG6
0
Write Sequence Trigger 6
Write 1 to trigger
WSEQ_TRG5
0
Write Sequence Trigger 5
Write 1 to trigger
WSEQ_TRG4
0
Write Sequence Trigger 4
Write 1 to trigger
WSEQ_TRG3
0
Write Sequence Trigger 3
Write 1 to trigger
WSEQ_TRG2
0
Write Sequence Trigger 2
Write 1 to trigger
WSEQ_TRG1
0
Write Sequence Trigger 1
Write 1 to trigger
DS1162F1
CS42L92
4.18 Control-Write Sequencer
Table 4-114. Write Sequencer Control—Initiating a Sequence (Cont.)
Register Address
R75 (0x004B)
Spare_Sequence_
Select_1
R76 (0x004C)
Spare_Sequence_
Select_2
R77 (0x004D)
Spare_Sequence_
Select_3
R78 (0x004E)
Spare_Sequence_
Select_4
R79 (0x004F)
Spare_Sequence_
Select_5
R80 (0x0050)
Spare_Sequence_
Select_6
R89 (0x0059)
Spare_Sequence_
Select_7
R90 (0x005A)
Spare_Sequence_
Select_8
R91 (0x005B)
Spare_Sequence_
Select_9
R92 (0x005C)
Spare_Sequence_
Select_10
Bit
8:0
R93 (0x005D)
Spare_Sequence_
Select_11
8:0
R94 (0x005E)
Spare_Sequence_
Select_12
8:0
R104 (0x0068)
Spare_Sequence_
Select_13
8:0
R105 (0x0069)
Spare_Sequence_
Select_14
8:0
R106 (0x006A)
Spare_Sequence_
Select_15
8:0
R107 (0x006B)
Spare_Sequence_
Select_16
8:0
8:0
8:0
8:0
8:0
8:0
8:0
8:0
8:0
8:0
Label
Default
Description
WSEQ_TRG1_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG1 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG2_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG2 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG3_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG3 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG4_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG4 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG5_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG5 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG6_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG6 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG7_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG7 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG8_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG8 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_TRG9_ 0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
INDEX[8:0]
memory of the first command in the sequence associated with the WSEQ_TRG9 trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_
0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
TRG10_
memory of the first command in the sequence associated with the WSEQ_TRG10
INDEX[8:0]
trigger.
Valid from 0 to 507 (0x1FB).
0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
WSEQ_
TRG11_
memory of the first command in the sequence associated with the WSEQ_TRG11
INDEX[8:0]
trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_
0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
TRG12_
memory of the first command in the sequence associated with the WSEQ_TRG12
INDEX[8:0]
trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_
0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
TRG13_
memory of the first command in the sequence associated with the WSEQ_TRG13
INDEX[8:0]
trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_
0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
TRG14_
memory of the first command in the sequence associated with the WSEQ_TRG14
INDEX[8:0]
trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_
0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
TRG15_
memory of the first command in the sequence associated with the WSEQ_TRG15
INDEX[8:0]
trigger.
Valid from 0 to 507 (0x1FB).
WSEQ_
0x1FF Write Sequence trigger 1 start index. Contains the index location in the sequencer
TRG16_
memory of the first command in the sequence associated with the WSEQ_TRG16
INDEX[8:0]
trigger.
Valid from 0 to 507 (0x1FB).
4.18.2 Automatic Sample-Rate Detection Sequences
The CS42L92 supports automatic sample-rate detection on the digital audio interfaces (AIF1–AIF3) when operating in AIF
Slave Mode. Automatic sample-rate detection is enabled by setting RATE_EST_ENA—see Table 4-104.
DS1162F1
251
CS42L92
4.18 Control-Write Sequencer
As many as four audio sample rates can be configured for automatic detection; these sample rates are selected using the
SAMPLE_RATE_DETECT_n fields. If a selected audio sample rate is detected, the control-write sequencer is triggered.
The applicable start index location within the sequencer memory is separately configurable for each detected sample rate.
The WSEQ_SAMPLE_RATE_DETECT_A_INDEX field defines the sequencer start index corresponding to the SAMPLE_
RATE_DETECT_A sample rate. Equivalent start index fields are defined for the other sample rates, as described in
Table 4-115.
Note that a sequencer start index of 0x1FF causes the respective sequence to be aborted.
The automatic sample-rate detection control sequences are undefined following power-on reset, a hardware reset, or a
Sleep Mode transition. The automatic sample-rate detection control sequences must be reconfigured by the host
processor following any of these events. Note that all control sequences are maintained in the sequencer memory through
software reset.
See Section 4.16 for further details of the automatic sample-rate detection function.
Table 4-115. Write Sequence Control—Automatic Sample-Rate Detection
Register Address
R97 (0x0061)
Sample_Rate_
Sequence_Select_1
Bit
8:0
R98 (0x0062)
Sample_Rate_
Sequence_Select_2
8:0
R99 (0x0063)
Sample_Rate_
Sequence_Select_3
8:0
R100 (0x0064)
Sample_Rate_
Sequence_Select_4
8:0
Label
Default
Description
WSEQ_SAMPLE_ 0x1FF Sample Rate A Write Sequence start index. Contains the index location in the
RATE_DETECT_
sequencer memory of the first command in the sequence associated with Sample
A_INDEX[8:0]
Rate A detection.
Valid from 0 to 507 (0x1FB).
WSEQ_SAMPLE_ 0x1FF Sample Rate B Write Sequence start index. Contains the index location in the
RATE_DETECT_
sequencer memory of the first command in the sequence associated with Sample
B_INDEX[8:0]
Rate B detection.
Valid from 0 to 507 (0x1FB).
WSEQ_SAMPLE_ 0x1FF Sample Rate C Write Sequence start index. Contains the index location in the
RATE_DETECT_
sequencer memory of the first command in the sequence associated with Sample
C_INDEX[8:0]
Rate C detection.
Valid from 0 to 507 (0x1FB).
WSEQ_SAMPLE_ 0x1FF Sample Rate D Write Sequence start index. Contains the index location in the
RATE_DETECT_
sequencer memory of the first command in the sequence associated with Sample
D_INDEX[8:0]
Rate D detection.
Valid from 0 to 507 (0x1FB).
4.18.3 DRC Signal-Detect Sequences
The DRC function within the CS42L92 digital core provides a configurable signal-detect function. This allows the signal
level at the DRC input to be monitored and used to trigger other events.
The DRC signal-detect functions are enabled and configured using the fields described in Table 4-17 and Table 4-18 for
DRC1 and DRC2 respectively.
A control-write sequence can be associated with a rising edge and/or a falling edge of the DRC1 signal-detect output. This
is enabled by setting DRC1_WSEQ_SIG_DET_ENA, as described in Table 4-17.
Note that signal detection is supported on DRC1 and DRC2, but the triggering of the control-write sequencer is available
on DRC1 only.
When the DRC signal-detect sequence is enabled, the control-write sequencer is triggered whenever the DRC1
signal-detect output transitions (high or low). The applicable start index location within the sequencer memory is separately
configurable for each logic condition.
The WSEQ_DRC1_SIG_DET_RISE_SEQ_INDEX field defines the sequencer start index corresponding to a DRC1
signal-detect rising edge event, as described in Table 4-116. The WSEQ_DRC1_SIG_DET_FALL_SEQ_INDEX field
defines the sequencer start index corresponding to a DRC1 signal-detect falling edge event.
Note that a sequencer start index of 0x1FF causes the respective sequence to be aborted.
The DRC signal-detect sequences cannot be independently enabled for rising and falling edges. Instead, a start index of
0x1FF can be used to disable the sequence for either edge, if required.
252
DS1162F1
CS42L92
4.18 Control-Write Sequencer
The DRC signal-detect control sequences are undefined following power-on reset, a hardware reset, or a Sleep Mode
transition. The DRC signal-detect control sequences must be reconfigured by the host processor following any of these
events. Note that all control sequences are maintained in the sequencer memory through software reset.
See Section 4.3.5 for further details of the DRC function.
Table 4-116. Write Sequencer Control—DRC Signal-Detect
Register Address Bit
Label
R110 (0x006E)
8:0 WSEQ_DRC1_
SIG_DET_RISE_
Trigger_
INDEX[8:0]
Sequence_
Select_32
R111 (0x006F)
8:0 WSEQ_DRC1_
SIG_DET_FALL_
Trigger_
INDEX[8:0]
Sequence_
Select_33
Default
Description
0x1FF DRC1 Signal-Detect (Rising) Write Sequence start index. Contains the index location in
the sequencer memory of the first command in the sequence associated with DRC1
Signal-Detect (Rising) detection.
Valid from 0 to 507 (0x1FB).
0x1FF DRC1 Signal-Detect (Falling) Write Sequence start index. Contains the index location in
the sequencer memory of the first command in the sequence associated with DRC1
Signal-Detect (Falling) detection.
Valid from 0 to 507 (0x1FB).
4.18.4 MICDET Clamp Sequences
The CS42L92 supports external accessory detection functions, including the MICDET clamp circuits. The MICDET clamp
status can be used to trigger the control-write sequencer. The MICDET clamps can be controlled using selectable logic
conditions in respect of the JDn signals, as described in Table 4-85.
A control-write sequence can be associated with a rising edge and/or a falling edge of the MICDET clamp status. This is
configured using the WSEQ_ENA_MICD_CLAMP_RISE and WSEQ_ENA_MICD_CLAMP_FALL bits, as described in
Table 4-85.
If one of the selected JDn logic conditions is detected, the control-write sequencer is triggered. Note that these
control-sequencer events are only valid if the clamp status changed in response to the JDn signals. The applicable start
index location within the sequencer memory is separately configurable for the rising and falling edge conditions.
Note that, due to control logic that is shared between the two MICDET clamps, the option to control both clamps in
response to the JDn signals cannot be supported at the same time. It is assumed that a maximum of one clamp is active
at any time. Accordingly, only the active clamp is capable of triggering the control-write sequencer.
The WSEQ_MICD_CLAMP_RISE_INDEX field defines the sequencer start index corresponding to a MICDET clamp
rising edge (clamp active) event, as described in Table 4-117. The WSEQ_MICD_CLAMP_FALL_INDEX field defines the
sequencer start index corresponding to a MICDET clamp falling edge event.
Note that a sequencer start index of 0x1FF causes the respective sequence to be aborted.
The MICDET clamp control sequences are undefined following power-on reset, a hardware reset, or a Sleep Mode
transition. The MICDET clamp control sequences must be reconfigured by the host processor following any of these
events. Note that all control sequences are maintained in the sequencer memory through software reset.
See Section 4.12 for further details of the MICDET clamp status signals.
Table 4-117. Write Sequencer Control—MICDET Clamp
Register Address
R102 (0x0066)
Always_On_Triggers_
Sequence_Select_1
Bit
Label
8:0 WSEQ_MICD_
CLAMP_RISE_
INDEX[8:0]
R103 (0x0067)
Always_On_Triggers_
Sequence_Select_2
8:0 WSEQ_MICD_
CLAMP_FALL_
INDEX[8:0]
Default
Description
0x1FF MICDET Clamp (Rising) Write Sequence start index. Contains the index location in
the sequencer memory of the first command in the sequence associated with
MICDET clamp (Rising) detection.
Valid from 0 to 507 (0x1FB).
0x1FF MICDET Clamp (Falling) Write Sequence start index. Contains the index location in
the sequencer memory of the first command in the sequence associated with
MICDET clamp (Falling) detection.
Valid from 0 to 507 (0x1FB).
4.18.5 Event Logger Sequences
The CS42L92 provides an event log function, for monitoring and recording internal or external signals. The logged events
are held in a FIFO buffer, from which the application software can read details of the detected logic transitions.
DS1162F1
253
CS42L92
4.18 Control-Write Sequencer
The control-write sequencer is automatically triggered whenever the NOT_EMPTY status of the event log buffer is
asserted.
The WSEQ_EVENTLOG1_INDEX field defines the sequencer start index corresponding to the event logger, as described
in Table 4-118.
Note that a sequencer start index of 0x1FF causes the respective sequence to be aborted.
The event logger control sequence is undefined following power-on reset, a hardware reset, or a Sleep Mode transition.
The event logger control sequence must be reconfigured by the host processor following any of these events. Note that
all control sequences are maintained in the sequencer memory through software reset.
See Section 4.5.1 for further details of the event logger.
Table 4-118. Write Sequencer Control—Event Logger
Register Address Bit
Label
R120 (0x0078)
8:0 WSEQ_
EVENTLOG1_
Eventlog_
INDEX[8:0]
Sequence_
Select_1
Default
Description
0x1FF Event Log 1 Write Sequence start index. Contains the index location in the sequencer
memory of the first command in the sequence associated with Event Log 1 FIFO
Not-Empty detection.
Valid from 0 to 507 (0x1FB).
4.18.6 Boot Sequence
The CS42L92 executes a boot sequence following power-on reset, hardware reset, software reset, or wake-up from Sleep
Mode. The boot sequence configures the CS42L92 with factory-set trim (calibration) data. See Section 4.22 and
Section 4.23 for further details.
The start index location of the boot sequence is 384 (0x180). See Table 4-123 for details of the write sequencer memory
allocation.
The boot sequence can be commanded at any time by writing 1 to the WSEQ_BOOT_START bit.
Table 4-119. Write Sequencer Control—Boot Sequence
Register Address
R24 (0x0018)
Write_Sequencer_
Ctrl_2
Bit
1
Label
WSEQ_BOOT_
START
Default
0
Description
Writing 1 to this bit starts the write sequencer at the index location configured for
the Boot Sequence.
The Boot Sequence start index is 384 (0x180).
4.18.7 Sequencer Status Indication
The status of the write sequencer can be read using WSEQ_BUSY and WSEQ_CURRENT_INDEX, as described in
Table 4-120. When the WSEQ_BUSY bit is asserted, this indicates that the write sequencer is busy.
The index address of the most recent write sequencer command can be read from the WSEQ_CURRENT_INDEX field.
This can be used to provide a precise indication of the write sequencer progress.
Table 4-120. Write Sequencer Control—Status Indication
Register Address Bit
Label
R23 (0x0017)
9 WSEQ_BUSY
Write_Sequencer_
(read only)
Ctrl_1
8:0 WSEQ_CURRENT_
INDEX[8:0]
(read only)
Default
Description
0
Sequencer Busy flag (Read Only).
0 = Sequencer idle
1 = Sequencer busy
0x000 Sequence Current Index. This indicates the memory location of the most recently
accessed command in the write sequencer memory.
Coding is the same as WSEQ_START_INDEX.
4.18.8 Programming a Sequence
A control-write sequence comprises a series of write operations to data bits within the control register map. Standard write
operations are defined by five fields, contained within a single 32-bit register. An extended instruction set is also defined;
the associated actions make use of alternate definitions of the 32-bit registers.
254
DS1162F1
CS42L92
4.18 Control-Write Sequencer
The sequencer instruction fields are replicated 508 times, defining each of the sequencer’s 508 possible index addresses.
Many sequences can be stored in the sequencer memory at the same time, with each assigned a unique range of index
addresses. The WSEQ_DELAYn field is used to identify the end-of-sequence position, as described below.
The general definition of the sequencer instruction fields is described as follows, where n denotes the sequencer index
address (valid from 0 to 507):
•
WSEQ_DATA_WIDTHn is a 3-bit field that identifies the width of the data block to be written. Note that the maximum
value of this field selects a width of 8 bits; writes to fields that are larger than 8 bits wide must be performed using
two separate operations of the write sequencer.
•
WSEQ_ADDRn is a 12-bit field containing the register address in which the data should be written. The applicable
register address is referenced to the base address currently configured for the sequencer—it is calculated as: (base
address * 512) + WSEQ_ADDRn. Note that the base address is configured using the sequencer’s extended
instruction set.
•
WSEQ_DELAYn is a 4-bit field that controls the waiting time between the current step and the next step in the
sequence (i.e., the delay occurs after the write in which it was called). The total delay time per step (including
execution) is defined below, giving a useful range of execution/delay times from 3.3 s up to 1 s per step.
If WSEQ_DELAYn = 0x0 or 0xF, the step execution time is 3.3 s
For all other values, the step execution time is 61.44 s x ((2 WSEQ_DELAY) – 1)
Setting this field to 0xF identifies the step as the last in the sequence
•
WSEQ_DATA_STARTn is a 4-bit field that identifies the LSB position within the selected control register to which
the data should be written. For example, setting WSEQ_DATA_STARTn = 0100 selects bit [4] as the LSB position
of the data to be written.
•
WSEQ_DATAn is an 8-bit field that contains the data to be written to the selected control register. The WSEQ_
DATA_WIDTHn field determines how many of these bits are written to the selected control register; the most
significant bits (above the number indicated by WSEQ_DATA_WIDTHn) are ignored.
The extended instruction set for the write sequencer is accessed by setting WSEQ_MODEn (bit [28]) in the respective
sequencer definition register. The extended instruction set comprises the following functions:
•
If bits [31:24] = 0x11, the register base address is set equal to the value contained in bits [23:0].
•
If bits [31:16] = 0x12FF, the sequencer performs an unconditional jump to the index location defined in bits [15:0].
The index location is valid in the range 0 to 507 (0x1FB).
•
All other settings within the extended instruction set are reserved.
The control field definitions for Step 0 are described in Table 4-121. The equivalent definitions also apply to Step 1 through
Step 507, in the subsequent register address locations.
DS1162F1
255
CS42L92
4.18 Control-Write Sequencer
Table 4-121. Write Sequencer Control—Programming a Sequence
Register Address Bit
Label
R12288 (0x3000) 31:29 WSEQ_DATA_
WIDTH0[2:0]
WSEQ_
Sequence_1
Default
Description
000 Width of the data block written in this sequence step.
000 = 1 bit
011 = 4 bits
110 = 7 bits
001 = 2 bits
100 = 5 bits
111 = 8 bits
010 = 3 bits
101 = 6 bits
28 WSEQ_MODE0
0
Extended Sequencer Instruction select
0 = Basic instruction set
1 = Extended instruction set
27:16 WSEQ_ADDR0[11:0] 0x000 Control Register Address to be written to in this sequence step.
The register address is calculated as: (Base Address * 512) + WSEQ_ADDRn.
Base Address is 0x00_0000 by default, and is configured using the sequencer’s
extended instruction set.
15:12 WSEQ_DELAY0[3:0] 0000 Time delay after executing this step.
0x0 = 3.3 s
0x1 to 0xE = 61.44 s x ((2WSEQ_DELAY)–1)
0xF = End of sequence marker
11:8 WSEQ_DATA_
0000 Bit position of the LSB of the data block written in this sequence step.
START0[3:0]
0000 = Bit 0
…
1111 = Bit 15
7:0 WSEQ_DATA0[7:0]
0x00 Data to be written in this sequence step. When the data width is less than 8 bits,
one or more of the MSBs of WSEQ_DATAn are ignored. It is recommended that
unused bits be cleared.
4.18.9 Sequencer Memory Definition
The write sequencer memory defines up to 508 write operations; these are indexed as 0 to 507 in the sequencer memory
map.
The write sequencer memory reverts to its default contents following power-on reset, a hardware reset, or a Sleep Mode
transition. In these cases, the sequence memory contains the boot sequence and the OUT1–OUT3 signal path enable/
disable sequences; the remainder of the sequence memory is undefined.
User-defined sequences can be programmed after power-up. The user-defined control sequences must be reconfigured
by the host processor following power-on reset, a hardware reset, or a Sleep Mode transition. Note that all control
sequences are maintained in the sequencer memory through software reset. See Section 5.2 for a summary of the
CS42L92 memory reset conditions.
The default control sequences can be overwritten in the sequencer memory, if required. Note that the headphone/earpiece
output path enable bits (HPnx_ENA) always trigger the write sequencer (at the predetermined start index addresses).
Writing 1 to the WSEQ_LOAD_MEM bit clears the sequencer memory to the power-on reset state.
Table 4-122. Write Sequencer Control—Load Memory Control
Register Address
R24 (0x0018)
Write_Sequencer_Ctrl_2
Bit
0
Label
WSEQ_LOAD_
MEM
Default
0
Description
Writing 1 to this bit resets the sequencer memory to the power-on reset
state.
The sequencer memory is summarized in Table 4-123. User-defined sequences should be assigned space within the
allocated portion (user space) of the write sequencer memory.
The start index for the user-defined sequences is configured using the fields described in Table 4-114 through
Table 4-118.
256
DS1162F1
CS42L92
4.19 Charge Pumps, Regulators, and Voltage Reference
Table 4-123. Write Sequencer Memory Allocation
Description
Default Sequences
User Space
Boot Sequence
Sequence Index Range
0 to 302
303 to 383
384 to 507
4.19 Charge Pumps, Regulators, and Voltage Reference
The CS42L92 incorporates two charge-pump circuits and an LDO-regulator circuit to generate supply rails for internal
functions and to support external microphone requirements. The CS42L92 also provides two MICBIAS generators (with
six switchable outputs), which provide low noise reference voltages suitable for biasing ECM-type microphones or
powering digital microphones.
In Sleep Mode, the CS42L92 can provide an unregulated voltage output that can be used to power an external
microphone. See Section 4.13 for details of Sleep Mode.
The CPVDD domain (1.8 V) powers the Charge Pump 1 and Charge Pump 2 circuits. The CPVDD2 power domain (1.2 V)
is an additional supply used by Charge Pump 1 only. Refer to Section 5.1 for recommended external components.
4.19.1 Charge Pump 1
Charge Pump 1 (CP1) is used to generate the positive and negative supply rails for the analog output drivers. CP1 is
enabled automatically by the CS42L92 when required by the output drivers.
The Charge Pump 1 circuit is shown in Fig. 4-75.
4.19.2 Charge Pump 2 and LDO2 Regulator
Charge Pump 2 (CP2) powers LDO2, which provides the supply rail for analog input circuits and for the MICBIAS
generators. CP2 and LDO2 are enabled by setting CP2_ENA.
If CP2 and LDO2 are enabled, the MICVDD voltage is selected using the LDO2_VSEL field. Note that, when one or more
of the MICBIAS generators is operating in normal (regulator) mode, the MICVDD voltage must be at least 200 mV greater
than the highest selected MICBIASn output voltages.
If CP2 and LDO2 are enabled, an internal bypass path may be selected, connecting the MICVDD pin directly to the CPVDD
supply. This path is controlled using the CP2_BYPASS bit. Note that the bypass path is only supported when CP2 is
enabled.
Note:
The 32-kHz clock must be configured and enabled if CP2 is enabled in its normal operating mode. The 32-kHz
clock is not required in bypass mode (CP2_BYPASS = 1). See Section 4.16 for details of the system clocks.
If CP2 is disabled, the CP2VOUT pin can be either floating or actively discharged. The behavior is configured using the
CP2_DISCH bit.
If LDO2 is disabled, the MICVDD pin can be either floating or actively discharged. The behavior is configured using the
LDO2_DISCH bit.
The MICVDD pin is connected to the output of LDO2. Note that the MICVDD does not support direct connection to an
external supply; MICVDD is always powered internally to the CS42L92.
The Charge Pump 2 and LDO2 Regulator circuits are shown in Fig. 4-75. The associated control bits are described in
Table 4-124.
Note that decoupling capacitors and flyback capacitors are required for these circuits. Refer to Section 5.1 for
recommended external components.
DS1162F1
257
CS42L92
4.19 Charge Pumps, Regulators, and Voltage Reference
4.19.3 Microphone Bias (MICBIAS) Control
There are two MICBIAS generators, which provide low-noise reference voltages suitable for biasing ECM-type
microphones or powering digital microphones. Refer to Section 5.1.3 for recommended external components.
The MICBIAS generators are powered from MICVDD, which is generated by an internal charge pump and LDO, as shown
in Fig. 4-75.
Switchable outputs from the MICBIAS generators allow six separate reference/supply outputs to be independently
controlled. The MICBIAS regulators are enabled using the MICB1_ENA and MICB2_ENA bits. The MICBIAS output
switches are enabled using the MICB1x_ENA and MICB2x_ENA (where x is A, B, C, or D).
The MICBIAS1 generator supports four switchable outputs (MICBIAS1A–MICBIAS1D). The MICBIAS2 generator
supports two switchable outputs (MICBIAS2A–MICBIAS2B).
Note that, to enable any of the MICBIASnx outputs, both the output switch and the respective regulator must be enabled.
When a MICBIAS output is disabled, it can be configured to be floating or to be actively discharged. This is configured
using the MICBn_DISCH bits (for the MICBIAS regulators), and the MICBnx_DISCH bits (for the switched outputs). Each
discharge path is only effective when the respective regulator, or switched output, is disabled.
The MICBIAS generators can each operate in Regulator Mode or in Bypass Mode. The applicable mode is selected using
the MICBn_BYPASS bits.
In Regulator Mode (MICBn_BYPASS = 0), the output voltage is selected using the MICBn_LVL fields. In this mode,
MICVDD must be at least 200 mV greater than the required MICBIAS output voltages. The MICBIAS outputs are powered
from the MICVDD pin and use the internal band-gap circuit as a reference.
In Regulator Mode, the MICBIAS regulators are designed to operate without external decoupling capacitors. The
regulators can be configured to support a capacitive load if required, using the MICBn_EXT_CAP bits. (This may be
appropriate for a DMIC supply.) It is important that the external capacitance is compatible with the applicable MICBn_EXT_
CAP setting. The compatible load conditions are detailed in Table 3-11.
In Bypass Mode (MICBn_BYPASS = 1), the respective outputs (MICBIASnx), when enabled, are connected directly to
MICVDD. This enables a low power operating state. Note that the MICBn_EXT_CAP settings are not applicable in Bypass
Mode—there are no restrictions on the external MICBIAS capacitance in Bypass Mode.
The MICBIAS generators incorporate a pop-free control circuit to ensure smooth transitions when the MICBIAS outputs
are enabled or disabled in Bypass Mode; this feature is enabled using the MICBn_RATE bits.
The MICBIAS generators are shown in Fig. 4-75. The MICBIAS control fields are described in Table 4-124.
The maximum output current for each MICBIAS regulator is noted in Table 3-11. This limit must be observed for each set
of MICBIASnx outputs, especially if more than one microphone is connected to a single regulator. Note that the maximum
output current differs between Regulator Mode and Bypass Mode.
4.19.3.1 MICBIAS output in Sleep Mode
The CS42L92 supports a low-power Sleep Mode, in which most functions are disabled and power consumption is
minimized. The CS42L92 can maintain an unregulated voltage output in Sleep Mode, suitable for powering an external
microphone in always-on applications. The INnx/DMICx connections are isolated from the CS42L92 circuits in Sleep
Mode, to allow any connected microphone to be used by another circuit while Sleep Mode is selected.
If the MICB1A_AOD_ENA bit is set, the normal register-field configuration of CP2, LDO2, and MICBIAS1 are overridden.
Under these conditions, the CP2, LDO2 and MICBIAS1 circuits are bypassed and the MICBIAS1A output is connected
directly to the CPVDD supply.
The unregulated MICBIAS1A output can be maintained in Sleep Mode by setting MICB1A_AOD_ENA before the DCVDD
supply is removed.
258
DS1162F1
CS42L92
4.19 Charge Pumps, Regulators, and Voltage Reference
To minimize any transient effects during the Sleep Mode transition, the MICBIAS1A should be configured in bypass mode
before Sleep Mode is enabled. The following control sequence is recommended:
•
CP_BYPASS = 1
•
MICB1_BYPASS = 1
•
MICB1A_AOD_ENA = 1
•
Remove DCVDD
To minimize any transient effects following a wake-up transition, the MICBIAS1A should be configured in bypass mode
before clearing MICB1A_AOD_ENA. The following control sequence is recommended:
•
Apply DCVDD
•
LDO2_VSEL = (set as required)
•
CP2_BYPASS = 0
•
MICB1_LVL = (set as required)
•
MICB1_BYPASS = 0
•
MICB1_ENA = 1
•
MICB1A_ENA = 1
•
MICB1A_AOD_ENA = 0
4.19.4 Voltage-Reference Circuit
The CS42L92 incorporates a voltage-reference circuit, powered by AVDD. This circuit ensures the accuracy of the
LDO-regulator and MICBIAS voltage settings.
4.19.5 Block Diagram and Control Registers
The charge-pump and regulator circuits are shown in Fig. 4-75. Note that decoupling capacitors and flyback capacitors
are required for these circuits. Refer to Section 5.1 for recommended external components.
DS1162F1
259
CS42L92
CPVDD
CP1C1A
CP1C1B
CP1C2A
CP1C2B
CP1VOUT1P
CP1VOUT1N
CP1VOUT2P
CP1VOUT2N
CPVDD2
4.19 Charge Pumps, Regulators, and Voltage Reference
Charge Pump 1
CPGND
CP2CA
CP2CB
CP2_ENA p. 260
CP2_BYPASS p. 260
CP2_DISCH p. 260
Charge
Pump 2
CP2VOUT
Analog
Output
Supply
MICBIAS1A
MICB1_ENA p. 261
MICB1_BYPASS p. 261
MICB1_LVL[3:0] p. 261
MICB1_RATE p. 261
MICB1_DISCH p. 261
MICB1_EXT_CAP p. 261
LDO2_VSEL[5:0] p. 261
LDO2_DISCH p. 261
LDO2
MICB1A_ENA p. 262
MICB1A_DISCH p. 262
MICBIAS1B
MICB1B_ENA p. 262
MICB1B_DISCH p. 262
MICBIAS1C
MICB1C_ENA p. 262
MICB1C_DISCH p. 262
MICBIAS1D
MICVDD
MICB1D_ENA p. 262
MICB1D_DISCH p. 262
Analog
Input
Supply
Analog
Supply
AVDD
AGND
Voltage
Reference
AVDD
MICBIAS2A
MICB2_ENA p. 261
MICB2_BYPASS p. 261
MICB2_LVL[3:0] p. 261
MICB2_RATE p. 261
MICB2_DISCH p. 261
MICB2_EXT_CAP p. 261
MICB2A_ENA p. 262
MICB2A_DISCH p. 262
MICBIAS2B
MICB2B_ENA p. 262
MICB2B_DISCH p. 262
Analog
Reference
Figure 4-75. Charge Pumps and Regulators
The charge-pump and regulator control registers are described in Table 4-124.
Table 4-124. Charge-Pump and LDO Control Registers
Register Address Bit
Label
R512 (0x0200)
2 CP2_DISCH
Mic_Charge_
Pump_1
260
1
CP2_BYPASS
0
CP2_ENA
Default
Description
1
Charge Pump 2 Discharge
0 = CP2VOUT floating when disabled
1 = CP2VOUT discharged when disabled
1
Charge Pump 2 and LDO2 Bypass Mode
0 = Normal
1 = Bypass Mode
In Bypass Mode, CPVDD is connected directly to MICVDD.
Note that CP2_ENA must also be set.
1
Charge Pump 2 and LDO2 Control
(Provides analog input and MICVDD supplies)
0 = Disabled
1 = Enabled
DS1162F1
CS42L92
4.19 Charge Pumps, Regulators, and Voltage Reference
Table 4-124. Charge-Pump and LDO Control Registers (Cont.)
Register Address Bit
Label
R531 (0x0213)
10:5 LDO2_VSEL[5:0]
LDO2_Control_1
R536 (0x0218)
Mic_Bias_Ctrl_1
R537 (0x0219)
Mic_Bias_Ctrl_2
DS1162F1
Default
Description
0x1F LDO2 Output Voltage Select 1
0x00 = 0.900 V
0x13 = 1.375 V
… (100-mV steps)
0x01 = 0.925 V
0x14 = 1.400 V
0x26 = 3.200 V
0x02 = 0.950 V
0x15 = 1.500 V
0x27 to 0x3F = 3.300 V
… (25-mV steps)
0x16 = 1.600 V
2 LDO2_DISCH
1
LDO2 Discharge
0 = MICVDD floating when disabled
1 = MICVDD discharged when disabled
15 MICB1_EXT_CAP
0
Microphone Bias 1 External Capacitor (when MICB1_BYPASS = 0).
Configures the MICBIAS1 regulator according to the specified capacitance connected
to the MICBIAS1x outputs.
0 = No external capacitor
1 = External capacitor connected
8:5 MICB1_LVL[3:0]
0x7 Microphone Bias 1 Voltage Control (when MICB1_BYPASS = 0)
0x0 = 1.5 V
… (0.1-V steps)
0xD to 0xF = 2.8 V
0x1 = 1.6 V
0xC = 2.7 V
3 MICB1_RATE
0
Microphone Bias 1 Rate (Bypass Mode)
0 = Fast start-up/shutdown
1 = Pop-free start-up/shutdown
2 MICB1_DISCH
1
Microphone Bias 1 Discharge
0 = MICBIAS1 floating when disabled
1 = MICBIAS1 discharged when disabled
1 MICB1_BYPASS
1
Microphone Bias 1 Mode
0 = Regulator Mode
1 = Bypass Mode
0 MICB1_ENA
0
Microphone Bias 1 Enable
0 = Disabled
1 = Enabled
15 MICB2_EXT_CAP
0
Microphone Bias 2 External Capacitor (when MICB2_BYPASS = 0). Configures the
MICBIAS2 regulator according to the specified capacitance connected to the
MICBIAS2x outputs.
0 = No external capacitor
1 = External capacitor connected
8:5 MICB2_LVL[3:0]
0x7 Microphone Bias 2 Voltage Control (when MICB2_BYPASS = 0)
0x0 = 1.5 V
… (0.1-V steps)
0xD to 0xF = 2.8 V
0x1 = 1.6 V
0xC = 2.7 V
3 MICB2_RATE
0
Microphone Bias 2 Rate (Bypass Mode)
0 = Fast start-up/shutdown
1 = Pop-free start-up/shutdown
2 MICB2_DISCH
1
Microphone Bias 2 Discharge
0 = MICBIAS2 floating when disabled
1 = MICBIAS2 discharged when disabled
1 MICB2_BYPASS
1
Microphone Bias 2 Mode
0 = Regulator Mode
1 = Bypass Mode
0 MICB2_ENA
0
Microphone Bias 2 Enable
0 = Disabled
1 = Enabled
261
CS42L92
4.19 Charge Pumps, Regulators, and Voltage Reference
Table 4-124. Charge-Pump and LDO Control Registers (Cont.)
Register Address Bit
Label
R540 (0x021C)
13 MICB1D_DISCH
Mic_Bias_Ctrl_5
12 MICB1D_ENA
R542 (0x021E)
Mic_Bias_Ctrl_6
R723 (0x02D3)
Jack_detect_
analogue
9
MICB1C_DISCH
8
MICB1C_ENA
5
MICB1B_DISCH
4
MICB1B_ENA
1
MICB1A_DISCH
0
MICB1A_ENA
5
MICB2B_DISCH
4
MICB2B_ENA
1
MICB2A_DISCH
0
MICB2A_ENA
14 MICB1A_AOD_
ENA
Default
Description
1
Microphone Bias 1D Discharge
0 = MICBIAS1D floating when disabled
1 = MICBIAS1D discharged when disabled
0
Microphone Bias 1D Enable
0 = Disabled
1 = Enabled
1
Microphone Bias 1C Discharge
0 = MICBIAS1C floating when disabled
1 = MICBIAS1C discharged when disabled
0
Microphone Bias 1C Enable
0 = Disabled
1 = Enabled
1
Microphone Bias 1B Discharge
0 = MICBIAS1B floating when disabled
1 = MICBIAS1B discharged when disabled
0
Microphone Bias 1B Enable
0 = Disabled
1 = Enabled
1
Microphone Bias 1A Discharge
0 = MICBIAS1A floating when disabled
1 = MICBIAS1A discharged when disabled
0
Microphone Bias 1A Enable
0 = Disabled
1 = Enabled
1
Microphone Bias 2B Discharge
0 = MICBIAS2B floating when disabled
1 = MICBIAS2B discharged when disabled
0
Microphone Bias 2B Enable
0 = Disabled
1 = Enabled
1
Microphone Bias 2A Discharge
0 = MICBIAS2A floating when disabled
1 = MICBIAS2A discharged when disabled
0
Microphone Bias 2A Enable
0 = Disabled
1 = Enabled
0
Microphone Bias 1A Always-On Enable
0 = Disabled
1 = Enabled
1.See Table 4-125 for LDO2 output voltage definition.
Table 4-125 lists the LDO2 voltage control settings.
Table 4-125. LDO2 Voltage Control
LDO2_VSEL[5:0]
0x00
0x01
0x02
0x03
0x04
0x05
0x06
0x07
0x08
0x09
0x0A
262
LDO Output
0.900 V
0.925 V
0.950 V
0.975 V
1.000 V
1.025 V
1.050 V
1.075 V
1.100 V
1.125 V
1.150 V
LDO2_VSEL[5:0]
0x15
0x16
0x17
0x18
0x19
0x1A
0x1B
0x1C
0x1D
0x1E
0x1F
LDO Output
1.500 V
1.600 V
1.700 V
1.800 V
1.900 V
2.000 V
2.100 V
2.200 V
2.300 V
2.400V
2.500 V
DS1162F1
CS42L92
4.20 JTAG Interface
Table 4-125. LDO2 Voltage Control (Cont.)
LDO2_VSEL[5:0]
0x0B
0x0C
0x0D
0x0E
0x0F
0x10
0x11
0x12
0x13
0x14
LDO Output
1.175 V
1.200 V
1.225 V
1.250 V
1.275 V
1.300 V
1.325 V
1.350 V
1.375 V
1.400 V
LDO2_VSEL[5:0]
0x20
0x21
0x22
0x23
0x24
0x25
0x26
0x27
0x28 to 0x3F
LDO Output
2.600 V
2.700 V
2.800 V
2.900 V
3.000 V
3.100 V
3.200 V
3.300 V
3.300 V
4.20 JTAG Interface
The JTAG interface provides test and debug access to the CS42L92. The interface comprises five connections, some of
which are multiplexed with the GPIO13–GPIO15 pins, as noted in Table 4-126.
Table 4-126. JTAG Interface Connections
Pin No
N8
R8
F7
J8
D7
Pin Name
AIF3BCLK/GPIO14
AIF3RXDAT/GPIO15
TDO
AIF3TXDAT/GPIO13
TRST
JTAG Function
TCK
TDI
TDO
TMS
TRST
JTAG Description
Clock input
Data input
Data output
Mode select input
Test access port reset input (active low)
The JTAG interface is supported whenever the GPIO13–GPIO15 are configured as GPIO inputs. To allow JTAG
operation, the following conditions must be met:
•
GPn_FN = 0x001 (n = 13–15)
•
GPn_DIR = 0x1 (n = 13–15)
The GPn_FN and GPn_DIR fields are defined in Table 4-93. Note that the above conditions are also the default values of
these control fields.
For normal operation (test and debug access disabled), the JTAG interface should be held in reset. An internal pull-down
resistor holds the TRST pin low (i.e., JTAG interface is held in reset) when not actively driven. It is recommended to
connect the TRST pin to DGND, if the JTAG interface function is not required.
Integrated pull-up and pull-down resistors can be enabled on the TCK, TDI, and TMS pins. This is provided as part of the
GPIO functionality, and provides a flexible capability for interfacing with other devices. The pull-up and pull-down resistors
can be configured independently using the fields described in Table 4-93.
If the JTAG interface is enabled (TRST deasserted and TCK active) at the time of any reset, a software reset must be
scheduled, with the TCK input stopped or TRST asserted (Logic 0), before using the JTAG interface.
It is recommended to always schedule a software reset before starting the JTAG clock or deasserting the JTAG reset. In
this event, the JTAG interface should be held in its reset state until the software reset has completed, and the BOOT_
DONE_STSx bits have been set. See Section 4.23 for further details of the CS42L92 software reset.
4.21 Short-Circuit Protection
The CS42L92 provides short-circuit protection on the headphone output drivers.
The short-circuit protection function for the headphone output paths operates continuously if the respective output driver
is enabled. If a short circuit is detected on the headphone output, current limiting is applied to protect the respective output
driver. Note that the driver continues to operate, but the output is current-limited.
DS1162F1
263
CS42L92
4.22 Power-On Reset (POR)
The headphone short-circuit protection function provides input to the interrupt control circuit and can be used to trigger an
interrupt event when a short-circuit condition is detected; see Section 4.15.
4.22 Power-On Reset (POR)
The CS42L92 remains in the reset state until AVDD, DBVDD, and DCVDD are above their respective reset thresholds.
Note that specified device performance is not assured outside the voltage ranges defined in Table 3-3.
After the initial power-up, the POR is rescheduled following an interruption to the DBVDD or AVDD supplies.
If the CS42L92 SLIMbus component is in its operational state, it must be reset before scheduling a POR. See Section 4.10
for details of the SLIMbus reset control messages.
4.22.1 Boot Sequence
Following power-on reset, a boot sequence is executed. The BOOT_DONE_STSx bits are asserted on completion of the
boot sequence, as described in Table 4-127. Control-register writes should not be attempted until BOOT_DONE_STSx
has been asserted. Note that the BOOT_DONE_STS1 and BOOT_DONE_STS2 bits provide the same information.
The BOOT_DONE_STSx signal is an input to the interrupt control circuit and can be used to trigger an interrupt event on
completion of the boot sequence; see Section 4.15. Under default register conditions, a falling edge on the IRQ pin
indicates completion of the boot sequence.
For details of the boot sequence, see Section 4.18.
Table 4-127. Device Boot-Up Status
Register Address Bit
Label
R6272 (0x1880)
7 BOOT_DONE_
STS1
IRQ1_Raw_
Status_1
R6528 (0x1980)
IRQ2_Raw_
Status_1
7 BOOT_DONE_
STS2
Default
Description
0
Boot Status
0 = Busy (boot sequence in progress)
1 = Idle (boot sequence completed)
Control register writes should not be attempted until Boot Sequence has completed.
0
Boot Status
0 = Busy (boot sequence in progress)
1 = Idle (boot sequence completed)
Control register writes should not be attempted until Boot Sequence has completed.
4.22.2 Digital I/O Status in Reset
Table 1-1 describes the default status of the CS42L92 digital I/O pins on completion of power-on reset, prior to any register
writes. The same default conditions are also applicable on completion of a hardware reset or software reset (see
Section 4.23).
The same default conditions are applicable following a wake-up transition, except for the IRQ and RESET pins. These are
always-on pins whose configuration is unchanged in Sleep Mode and during a wake-up transition.
Note that the default conditions described in Table 1-1 are not valid if modified by the boot sequence or by a wake-up
control sequence. See Section 4.18 for details of these functions.
4.23 Hardware Reset, Software Reset, Wake-Up, and Device ID
The CS42L92 supports hardware- and software-controlled reset functions. The reset functions, and the Sleep/Wake-Up
state transitions, provide similar (but not identical) functionality. Each of these is described in the following subsections.
The CS42L92 device ID can be read from the Software_Reset (R0) control register, as described in Section 4.23.7.
264
DS1162F1
CS42L92
4.23 Hardware Reset, Software Reset, Wake-Up, and Device ID
4.23.1 Hardware Reset
The CS42L92 provides a hardware reset function, which is executed whenever the RESET input is asserted (Logic 0). The
RESET input is active low and is referenced to the DBVDD power domain. A hardware reset causes all of the CS42L92
control registers to be reset to their default states.
An internal pull-up resistor is enabled by default on the RESET pin; this can be configured using the RESET_PU bit. A
pull-down resistor is also available, as described in Table 4-128. When the pull-up and pull-down resistors are both
enabled, the CS42L92 provides a bus keeper function on the RESET pin. The bus keeper function holds the input logic
level unchanged whenever the external circuit removes the drive (e.g., if the signal is tristated).
If the CS42L92 SLIMbus component is in its operational state, it must be reset prior to scheduling a hardware reset. See
Section 4.10 for details of the SLIMbus reset control messages.
Table 4-128. Reset Pull-Up/Pull-Down Configuration
Register Address
R6864 (0x1AD0)
AOD_Pad_Ctrl
Bit
Label
Default
Description
1
RESET_PU
1
RESET Pull-up enable
0 = Disabled
1 = Enabled
Note: If RESET_PD and RESET_PU are both set, a bus keeper function is enabled on
the RESET pin.
0
RESET_PD
0
RESET Pull-down enable
0 = Disabled
1 = Enabled
Note: If RESET_PD and RESET_PU are both set, a bus keeper function is enabled on
the RESET pin.
4.23.2 Software Reset
A software reset is executed by writing any value to register R0. A software reset causes most of the CS42L92 control
registers to be reset to their default states. Note that the control-write sequencer memory is retained during software reset.
Note that the first register read/write operation following a software reset may be unsuccessful, if the register access is
attempted via a different control interface to the one that commanded the software reset. Note that only the first register
read/write is affected, and only when using more than one control interface.
4.23.3 Wake-Up
The CS42L92 is in Sleep Mode when AVDD and DBVDD are present, and DCVDD is below its reset threshold. (Note that
specific control requirements are also applicable for entering Sleep Mode, as described in Section 4.13.)
In Sleep Mode, most of the digital core (and control registers) are held in reset; selected functions and control registers
are maintained via an always-on internal supply domain. See Section 4.13 for details of the always-on functions.
A wake-up transition (from Sleep Mode) is similar to a software reset, but selected functions and control registers are
maintained via an always-on internal supply domain—the always-on registers are not reset during wake-up. See
Section 4.13 for details of the always-on functions.
4.23.4 Write Sequencer and DSP Firmware Memory Control in Reset and Wake-Up
The control-write sequencer memory contents reverts to its default contents following power-on reset, a hardware reset,
or a Sleep Mode transition. The control sequences (including any user-defined sequences) are maintained in the
sequencer memory through software reset.
The DSP firmware memory contents are cleared following power-on reset, a hardware reset, or a Sleep Mode transition.
The firmware memory contents are not affected by software reset, provided DCVDD is held above its reset threshold.
See Section 5.2 for a summary of the CS42L92 memory reset conditions.
DS1162F1
265
CS42L92
4.23 Hardware Reset, Software Reset, Wake-Up, and Device ID
4.23.5 Boot Sequence
Following hardware reset, software reset, or wake-up from Sleep Mode, a boot sequence is executed. The BOOT_DONE_
STSx bits (see Table 4-127) are deasserted during hardware reset and software reset, and also in Sleep Mode. The
BOOT_DONE_STSx bits are asserted on completion of the boot sequence. Control register writes should not be
attempted until BOOT_DONE_STSx has been asserted.
The BOOT_DONE_STSx status is an input to the interrupt control circuit and can be used to trigger an interrupt event; see
Section 4.15. Note that the BOOT_DONE_STS1 and BOOT_DONE_STS2 bits provide the same information.
For details of the boot sequence, see Section 4.18.
4.23.6 Digital I/O Status in Reset
The status of the CS42L92 digital I/O pins following hardware reset, software reset, or wake-up is described in
Section 4.22.2.
4.23.7 Device ID
The device ID can be read from Register R0. The hardware revision can be read from Register R1.
The software revision can be read from Register R2. The software revision code is incremented if software driver
compatibility or software feature support is changed.
Table 4-129. Device Reset and ID
Register Address Bit
Label
Default
Description
R0 (0x0000)
15:0 SW_RST_DEV_ 0x6371 Writing to this register resets all registers to their default state.
ID[15:0]
Software_Reset
Reading from this register indicates Device ID 0x6371.
R1 (0x0001)
7:0 HW_
—
Hardware Device revision.
REVISION[7:0]
Hardware_
This field is incremented for every new revision of the device.
Revision
R2 (0x0002)
7:0 SW_
—
Software Device revision.
REVISION[7:0]
Software_Revision
This field is incremented if software driver compatibility or software feature support is
changed.
266
DS1162F1
CS42L92
5 Applications
5 Applications
5.1 Recommended External Components
This section provides information on the recommended external components for use with the CS42L92.
5.1.1
Analog Input Paths
The CS42L92 supports up to eight analog audio input connections. Each input is biased to the internal DC reference,
VREF. (Note that this reference voltage is present on the VREFC pin.) A DC-blocking capacitor is required for each analog
input pin used in the target application. The choice of capacitor is determined by the filter that is formed between that
capacitor and the impedance of the input pin. The circuit is shown in Fig. 5-1.
Fc =
VREF
Input
+
PGA
–
C
R
1
2 RC
Fc = High-pass 3 dB cut-off frequency
Figure 5-1. Audio Input Path DC-Blocking Capacitor
In accordance with the CS42L92 input pin resistance (see Table 3-5), a 1-F capacitance for all input connections gives
good results in most cases, with a 3-dB cut-off frequency around 13 Hz.
Ceramic capacitors are suitable, but take care to ensure the desired capacitance is maintained at the AVDD operating
voltage. Also, ceramic capacitors may show microphonic effects, where vibrations and mechanical conditions give rise to
electrical signals. This is particularly problematic for microphone input paths where a large signal gain is required.
A single capacitor is required for a single-ended line or microphone input connection. For a differential input connection,
a DC-blocking capacitor is required on both input pins.
The external connections for single-ended and differential microphones, incorporating the CS42L92 microphone bias
circuit, are shown in Fig. 5-2.
5.1.2
DMIC Input Paths
The CS42L92 supports up to eight channels of DMIC input; two channels of audio data can be multiplexed on each
DMICDATn pin. Each stereo pair is clocked using the respective DMICCLKn pin.
The external connections for digital microphones, incorporating the CS42L92 microphone bias circuit, are shown in
Fig. 5-4. Ceramic decoupling capacitors for the digital microphones may be required—refer to the specific
recommendations for the application microphones.
If two microphones are connected to a single DMICDAT pin, the microphones must be configured to ensure that the Left
mic transmits a data bit when DMICCLK is high, and the Right mic transmits a data bit when DMICCLK is low. The
CS42L92 samples the DMIC data at the end of each DMICCLK phase. Each microphone must tristate its data output when
the other microphone is transmitting. Integrated pull-down resistors can be enabled on the DMICDAT pins if required.
The voltage reference for each DMIC interface is selectable. It is important that the selected reference for the CS42L92
interface is compatible with the applicable configuration of the external microphone.
DS1162F1
267
CS42L92
5.1 Recommended External Components
5.1.3
Microphone Bias Circuit
The CS42L92 is designed to interface easily with analog or digital microphones.
Each microphone requires a bias current (electret condenser microphones) or voltage supply (silicon microphones); these
can be provided by the MICBIAS regulators on the CS42L92. Two MICBIAS generators are available; switchable outputs
allow six separate reference/supply outputs to be independently controlled.
Note that the MICVDD pin can also be used (instead of MICBIASnx) as a reference or power supply for external
microphones. The MICBIAS outputs are recommended, as these offer better noise performance and independent enable/
disable control.
Analog microphones may be connected in single-ended or differential configurations, as shown in Fig. 5-2. The differential
configuration provides better performance due to its rejection of common-mode noise; the single-ended method provides
a reduction in external component count.
A bias resistor is required when using an ECM. The bias resistor should be chosen according to the minimum operating
impedance of the microphone and MICBIAS voltage so that the maximum bias current of the CS42L92 is not exceeded.
A 2.2-k bias resistor is recommended; this provides compatibility with a wide range of microphone components.
MICBIAS
MICBIAS
INnAxP,
INnBLP,
INnBx
INnAxN,
IN1BLN
ECM
INnAxP,
INnBLP,
INnBx
+
PGA
–
To ADC
ECM
+
PGA
–
INnAxN,
IN1BLN
To ADC
GND
VREF
VREF
GND
Figure 5-2. Single-Ended and Differential Analog Microphone Connections
Analog MEMS microphones can be connected to the CS42L92 as shown in Fig. 5-3. In this configuration, the MICBIAS
generators provide a low-noise supply for the microphones; a bias resistor is not required.
MICBIAS
VDD
MEMS
Mic
OUT
INnAxP,
INnBLP,
INnBx
GND
INnAxN,
IN1BLN
GND
VREF
MICBIAS
+
PGA
–
To ADC
MEMS
Mic
VDD
OUT-P
OUT-N
GND
GND
INnAxP,
INnBLP,
INnBx
INnAxN,
IN1BLN
+
PGA
–
To ADC
VREF
Figure 5-3. Single-Ended and Differential Analog Microphone Connections
DMIC connection to the CS42L92 is shown in Fig. 5-4. Note that ceramic decoupling capacitors at the DMIC power supply
pins may be required—refer to the specific recommendations for the application microphones.
268
DS1162F1
CS42L92
5.1 Recommended External Components
MICVDD or MICBIASnx
DMICCLKn
DMICDATn
VDD
VDD
CLK DATA
Digital Mic
CHAN
VDD
Digital
Microphone
Interface
The DMIC inputs are referenced to
MICVDD, MICBIAS1, or MICBIAS2.
CLK DATA
Digital Mic
The supply for each digital microphone
should provide the same voltage as the
applicable reference.
CHAN
AGND
Figure 5-4. DMIC Connection
Each MICBIAS generator can operate in Regulator Mode or in Bypass Mode. See Section 4.19 for details of the MICBIAS
generators.
In Regulator Mode, the MICBIAS regulators are designed to operate without external decoupling capacitors. The
regulators can be configured to support a capacitive load if required (e.g., for DMIC supply decoupling). The compatible
load conditions are detailed in Table 3-11.
If the capacitive load on MICBIAS1 or MICBIAS2 exceeds the specified conditions for Regulator Mode (e.g., due to a
decoupling capacitor or long PCB trace), the respective generator must be configured in Bypass Mode.
The maximum output current for each MICBIAS regulator is noted in Table 3-11. This limit must be observed for each set
of MICBIASnx outputs, especially if more than one microphone is connected to a single regulator. Note that the maximum
output current differs between Regulator Mode and Bypass Mode. The MICBIAS output voltage can be adjusted using
register control in Regulator Mode.
5.1.4
Headphone Driver Output Path
The CS42L92 provides four stereo headphone output drivers. These outputs are all ground referenced, allowing direct
connection to the external loads. There is no requirement for DC-blocking capacitors.
In single-ended (default) configuration, the headphone outputs comprise eight independently controlled output channels,
for up to four stereo headphone or line outputs. In mono (BTL) mode, the headphone drivers support up to four differential
outputs, suitable for a mono earpiece or hearing coil load.
Note that the OUT3 signal path is common to the HPOUT3 and HPOUT4 drivers—only one of these stereo drivers may
be enabled at any time.
The headphone outputs incorporate a common mode, or ground loop, feedback path that provides rejection of
system-related ground noise. The feedback pins must be connected to ground for normal operation of the headphone
outputs. Five feedback pins are provided (HPOUTFB1–HPOUTFB5). The ground feedback path for each HPOUT path is
selected using the HPn_GND_SEL bits as follows:
•
The ground feedback path for HPOUT1 and HPOUT2 headphone outputs is selected using the HP1_GND_SEL
and HP2_GND_SEL register fields respectively—see Table 4-81.
•
The ground feedback path for HPOUT3 and HPOUT4 headphone outputs is selected using the HP3_GND_SEL
field.
DS1162F1
269
CS42L92
5.1 Recommended External Components
The selected feedback pin should be connected to GND as close as possible to the respective headphone jack ground
pin, as shown in Fig. 5-5. In mono (differential) mode, the feedback pins should be connected to the ground plane that is
closest to the earpiece output PCB tracks.
It is recommended to ensure that the electrical characteristics of the PCB traces for each output pair are closely matched.
This is particularly important to matching the two traces of a differential (BTL) output.
Typical headphone and earpiece connections are shown in Fig. 5-5.
CS42L92
HPOUT1L
HPOUT1R
HPOUTFB1
HPOUTFB2
The HPOUT outputs can use any of the
HPOUTFBn pins for ground feedback.
The feedback pins are configured using
HP1_GND_SEL, HP2_GND_SEL and
HP2_GND_SEL.
NC
HPOUT2L
HPOUT2R
HPOUTFB3
HPOUTFB4
NC
HPOUT3L
HPOUT3R
Line Output (Aux/Dock)
HPOUT4L
HPOUT4R
Earpiece
HPOUTFB5
Each headphone output can support stereo (single-ended) or mono (differential)
output. The illustration shows the configuration for a typical application .
Figure 5-5. Headphone and Earpiece Connection
It is common for ESD diodes to be wired to pins that link to external connectors. This provides protection from potentially
harmful ESD effects. In a typical application, ESD diodes would be recommended if the headphone paths
(HPOUT1–HPOUT4) are used for external headphone or line output.
The HPOUTn outputs are ground-referenced, and the respective voltages may swing between +1.8V and –1.8V. The ESD
diode configuration must be carefully chosen.
The recommended ESD diode configuration for these ground-referenced outputs is shown in Fig. 5-6. The back-to-back
arrangement prevents clipping and distortion of the output signal.
Note that similar care is required when connecting the CS42L92 outputs to external circuits that provide input path ESD
protection; the configuration on those input circuits must be correctly designed to accommodate ground-referenced
signals.
270
DS1162F1
CS42L92
5.1 Recommended External Components
CS42L92
HPOUTnL
External Headphone/Line
Output Connection
HPOUTnR
External Headphone/Line
Output Connection
ESD Protection Diodes
Figure 5-6. ESD Diode Configuration for External Output Connections
5.1.5
Power Supply/Reference Decoupling
Electrical coupling exists particularly in digital logic systems where switching in one subsystem causes fluctuations on the
power supply. This effect occurs because the inductance of the power supply acts in opposition to the changes in current
flow that are caused by the logic switching. The resultant variations (spikes) in the power-supply voltage can cause
malfunctions and unintentional behavior in other components. A decoupling (bypass) capacitor can be used as an energy
storage component that provides power to the decoupled circuit for the duration of these power-supply variations,
protecting it from malfunctions that could otherwise arise.
Coupling also occurs in a lower frequency form when ripple is present on the power supply rail caused by changes in the
load current or by limitations of the power-supply regulation method. In audio components such as the CS42L92, these
variations can alter the performance of the signal path, leading to degradation in signal quality. A decoupling capacitor can
be used to filter these effects by presenting the ripple voltage with a low-impedance path that does not affect the circuit to
be decoupled.
These coupling effects are addressed by placing a capacitor between the supply rail and the corresponding ground
reference. In the case of systems comprising multiple power supply rails, decoupling should be provided on each rail.
PCB layout is also a contributory factor for coupling effects. If multiple power supply rails are connected to a single supply
source, it is recommended to provide separate PCB tracks connecting each rail to the supply. See Section 5.5 for
PCB-layout recommendations.
The recommended power-supply decoupling capacitors for CS42L92 are detailed in Table 5-1.
Table 5-1. Power Supply Decoupling Capacitors
Power Supply
AVDD1, AVDD2
CPVDD1
CPVDD2
DBVDD
DCVDD
FLLVDD
MICVDD
VREFC
Decoupling Capacitor
2 x 1.0 F ceramic—one capacitor on each AVDDn pin
4.7 F ceramic
4.7 F ceramic
1 x 0.1 F ceramic 1
2 x 1.0 F ceramic—one capacitor on each DCVDD pin
4.7 F ceramic
4.7 F ceramic
2.2 F ceramic
1.Total capacitance of 4.7 F is required for the DBVDD domain. This can be provided by dedicated
DBVDD decoupling or by other capacitors on the same power rail.
DS1162F1
271
CS42L92
5.1 Recommended External Components
All decoupling capacitors should be placed as close as possible to the CS42L92 device. The connection between AGND,
the AVDD decoupling capacitor, and the main system ground should be made at a single point as close as possible to the
AGND balls of the CS42L92.
Due to the wide tolerance of many types of ceramic capacitors, care must be taken to ensure that the selected components
provide the required capacitance across the required temperature and voltage ranges in the intended application. For most
application the use of ceramic capacitors with capacitor dielectric X7R is recommended.
5.1.6
Charge-Pump Components
The CS42L92 incorporates two charge-pump circuits (CP1 and CP2).
CP1 generates the CP1VOUTnx supply rails for the ground-referenced headphone drivers; CP2 generates the CP2VOUT
supply rail for the microphone bias (MICBIAS) regulators.
Decoupling capacitors are required on each of the charge-pump outputs. Two fly-back capacitors are required for CP1; a
single fly-back capacitor is required for CP2.
The recommended charge-pump capacitors for CS42L92 are detailed in Table 5-2.
Table 5-2. Charge-Pump External Capacitors
Description
CP1VOUT1P decoupling
CP1VOUT1N decoupling
CP1 fly-back 1
(connect between CP1C1A and CP1C1B)
CP1VOUT2P decoupling
CP1VOUT2N decoupling
CP1 fly-back 2
(connect between CP1C2A and CP1C2B)
CP2VOUT decoupling
CP2 fly-back
(connect between CP2CA and CP2CB)
Capacitor
Required capacitance is 2.0 F at 2 V.
Suitable component typically 4.7 F.
Required capacitance is 2.0 F at 2 V.
Suitable component typically 4.7 F.
Required capacitance is 1.0 F at 2 V.
Suitable component typically 2.2 F.
Required capacitance is 2.0 F at 2 V.
Suitable component typically 4.7 F.
Required capacitance is 2.0 F at 2 V.
Suitable component typically 4.7 F.
Required capacitance is 1.0 F at 2 V.
Suitable component typically 2.2 F.
Required capacitance is 1.0 F at 3.6 V.
Suitable component typically 4.7 F.
Required capacitance is 220 nF at 2 V.
Suitable component typically 470 nF.
Ceramic capacitors are recommended for these charge-pump requirements. Note that, due to the wide tolerance of many
types of ceramic capacitors, care must be taken to ensure that the selected components provide the required capacitance
across the required temperature and voltage ranges in the intended application. Ceramic capacitors with X7R dielectric
are recommended.
The positioning of the charge-pump capacitors is important. These capacitors (particularly the fly-back capacitors) must
be placed as close as possible to the CS42L92. The component choice and positioning of the CP1 components are more
critical than those of CP2, due to the higher output power requirements of CP1.
5.1.7
External Accessory Detection Components
The external accessory detection circuit measures jack insertion using the JACKDETn pins. The insertion switch status is
detected using an internal pull-up resistor circuit on the respective pin. Note that the logic thresholds associated with the
JACKDETn pins differ from each other, as described in Table 3-11—this provides support for different jack switch
configurations.
Microphone detection and key-button press detection is supported using the MICDETn pins. The applicable pin should be
connected to one of the MICBIASnx outputs, via a 2.2-k bias resistor, as described in Section 5.1.3. Note that, when
using the external accessory detection function, the MICBIASnx resistor must be 2.2 k ±2%.
A recommended circuit configuration, including headphone output on HPOUT1 and microphone connections, is shown in
Fig. 5-7. See Section 5.1.1 for details of the DC-blocking microphone input capacitor selection.
272
DS1162F1
CS42L92
5.1 Recommended External Components
The recommended external components and connections for microphone/push-button detection are shown in Fig. 5-7.
Note that, when using the microphone detect circuit, it is recommended to use the IN1ALx, IN1BLx, or IN1BR analog
microphone input paths to ensure best immunity to electrical transients arising from the external accessory.
CS42L92
2.2 k(±2%)
MICBIASnx
* IN1ALx, IN1BLx,
IN1BR
C
MICDET1
HPOUT1L
HPOUT1R
HPOUTFB2
(jack insertion switch )
JACKDETn
* Note that the IN1ALx, IN1BLx, or IN1BR
analog mic channels are recommended
with the external accessory detect function
Note: The illustrated circuit
assumes the jack insertion
switch contacts are closed
when the jack is inserted.
Figure 5-7. External Accessory Detection
The accessory detection circuit measures the impedance of an external load connected to one of the MICDET pins.
The microphone-detection circuit uses MICVDD, or any one of the MICBIASnx sources, as a reference. The applicable
source is configured using MICDn_BIAS_SRC.
With default register configuration, the CS42L92 can detect the presence of a typical microphone and up to four push
buttons, using the components shown in Fig. 5-8. When the microphone detection circuit is enabled, each of the push
buttons shown causes a different bit in the MICDn_LVL field to be set.
The choice of external resistor values must take into account the impedance of the microphone—the detected impedance
corresponds to the combined parallel resistance of the microphone and any asserted push button. The components shown
in Fig. 5-8 are examples only, assuming default impedance measurement ranges and a microphone impedance of 1 k
or higher.
DS1162F1
273
CS42L92
5.2 Resets Summary
The measured impedance is reported using the MICDm_STS and MICDm_LVL bits.
If no accessory or push button is detected, the MICDm_STS bit is cleared.
MICBIAS
If MICDm_STS = 1, one of the MICDm_LVL bits is set to indicate the measured
impedance.
The applicable MICDm_LVL bit for each push button is noted below.
2.2 k
(±2%)
Detection of the microphone alone (no push buttons closed) is indicated in
MICDm_LVL[8].
Analog Input
Rmic 1 k
MICDETn
HPDETn
JACKDETn
MICDm_LVL[8] –
Microphone detect
R1 = 0
MICDm_LVL[0]
R2 = 150
MICDm_LVL[1]
R3 = 270
MICDm_LVL[2]
MICDm_LVL[3]
R4 = 620
C
4 x Push Buttons
Sense pin selected by
MICDm_SENSE_SEL
MICDETn
Ground pin selected
by MICDm_GND_SEL
Microphone
Figure 5-8. External Accessory Detect Components
5.2 Resets Summary
Table 5-3 summarizes the CS42L92 registers and other programmable memory under different reset conditions. The
associated events and conditions are listed as follows:
•
A power-on reset occurs when AVDD or DBVDD is below its respective reset threshold. Note that DCVDD is also
required for initial start-up; subsequent interruption to DCVDD should only be permitted as part of a control
sequence for entering Sleep Mode.
•
A hardware reset occurs when the RESET input is asserted (Logic 0).
•
A software reset occurs when register R0 is written to.
•
Sleep Mode is selected when DCVDD is removed. Note that the AVDD and DBVDD supplies must be present
throughout the Sleep Mode duration.
Table 5-3. Memory Reset Summary
Reset Type
Power-on reset
Hardware reset
Software reset
Sleep Mode
Always-On Registers 1
Other Registers
Reset
Reset
Reset
Retained
Reset
Reset
Reset
Reset
Control-Write Sequencer
Memory
Reset
Reset
Retained
Reset
DSP Firmware Memory
Reset
Reset
Retained 2
Reset
1.See Section 4.13 for details of Sleep Mode and the always-on registers.
2.To retain the DSP firmware memory contents during software reset, it must be ensured that DCVDD is held above its reset threshold.
5.3 Output-Signal Drive-Strength Control
The CS42L92 supports configurable drive-strength control for the digital output pins. This can be used to assist
system-level integration and design considerations.
The drive-strength control bits are described in Table 5-4. Note that, in the case of bidirectional pins (e.g., GPIOn), the
drive-strength control bits are only applicable if the pin is configured as an output.
274
DS1162F1
CS42L92
5.3 Output-Signal Drive-Strength Control
Table 5-4. Output Drive-Strength and Slew-Rate Control
Register Address
R8 (0x0008)
Ctrl_IF_CFG_1
Bit
8
Label
CIF1MISO_DRV_
STR
Default
1
R1520 (0x05F0)
Slimbus_Pad_Ctrl
1
SLIMDAT2_DRV_
STR
1
1
SLIMDAT1_DRV_
STR
1
0
SLIMCLK_DRV_
STR
1
R5889 (0x1701)
GPIO1_CTRL2
12
GP1_DRV_STR
1
R5891 (0x1703)
GPIO2_CTRL2
12
GP2_DRV_STR
1
R5893 (0x1705)
GPIO3_CTRL2
12
GP3_DRV_STR
1
R5895 (0x1707)
GPIO4_CTRL2
12
GP4_DRV_STR
1
R5897 (0x1709)
GPIO5_CTRL2
12
GP5_DRV_STR
1
R5899 (0x170B)
GPIO6_CTRL2
12
GP6_DRV_STR
1
R5901 (0x170D)
GPIO7_CTRL2
12
GP7_DRV_STR
1
R5903 (0x170F)
GPIO8_CTRL2
12
GP8_DRV_STR
1
R5905 (0x1711)
GPIO9_CTRL2
12
GP9_DRV_STR
1
R5907 (0x1713)
GPIO10_CTRL2
12
GP10_DRV_STR
1
R5909 (0x1715)
GPIO11_CTRL2
12
GP11_DRV_STR
1
R5911 (0x1717)
GPIO12_CTRL2
12
GP12_DRV_STR
1
R5913 (0x1719)
GPIO13_CTRL2
12
GP13_DRV_STR
1
DS1162F1
Description
CIF1MISO output drive strength
0 = 4 mA
1 = 8 mA
SLIMDAT2 output drive strength
0 = 8 mA
1 = 12 mA
SLIMDAT1 output drive strength
0 = 8 mA
1 = 12 mA
SLIMCLK output drive strength
0 = 2 mA
1 = 4 mA
GPIO1 output drive strength
0 = 4 mA
1 = 8 mA
GPIO2 output drive strength
0 = 4 mA
1 = 8 mA
SPKCLK/GPIO3 output drive strength
0 = 4 mA
1 = 8 mA
SPKDAT/GPIO4 output drive strength
0 = 4 mA
1 = 8 mA
AIF1TXDAT/GPIO5 output drive strength
0 = 4 mA
1 = 8 mA
AIF1BCLK/GPIO6 output drive strength
0 = 4 mA
1 = 8 mA
AIF1RXDAT/GPIO7 output drive strength
0 = 4 mA
1 = 8 mA
AIF1LRCLK/GPIO8 output drive strength
0 = 4 mA
1 = 8 mA
AIF2TXDAT/GPIO9 output drive strength
0 = 4 mA
1 = 8 mA
AIF2BCLK/GPIO10 output drive strength
0 = 4 mA
1 = 8 mA
AIF2RXDAT/GPIO11 output drive strength
0 = 4 mA
1 = 8 mA
AIF2LRCLK/GPIO12 output drive strength
0 = 4 mA
1 = 8 mA
AIF3TXDAT/GPIO13 output drive strength
0 = 4 mA
1 = 8 mA
275
CS42L92
5.4 Digital Audio Interface Clocking Configurations
Table 5-4. Output Drive-Strength and Slew-Rate Control (Cont.)
Register Address
R5915 (0x171B)
GPIO14_CTRL2
Bit
12
Label
GP14_DRV_STR
Default
1
R5917 (0x171D)
GPIO15_CTRL2
12
GP15_DRV_STR
1
R5919 (0x171F)
GPIO16_CTRL2
12
GP16_DRV_STR
1
Description
AIF3BCLK/GPIO14 output drive strength
0 = 4 mA
1 = 8 mA
AIF3RXDAT/GPIO15 output drive strength
0 = 4 mA
1 = 8 mA
AIF3LRCLK/GPIO16 output drive strength
0 = 4 mA
1 = 8 mA
5.4 Digital Audio Interface Clocking Configurations
The digital audio interfaces (AIF1–AIF3) can be configured in master or slave modes. In all applications, it is important that
the system clocking configuration is correctly designed. Incorrect clock configurations lead to audible clicks arising from
dropped or repeated audio samples; this is caused by the inherent tolerances of multiple asynchronous system clocks.
To ensure reliable clocking of the audio interface functions, the external interface clocks (e.g., BCLK, LRCLK) must be
derived from the same clock source as SYSCLK (or ASYNCCLK, where applicable).
In AIF Master Mode, the external BCLK and LRCLK signals are generated by the CS42L92 and synchronization of these
signals with SYSCLK (or ASYNCCLK) is ensured. In this case, clocking of the AIF is typically derived from the MCLKn
inputs, either directly or via one of the FLL circuits. Alternatively, an AIFn or SLIMbus interface can be used to provide the
reference clock to which the AIF master can be synchronized.
In AIF Slave Mode, the external BCLK and LRCLK signals are generated by another device, as inputs to the CS42L92. In
this case, the system clock (SYSCLK or ASYNCCLK) must be generated from a source that is synchronized to the external
BCLK and LRCLK inputs.
In a typical Slave Mode application, the BCLK input is selected as the clock reference, using the FLL to perform frequency
shifting. The MCLK1, MCLK2, or MCLK3 inputs can also be used, but only if the selected clock is synchronized externally
to the BCLK and LRCLK inputs. The SLIMbus interface can also provide the clock reference, via one of the FLLs, provided
that the BCLK and LRCLK signals are externally synchronized with the SLIMCLK input.
The valid AIF clocking configurations are listed in Table 5-5 for AIF Master and AIF Slave Modes.
The applicable system clock (SYSCLK or ASYNCCLK) depends on the AIFn_RATE setting for the relevant digital audio
interface; if AIFn_RATE < 1000, SYSCLK is applicable; if AIFn_RATE 1000, ASYNCCLK is applicable.
Table 5-5. AIF Clocking Configurations
AIF Mode
AIF Master Mode
AIF Slave Mode
Clocking Configuration
SYSCLK_SRC (ASYNCCLK_SRC) selects MCLK1, MCLK2, or MCLK3 as SYSCLK (ASYNCCLK) source.
SYSCLK_SRC (ASYNCCLK_SRC) selects FLLn as SYSCLK (ASYNCCLK) source;
FLLn_REFCLK_SRC selects MCLK1, MCLK2, or MCLK3 as FLLn source.
SYSCLK_SRC (ASYNCCLK_SRC) selects FLLn as SYSCLK (ASYNCCLK) source;
FLLn_REFCLK_SRC selects a different interface (BCLK, LRCLK, SLIMCLK) as FLLn source.
SYSCLK_SRC (ASYNCCLK_SRC) selects FLLn as SYSCLK (ASYNCCLK) source;
FLLn_REFCLK_SRC selects BCLK as FLLn source.
SYSCLK_SRC (ASYNCCLK_SRC) selects MCLK1, MCLK2, or MCLK3 as SYSCLK (ASYNCCLK) source,
provided MCLK is externally synchronized to the BCLK input.
SYSCLK_SRC (ASYNCCLK_SRC) selects FLLn as SYSCLK (ASYNCCLK) source;
FLLn_REFCLK_SRC selects MCLK1, MCLK2, or MCLK3 as FLLn source, provided MCLK is externally
synchronized to the BCLK input.
SYSCLK_SRC (ASYNCCLK_SRC) selects FLLn as SYSCLK (ASYNCCLK) source;
FLLn_REFCLK_SRC selects a different interface (e.g., SLIMCLK) as FLLn source, provided the other
interface is externally synchronized to the BCLK input.
In each case, the SYSCLK (ASYNCCLK) frequency must be a valid ratio to the LRCLK frequency; the supported clocking
rates are defined by the SYSCLK_FREQ (ASYNC_CLK_FREQ) and SAMPLE_RATE_n (ASYNC_SAMPLE_RATE_n)
fields.
276
DS1162F1
CS42L92
5.4 Digital Audio Interface Clocking Configurations
The valid AIF clocking configurations are shown in Fig. 5-9 to Fig. 5-15. Note that, where MCLK1 is shown as the clock
source, it is equally possible to select MCLK2 or MCLK3 as the clock source. Similarly, in cases where FLL1 is shown, it
is equally possible to select FLL2.
Fig. 5-9 shows AIF Master Mode operation, using MCLK as the clock reference.
CS42L92
Processor
AIFnBCLK
MCLK3
MCLK2
MCLK1
FLLn
AIFnBCLK
SLIMCLK
SYSCLK
(or ASYNCCLK)
AIFn
(Master Mode)
SYSCLK_SRC
(or ASYNC_CLK_SRC)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
Oscillator
Figure 5-9. AIF Master Mode, Using MCLK as Reference
Fig. 5-10 shows AIF Master Mode operation, using MCLK as the clock reference. In this example, the FLL is used to
generate the system clock, with MCLK as the reference.
CS42L92
Processor
AIFnBCLK
AIFnLRCLK
SLIMCLK
FLL1
MCLK3
MCLK2
MCLK1
FLL1_REFCLK
_SRC
AIFnBCLK
AIFnBCLK
SLIMCLK
MCLK1
MCLK2
MCLK3
SYSCLK
(or ASYNCCLK)
AIFn
(Master Mode)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
SYSCLK_SRC
(or ASYNC_CLK_SRC)
Oscillator
Figure 5-10. AIF Master Mode, Using MCLK and FLL as Reference
DS1162F1
277
CS42L92
5.4 Digital Audio Interface Clocking Configurations
Fig. 5-11 shows AIF Master Mode operation, using a separate interface as the clock reference. In this example, the FLL
is used to generate the system clock, with SLIMCLK as the reference.
CS42L92
Processor
FLL1
FLL1_REFCLK
_SRC
AIFnBCLK
AIFnLRCLK
SLIMCLK
MCLK1
MCLK2
MCLK3
AIFnBCLK
AIFnBCLK
SLIMCLK
MCLK1
MCLK2
MCLK3
SYSCLK
(or ASYNCCLK)
AIFn
(Master Mode)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
SYSCLK_SRC
(or ASYNC_CLK_SRC)
Processor
AIFnBCLK
AIFn
(Slave Mode)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
Automatic
Divider
FRAMER_REF_GEAR
Processor
SLIMbus
Interface
SLIMCLK
SLIMDAT
Figure 5-11. AIF Master Mode, Using Another Interface as Reference
Fig. 5-12 shows AIF Slave Mode operation, using BCLK as the clock reference. In this example, the FLL is used to
generate the system clock, with BCLK as the reference.
CS42L92
AIFnBCLK
AIFnLRCLK
SLIMCLK
MCLK1
MCLK2
MCLK3
FLL1_REFCLK_SRC
Processor
FLL1
AIFnBCLK
AIFnBCLK
SLIMCLK
MCLK1
MCLK2
MCLK3
SYSCLK
(or ASYNCCLK)
AIFn
(Slave Mode)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
SYSCLK_SRC
(or ASYNC_CLK_SRC)
Figure 5-12. AIF Slave Mode, Using BCLK and FLL as Reference
278
DS1162F1
CS42L92
5.4 Digital Audio Interface Clocking Configurations
Fig. 5-13 shows AIF Slave Mode operation, using MCLK as the clock reference. For correct operation, the MCLK input
must be fully synchronized to the audio interface.
CS42L92
Processor
MCLK3
MCLK2
MCLK1
FLLn
AIFnBCLK
SLIMCLK
AIFnBCLK
SYSCLK
(or ASYNCCLK)
AIFn
(Slave Mode)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
SYSCLK_SRC
(or ASYNC_CLK_SRC)
Synchronous
Clock Generator
Figure 5-13. AIF Slave Mode, Using MCLK as Reference
Fig. 5-14 shows AIF Slave Mode operation, using MCLK as the clock reference. For correct operation, the MCLK input
must be fully synchronized to the audio interface. In this example, the FLL is used to generate the system clock, with MCLK
as the reference.
CS42L92
Processor
AIFnBCLK
AIFnLRCLK
SLIMCLK
MCLK3
MCLK2
MCLK1
FLL1_REFCLK
_SRC
FLL1
AIFnBCLK
AIFnBCLK
SLIMCLK
MCLK1
MCLK2
MCLK3
SYSCLK
(or ASYNCCLK)
AIFn
(Slave Mode)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
SYSCLK_SRC
(or ASYNC_CLK_SRC)
Synchronous
Clock Generator
Figure 5-14. AIF Slave Mode, Using MCLK and FLL as Reference
DS1162F1
279
CS42L92
5.5 PCB Layout Considerations
Fig. 5-15 shows AIF Slave Mode operation, using a separate interface as the clock reference. In this example, the FLL is
used to generate the system clock, with SLIMCLK as the reference. For correct operation, the SLIMCLK input must be
fully synchronized to the other audio interfaces.
Processor
MCLK1
MCLK2
MCLK3
FLL1
FLL1_REFCLK
_SRC
AIFnBCLK
AIFnLRCLK
SLIMCLK
CS42L92
AIFnBCLK
SLIMCLK
MCLK1
MCLK2
MCLK3
AIFnBCLK
SYSCLK
(or ASYNCCLK)
AIFn
(Slave Mode)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
SYSCLK_SRC
(or ASYNC_CLK_SRC)
Synchronous
Clock Generator
Processor
AIFnBCLK
AIFn
(Slave Mode)
AIFnLRCLK
AIFnRXDAT
AIFnTXDAT
Automatic
Divider
FRAMER_REF_GEAR
Processor
SLIMbus
Interface
SLIMCLK
SLIMDAT
Figure 5-15. AIF Slave Mode, Using Another Interface as Reference
5.5 PCB Layout Considerations
PCB layout should be carefully considered, to ensure optimum performance of the CS42L92. Poor PCB layout degrades
the performance and is a contributory factor in EMI, ground bounce, and resistive voltage losses. All external components
should be placed close to the CS42L92, with current loop areas kept as small as possible. The following specific
considerations should be noted:
•
Placement of the charge pump capacitors is a high priority requirement—these capacitors (particularly the fly-back
capacitors) must be placed as close as possible to the CS42L92. The component choice and positioning of the CP1
components are more critical than those of CP2, due to the higher output power requirements of CP1.
•
Decoupling capacitors should be placed as close as possible to the CS42L92. The connection between AGND, the
AVDD decoupling capacitor, and the main system ground should be made at a single point as close as possible to
the AGND balls of the CS42L92.
•
The VREFC capacitor should be placed as close as possible to the CS42L92. The ground connection to the VREFC
capacitor should be as close as possible to the AGND1 ball of the CS42L92.
•
If multiple power supply rails are connected to a single supply source, it is recommended to provide separate PCB
tracks connecting each rail to the supply. This configuration is also known as star connection.
•
If power supply rails are routed between different layers of the PCB, it is recommended to use several track vias, in
order to minimize resistive voltage losses.
•
Differential input signal tracks should be routed as a pair, ensuring similar length/width dimensions on each track.
Input signal paths should be kept away from high frequency digital signals.
280
DS1162F1
CS42L92
6 Register Map
•
Differential output signal tracks should be routed as a pair, ensuring similar length/width dimensions on each track.
The tracks should provide a low resistance path from the device output pin to the load (< 1% of the minimum load).
•
The headphone output ground-feedback pins should be connected to GND as close as possible to the respective
headphone jack ground pin. The ground-feedback PCB track should follow the same route as the respective output
signal paths.
6 Register Map
The CS42L92 control registers are listed in the following tables. Note that only the register addresses described here
should be accessed; writing to other addresses may result in undefined behavior. Register bits that are not documented
should not be changed from the default values.
The CS42L92 register map is defined in two regions:
•
The register space below 0x3000 is defined in 16-bit word format
•
The register space from 0x3000 upwards is defined in 32-bit word format
It is important to ensure that all control interface register operations use the applicable data word format, in accordance
with the applicable register addresses.
The 16-bit codec register space is described in Table 6-1.
Table 6-1. Register Map Definition—16-bit region
Register
R0
(0h)
R1
(1h)
R2
(2h)
R8
(8h)
R22
(16h)
R23
(17h)
R24
(18h)
R32
(20h)
R33
(21h)
R34
(22h)
R35
(23h)
R36
(24h)
R48
(30h)
R49
(31h)
R50
(32h)
R66
(42h)R65
(41h)
R75
(4Bh)
R76
(4Ch)
R77
(4Dh)
R78
(4Eh)
R79
(4Fh)
R80
(50h)
Name
Software_Reset
15
14
13
12
11
10
9
Hardware_Revision
0
0
0
0
0
0
0
0
HW_REVISION [7:0]
0001h
Software_Revision
0
0
0
0
0
0
0
0
SW_REVISION [7:0]
0000h
Ctrl_IF_CFG_1
0
0
0
0
0
0
1
Write_Sequencer_Ctrl_0
0
0
0
0
WSEQ_
ABORT
WSEQ_
START
WSEQ_
ENA
WSEQ_START_INDEX [8:0]
0000h
Write_Sequencer_Ctrl_1
0
0
0
0
0
0
WSEQ_
BUSY
WSEQ_CURRENT_INDEX [8:0]
0000h
Write_Sequencer_Ctrl_2
0
0
0
0
0
0
0
Tone_Generator_1
TONE_RATE [4:0]
0
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
0
0
TONE2_ TONE1_
OVD
OVD
1
0
0
0
0
0
0
0
WSEQ_ WSEQ_
BOOT_ LOAD_
START
MEM
TONE2_ TONE1_
ENA
ENA
0
0
0
0
0
0
0
0
0
PWM_Drive_1
0
0
0
PWM_RATE [4:0]
0
0
0000h
0000h
TONE2_LVL [7:0]
0
0000h
1000h
0
PWM_CLK_SEL [2:0]
0308h
0000h
TONE1_LVL [7:0]
TONE2_LVL [23:8]
0
Default
6371h
1000h
TONE1_LVL [23:8]
Tone_Generator_4
Tone_Generator_5
7
CIF1MISO CIF1MISO
_DRV_
_PD
STR
TONE_OFFSET [1:0]
Tone_Generator_2
Tone_Generator_3
8
SW_RST_DEV_ID [15:0]
0
PWM2_
OVD
PWM1_
OVD
0
0
PWM2_
ENA
PWM1_
ENA
0000h
PWM_Drive_2
0
0
0
0
0
0
PWM1_LVL [9:0]
0100h
PWM_Drive_3
0
0
0
0
0
0
PWM2_LVL [9:0]
0100h
Spare_Triggers
WSEQ_
TRG16
WSEQ_
TRG15
WSEQ_
TRG14
WSEQ_
TRG13
WSEQ_
TRG12
WSEQ_
TRG11
WSEQ_
TRG10
0
0
0
0
0
0
0
WSEQ_TRG1_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG2_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG3_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG4_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG5_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG6_INDEX [8:0]
01FFh
Spare_Sequence_
Select_1
Spare_Sequence_
Select_2
Spare_Sequence_
Select_3
Spare_Sequence_
Select_4
Spare_Sequence_
Select_5
Spare_Sequence_
Select_6
DS1162F1
WSEQ_
TRG9
WSEQ_
TRG8
WSEQ_
TRG7
WSEQ_
TRG6
WSEQ_
TRG5
WSEQ_
TRG4
WSEQ_
TRG3
WSEQ_
TRG2
WSEQ_
TRG1
0000h
281
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R89
(59h)
R90
(5Ah)
R91
(5Bh)
R92
(5Ch)
R93
(5Dh)
R94
(5Eh)
R97
(61h)
R98
(62h)
R99
(63h)
R100
(64h)
R102
(66h)
R103
(67h)
R104
(68h)
R105
(69h)
R106
(6Ah)
R107
(6Bh)
R110
(6Eh)
R111
(6Fh)
R120
(78h)
R144
(90h)
R145
(91h)
R146
(92h)
R147
(93h)
R148
(94h)
R149
(95h)
R150
(96h)
R151
(97h)
R152
(98h)
R160
(A0h)
R256
(100h)
R257
(101h)
R258
(102h)
R259
(103h)
R260
(104h)
R266
(10Ah)
R267
(10Bh)
R268
(10Ch)
R274
(112h)
282
Name
Spare_Sequence_
Select_7
Spare_Sequence_
Select_8
Spare_Sequence_
Select_9
Spare_Sequence_
Select_10
Spare_Sequence_
Select_11
Spare_Sequence_
Select_12
Sample_Rate_
Sequence_Select_1
Sample_Rate_
Sequence_Select_2
Sample_Rate_
Sequence_Select_3
Sample_Rate_
Sequence_Select_4
Always_On_Triggers_
Sequence_Select_1
Always_On_Triggers_
Sequence_Select_2
Spare_Sequence_
Select_13
Spare_Sequence_
Select_14
Spare_Sequence_
Select_15
Spare_Sequence_
Select_16
Trigger_Sequence_
Select_32
Trigger_Sequence_
Select_33
Eventlog_Sequence_
Select_1
Haptics_Control_1
15
14
13
12
11
10
9
0
0
0
0
0
0
0
WSEQ_TRG7_INDEX [8:0]
Default
01FFh
0
0
0
0
0
0
0
WSEQ_TRG8_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG9_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG10_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG11_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG12_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_SAMPLE_RATE_DETECT_A_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_SAMPLE_RATE_DETECT_B_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_SAMPLE_RATE_DETECT_C_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_SAMPLE_RATE_DETECT_D_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_MICD_CLAMP_RISE_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_MICD_CLAMP_FALL_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG13_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG14_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG15_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_TRG16_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_DRC1_SIG_DET_RISE_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_DRC1_SIG_DET_FALL_INDEX [8:0]
01FFh
0
0
0
0
0
0
0
WSEQ_EVENTLOG1_INDEX [8:0]
01FFh
0
0
Haptics_Control_2
0
Haptics_phase_1_
intensity
Haptics_phase_1_
duration
Haptics_phase_2_
intensity
Haptics_phase_2_
duration
Haptics_phase_3_
intensity
Haptics_phase_3_
duration
Haptics_Status
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
NOISE_
GEN_ENA
0
0
0
0
CLK_32K_
ENA
0
0
0
SYSCLK_
ENA
0
0
Comfort_Noise_
Generator
Clock_32k_1
HAP_RATE [4:0]
8
0
7
6
0
5
0
4
0
ONESHOT
_TRIG
3
2
HAP_CTRL [1:0]
1
0
HAP_ACT
0
7FFFh
LRA_FREQ [14:0]
NOISE_GEN_RATE [4:0]
0000h
0
0000h
PHASE1_INTENSITY [7:0]
0000h
PHASE1_DURATION [8:0]
0
0000h
PHASE2_INTENSITY [7:0]
0000h
PHASE2_DURATION [10:0]
0
0000h
PHASE3_INTENSITY [7:0]
0000h
PHASE3_DURATION [8:0]
0
0
0
0
ONESHOT
_STS
0000h
NOISE_GEN_GAIN [4:0]
0000h
0
0002h
0
0
0
0
0
SYSCLK_
FRAC
0
0
0
0
Sample_rate_1
0
0
0
0
0
0
0
0
0
0
0
SAMPLE_RATE_1 [4:0]
0011h
Sample_rate_2
0
0
0
0
0
0
0
0
0
0
0
SAMPLE_RATE_2 [4:0]
0011h
Sample_rate_3
0
0
0
0
0
0
0
0
0
0
0
SAMPLE_RATE_3 [4:0]
0011h
Sample_rate_1_status
0
0
0
0
0
0
0
0
0
0
0
SAMPLE_RATE_1_STS [4:0]
0000h
Sample_rate_2_status
0
0
0
0
0
0
0
0
0
0
0
SAMPLE_RATE_2_STS [4:0]
0000h
Sample_rate_3_status
0
0
0
0
0
0
0
0
0
0
0
SAMPLE_RATE_3_STS [4:0]
0000h
Async_clock_1
0
0
0
0
0
0
ASYNC_
CLK_ENA
0
System_Clock_1
SYSCLK_FREQ [2:0]
ASYNC_CLK_FREQ [2:0]
0
0
CLK_32K_SRC [1:0]
SYSCLK_SRC [3:0]
ASYNC_CLK_SRC [3:0]
0404h
0305h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R275
(113h)
R276
(114h)
R283
(11Bh)
R284
(11Ch)
R329
(149h)
R330
(14Ah)
Name
Async_sample_rate_1
15
14
13
12
11
10
9
8
7
6
5
0
0
0
0
0
0
0
0
0
0
0
ASYNC_SAMPLE_RATE_1 [4:0]
Default
0011h
Async_sample_rate_2
0
0
0
0
0
0
0
0
0
0
0
ASYNC_SAMPLE_RATE_2 [4:0]
0011h
Async_sample_rate_1_
status
Async_sample_rate_2_
status
Output_system_clock
0
0
0
0
0
0
0
0
0
0
0
ASYNC_SAMPLE_RATE_1_STS [4:0]
0000h
0
0
0
0
0
0
0
0
0
0
0
ASYNC_SAMPLE_RATE_2_STS [4:0]
0000h
OPCLK_
ENA
0
0
0
0
0
0
0
OPCLK_DIV [4:0]
OPCLK_SEL [2:0]
0000h
0
0
0
0
0
0
0
OPCLK_ASYNC_DIV [4:0]
OPCLK_ASYNC_SEL [2:0]
0000h
R334
(14Eh)
R338
(152h)
R339
(153h)
R340
(154h)
R341
(155h)
R342
(156h)
R352
(160h)
R369
(171h)
R370
(172h)
Clock_Gen_Pad_Ctrl
OPCLK_
ASYNC_
ENA
0
0
0
0
0
0
Rate_Estimator_1
0
0
0
0
0
0
0
0
Rate_Estimator_2
0
0
0
0
0
0
0
Rate_Estimator_3
0
0
0
0
0
0
Rate_Estimator_4
0
0
0
0
0
Rate_Estimator_5
0
0
0
0
0
R371
(173h)
R372
(174h)
R373
(175h)
R374
(176h)
R376
(178h)
R378
(17Ah)
R379
(17Bh)
R381
(17Dh)
R398
(18Eh)
FLL1_Control_3
FLL1_THETA [15:0]
0000h
FLL1_Control_4
FLL1_LAMBDA [15:0]
0000h
R401
(191h)
R402
(192h)
FLL2_Control_1
R403
(193h)
R404
(194h)
R405
(195h)
R406
(196h)
R408
(198h)
R410
(19Ah)
R411
(19Bh)
R413
(19Dh)
R430
(1AEh)
FLL2_Control_3
FLL2_THETA [15:0]
0000h
FLL2_Control_4
FLL2_LAMBDA [15:0]
0000h
R512
(200h)
R531
(213h)
Output_async_clock
Clocking_debug_5
ASYNC_CLK_FREQ_STS [2:0]
FLL1_Control_1
FLL1_Control_2
0
0
0
0
0
0
SAMPLE_RATE_DETECT_A [4:0]
0000h
0
0
0
0
0
SAMPLE_RATE_DETECT_B [4:0]
0000h
0
0
0
0
0
0
SAMPLE_RATE_DETECT_C [4:0]
0000h
0
0
0
0
0
0
SAMPLE_RATE_DETECT_D [4:0]
0000h
0
0
0
0
0
0
0
0
0
FLL1_Control_6
FLL1_
REFDET
0
0
0
0
0
0
0
0
0
FLL1_REFCLK_DIV
[1:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
FLL1_Digital_Test_1
0
0
1
1
0
0
1
1
0
1
1
FLL1_GPIO_Clock
0
0
0
0
0
0
0
0
FLL2_
CTRL_
UPD
0
0
0
0
0
FLL2_Control_5
0
0
0
0
0
0
FLL2_Control_6
FLL2_
REFDET
0
0
0
0
0
FLL2_Control_8
FLL2_Control_10
FLL2_PD_GAIN_FINE [3:0]
FLL2_HP [1:0]
0
0
0
FLL1_ENA
0
0
FLL2_REFCLK_DIV
[1:0]
0
0
0001h
0
0
0
0
0
0
0
1
1
0
0
0
0
1000h
FLL1_
LOCKDET
0011h
0
FLL1_LOCKDET_THR [3:0]
FLL1_CLK_VCO_
FAST_SRC[1:0]
FLL2_
HOLD
0
FLL1_
GPCLK_
ENA
FLL2_ENA
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
FLL2_Digital_Test_1
0
0
1
1
0
0
1
1
0
1
1
0
FLL2_GPIO_Clock
0
0
0
0
0
0
Mic_Charge_Pump_1
0
0
0
0
0
0
0
LDO2_Control_1
0
0
0
0
0
0
0
0
0
0
FLL2_LOCKDET_THR [3:0]
1
1
0
LDO2_VSEL [5:0]
0
0
0
7000h
0
0
CP2_
DISCH
CP2_
BYPASS
0
0
LDO2_
DISCH
0
8000h
21F0h
0
1000h
FLL2_
LOCKDET
0011h
FLL2_CLK_VCO_
FAST_SRC[1:0]
FLL2_GPCLK_DIV [6:0]
0
0C04h
0001h
FLL2_FD_GAIN_COARSE [3:0]
0
33E8h
0004h
FLL2_FD_GAIN_FINE [3:0]
1
8000h
21F0h
FLL1_FD_GAIN_COARSE [3:0]
0
7004h
0004h
FLL2_FB_DIV [9:0]
FLL2_Control_11
DS1162F1
0
FLL2_N [9:0]
0
0
FLL1_
HOLD
FLL1_GPCLK_DIV [6:0]
FLL2_PD_GAIN_COARSE [3:0]
FLL2_GPDIV_SRC
[1:0]
0
FLL1_FD_GAIN_FINE [3:0]
1
0
0
FLL1_FB_DIV [9:0]
0
0
0000h
SYSCLK_SRC_STS [3:0]
FLL1_N [9:0]
FLL1_PD_GAIN_COARSE [3:0]
FLL1_GPDIV_SRC
[1:0]
0
LRCLK_SRC [2:0]
SYSCLK_FREQ_STS [2:0]
FLL1_Control_11
FLL2_Control_2
0000h
0
0
FLL2_REFCLK_SRC [3:0]
RATE_
EST_ENA
TRIG_ON_
STARTUP
0
FLL1_HP [1:0]
0000h
0
0
FLL1_Control_10
0
0
0
0
0
0
0
FLL1_PD_GAIN_FINE [3:0]
1
0
0
0
2
0
FLL1_Control_5
FLL1_Control_8
3
0
ASYNC_CLK_SRC_STS [3:0]
FLL1_REFCLK_SRC [3:0]
FLL1_
CTRL_
UPD
MCLK3_ MCLK2_ MCLK1_
PD
PD
PD
4
33E8h
FLL2_
GPCLK_
ENA
CP2_ENA
0C04h
0
03E4h
0006h
283
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R536
(218h)
R537
(219h)
R540
(21Ch)
R542
(21Eh)
R665
(299h)
R667
(29Bh)
R668
(29Ch)
R669
(29Dh)
R674
(2A2h)
Name
Mic_Bias_Ctrl_1
15
14
13
12
11
10
9
4
3
2
1
0
MICB1_
EXT_CAP
0
0
0
0
0
0
MICB1_LVL [3:0]
0
MICB1_
RATE
MICB1_
DISCH
MICB1_
BYPASS
MICB1_
ENA
Mic_Bias_Ctrl_2
MICB2_
EXT_CAP
0
0
0
0
0
0
MICB2_LVL [3:0]
0
MICB2_
RATE
MICB2_
DISCH
MICB2_
BYPASS
MICB2_
ENA
00E6h
Mic_Bias_Ctrl_5
0
0
0
0
Mic_Bias_Ctrl_6
0
0
0
0
Headphone_Detect_0
HPD_
OVD_ENA
Headphone_Detect_1
0
Headphone_Detect_2
HPD_
DONE
Headphone_Detect_3
0
MICB1D_ MICB1D_
DISCH
ENA
0
0
HPD_OUT_SEL [2:0]
0
0
7
MICB1C_ MICB1C_
DISCH
ENA
0
0
0
0
HPD_IMPEDANCE_
RANGE [1:0]
0
0
0
0
0
0
ADC_
MODE
MICD1_BIAS_STARTTIME [3:0]
0
0
0
0
MICB1B_ MICB1B_
DISCH
ENA
0
0
MICB1A_ MICB1A_
DISCH
ENA
2222h
0
0
MICB2B_ MICB2B_
DISCH
ENA
0
0
MICB2A_ MICB2A_
DISCH
ENA
0022h
HPD_SENSE_SEL [3:0]
0
0
0
R691
(2B3h)
R692
(2B4h)
R693
(2B5h)
R699
(2BBh)
R710
(2C6h)
Mic_Detect_2_Control_1
Micd_Clamp_control
0
0
0
0
0
0
R712
(2C8h)
R723
(2D3h)
R768
(300h)
R769
(301h)
R776
(308h)
R777
(309h)
R780
(30Ch)
R784
(310h)
R785
(311h)
R786
(312h)
R787
(313h)
R788
(314h)
R789
(315h)
R790
(316h)
GP_Switch_1
0
0
0
0
0
0
MICD_
CLAMP2_
OVD
0
Jack_detect_analogue
0
MICB1A_
AOD_ENA
0
0
0
0
Input_Enables
0
0
0
0
0
Input_Enables_Status
0
0
0
0
0
R791
(317h)
R792
(318h)
R793
(319h)
R794
(31Ah)
IN1R_Rate_Control
0
0
0
0
0
Mic_Detect_1_Control_3
0
0
0
0
0
Mic_Detect_1_Control_4
0
MICD1_RATE [3:0]
Mic_Detect_1_Control_2
0
0
Mic_Detect_2_Control_0 MICD2_
0
0
0
ADC_
MODE
MICD2_BIAS_STARTTIME [3:0]
0
0
0
0
Mic_Detect_2_Control_3
0
0
0
0
0
Mic_Detect_2_Control_4
IN_RATE [4:0]
0
0
0
0
0
0000h
MICD2_ADCVAL [6:0]
0
0000h
0210h
MICD_CLAMP1_MODE [3:0]
SW2_MODE [1:0]
SW1_MODE [1:0]
0000h
0
IN4L_
IN4R_
IN3L_
IN3R_
IN2L_
IN2R_
IN1L_
IN1R_
ENA_STS ENA_STS ENA_STS ENA_STS ENA_STS ENA_STS ENA_STS ENA_STS
0000h
IN_RATE_
MODE
0
0
0
0
0
0
IN_VU
IN1L_
MUTE
IN1_OSR [2:0]
0
0
0
0
0
0
IN_VD_RAMP [2:0]
0
0
0
0
0
0
0
0
0400h
0
IN_VI_RAMP [2:0]
0022h
0
IN_HPF_CUT [2:0]
0002h
IN1L_PGA_VOL [6:0]
0
0080h
0180h
IN1L_VOL [7:0]
0
0
0
0
0
0
0
0
0500h
0
0
0
0
0
0
0
0
0000h
0
0080h
0
0
0
0
0
0
IN1R_LP_
MODE
0
IN_VU
IN1R_
MUTE
0
0
0
0
0
0
0
0
0
0
0
0
0
0000h
IN1R_RATE [4:0]
0
0
0
0
0
0
0
0
0
0
0
0000h
0
IN2_
MODE
0
0
0
0080h
0
IN_VU
IN2L_
MUTE
IN1R_SRC [1:0]
0
IN2L_SRC [1:0]
0
MICD2_
STS
0
IN1_
MODE
IN2L_SIG_
DET_ENA
009Fh
MICD2_
VALID
0
0
DMIC2L_Control
MICD2_
ENA
0000h
0
0
1102h
MICD2_
DBTIME
IN4L_ENA IN4R_ENA IN3L_ENA IN3R_ENA IN2L_ENA IN2R_ENA IN1L_ENA IN1R_ENA
IN1L_HPF
ADC_Digital_Volume_2L
0
0
IN1L_Control
0
0
0
0
IN2L_HPF
MICD2_BIAS_SRC [3:0]
0
0
IN2L_Control
0010h
0000h
0
0
MICD2_GND_SEL [2:0]
JD3_ENA JD2_ENA JD1_ENA
0
IN1R_
SIG_DET_
ENA
0000h
0
0
0
DMIC1R_Control
MICD1_
STS
MICD2_SENSE_SEL [3:0]
0
0
0
009Fh
0000h
0
0
0
MICD1_
ENA
MICD1_ADCVAL [6:0]
0
0
IN1L_RATE [4:0]
MICD1_
DBTIME
MICD1_
VALID
0
0
IN1L_Rate_Control
1102h
0
HPF_Control
0
0
0
0
0
0
0
0
0
MICD1_BIAS_SRC [3:0]
0
0
0
0010h
0
0
IN1L_LP_
MODE
MICD1_GND_SEL [2:0]
MICD_
CLAMP1_
OVD
0
0
0
0
MICD_CLAMP2_MODE [2:0]
0
IN1L_SRC [1:0]
MICD1_SENSE_SEL [3:0]
0
0
IN1_DMIC_SUP [1:0]
0000h
0000h
MICD2_LVL [8:0]
0
0
HPD_
POLL (M)
MICD2_LVL_SEL [7:0]
0
ADC_Digital_Volume_1R
HPD_RATE [1:0]
0000h
0
Input_Volume_Ramp
IN1R_HPF
HPD_CLK_DIV [1:0]
0
MICD2_ADCVAL_DIFF [7:0]
Input_Rate
IN1R_Control
0000h
HPD_GND_SEL [2:0]
MICD1_LVL_SEL [7:0]
MICD2_RATE [3:0]
0
IN1L_SIG_
DET_ENA
0
0
MICD1_LVL [8:0]
0
Mic_Detect_2_Control_2
DMIC1L_Control
0
0
MICD1_ADCVAL_DIFF [7:0]
Default
00E6h
0
HPD_DACVAL [9:0]
Mic_Detect_1_Control_1
0
5
HPD_LVL [14:0]
Mic_Detect_1_Control_0 MICD1_
ADC_Digital_Volume_1L
6
0
HPD_FRC_SEL [3:0]
R675
(2A3h)
R676
(2A4h)
R677
(2A5h)
R683
(2ABh)
R690
(2B2h)
284
8
0
IN2_DMIC_SUP [1:0]
0
IN2L_LP_
MODE
0
0
IN2_OSR [2:0]
IN1R_PGA_VOL [6:0]
0180h
IN1R_VOL [7:0]
IN2L_PGA_VOL [6:0]
0180h
IN2L_VOL [7:0]
0
0
0
0
0
0
0
0
0500h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R795
(31Bh)
R796
(31Ch)
R797
(31Dh)
R798
(31Eh)
Name
IN2L_Rate_Control
R799
(31Fh)
R800
(320h)
R801
(321h)
R802
(322h)
R803
(323h)
R804
(324h)
R805
(325h)
R806
(326h)
IN2R_Rate_Control
R807
(327h)
R808
(328h)
R809
(329h)
R810
(32Ah)
R811
(32Bh)
R812
(32Ch)
R813
(32Dh)
R814
(32Eh)
IN3R_Rate_Control
R815
(32Fh)
R832
(340h)
R840
(348h)
R1024
(400h)
R1025
(401h)
R1030
(406h)
R1032
(408h)
R1033
(409h)
R1040
(410h)
R1041
(411h)
R1042
(412h)
R1043
(413h)
R1044
(414h)
R1045
(415h)
R1047
(417h)
R1048
(418h)
R1049
(419h)
R1050
(41Ah)
IN4R_Rate_Control
IN2R_Control
ADC_Digital_Volume_2R
DMIC2R_Control
IN3L_Control
ADC_Digital_Volume_3L
DMIC3L_Control
15
14
IN2R_HPF
0
IN2R_
SIG_DET_
ENA
0
ADC_Digital_Volume_3R
DMIC3R_Control
IN4L_Control
ADC_Digital_Volume_4L
DMIC4L_Control
ADC_Digital_Volume_4R
DMIC4R_Control
0
11
10
9
8
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
0
0
0
Default
0000h
0
0080h
0
0
0
0
0
0
IN2R_LP_
MODE
0
IN_VU
IN2R_
MUTE
0
0
0
0
0
0
0
0
0
0
0
0
0
0000h
IN2R_RATE [4:0]
0
0
0
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0
0
0
0000h
0
IN_VU
IN3L_
MUTE
0
0
IN3L_HPF
0
0
0
0
0
0
0
IN3L_SIG_
DET_ENA
0
0
0
0
IN3_DMIC_SUP [1:0]
IN3L_RATE [4:0]
IN3_OSR [2:0]
IN2R_PGA_VOL [6:0]
0180h
IN3L_VOL [7:0]
0
0
0
0
0
0
0
0
0500h
0
0
0
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0
0
0
0
0
IN_VU
IN3R_
MUTE
IN3R_
SIG_DET_
ENA
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0000h
IN3R_RATE [4:0]
0
0
0
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0
0
0
0000h
0
IN_VU
IN4L_
MUTE
IN4L_HPF
0
0
IN4_DMIC_SUP [1:0]
0
0
0
0
0
IN4L_SIG_
DET_ENA
0
0
0
0
IN4L_RATE [4:0]
IN4_OSR [2:0]
0180h
IN3R_VOL [7:0]
0180h
IN4L_VOL [7:0]
0
0
0
0
0
0
0
0
0500h
0
0
0
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0000h
IN4R_HPF
0
0
0
0
0
0
0
0
0
0
0
0
0
IN_VU
IN4R_
MUTE
IN4R_
SIG_DET_
ENA
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0
0
0
0000h
IN4R_RATE [4:0]
Signal_Detect_Globals
0
0
0
0
0
0
0
Dig_Mic_Pad_Ctrl
0
0
0
0
0
0
0
Output_Enables_1
EP_SEL
0
0
0
0
0
Output_Status_1
0
0
0
0
0
0
Raw_Output_Status_1
0
0
0
0
0
0
0
0
Output_Rate_1
OUT_RATE [4:0]
IN_SIG_DET_HOLD [3:0]
0001h
DMICDAT4DMICDAT3DMICDAT2DMICDAT1
_PD
_PD
_PD
_PD
0000h
IN_SIG_DET_THR [4:0]
0
0180h
IN4R_VOL [7:0]
0
0
0
0
OUT5L_ OUT5R_
ENA
ENA
0
0
HP3L_
ENA
HP3R_
ENA
HP2L_
ENA
HP2R_
ENA
HP1L_
ENA
HP1R_
ENA
0000h
OUT5L_ OUT5R_
ENA_STS ENA_STS
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
CP_DAC_ OUT_EXT_CLK_DIV
MODE
[1:0]
0
OUT_CLK_SRC [2:0]
0040h
OUT_VD_RAMP [2:0]
0
OUT_VI_RAMP [2:0]
0022h
Output_Volume_Ramp
0
0
0
0
0
0
0
0
0
Output_Path_Config_1L
0
OUT1L_
HIFI
0
OUT1_
MONO
0
0
0
0
1
DAC_Digital_Volume_1L
0
0
0
0
0
0
Output_Path_Config_1
0
0
0
0
0
0
Noise_Gate_Select_1L
0
0
0
0
Output_Path_Config_1R
0
OUT1R_
HIFI
0
0
0
0
DAC_Digital_Volume_1R
0
0
0
0
0
0
Noise_Gate_Select_1R
0
0
0
0
Output_Path_Config_2L
0
OUT2L_
HIFI
0
OUT2_
MONO
0
0
DAC_Digital_Volume_2L
0
0
0
0
0
0
Output_Path_Config_2
0
0
0
0
0
0
DS1162F1
0180h
IN2R_VOL [7:0]
IN3R_HPF
IN4L_Rate_Control
IN4R_Control
12
IN2R_SRC [1:0]
IN3L_Rate_Control
IN3R_Control
13
IN2L_RATE [4:0]
0
OUT3L_ OUT3R_ OUT2L_ OUT2R_ OUT1L_ OUT1R_
ENA_STS ENA_STS ENA_STS ENA_STS ENA_STS ENA_STS
0
OUT_VU OUT1L_
MUTE
0
0
0
0
0
0
0
0
0
0
0
0000h
HP1_GND_SEL [2:0]
0001h
OUT1L_NGATE_SRC [11:0]
0
0
1
0
0
OUT_VU OUT1R_
MUTE
0
0
0
0
0
0
1
0
0
OUT_VU OUT2L_
MUTE
0
0
0002h
0
0
0
0
0
0
0
0
0
0080h
0180h
OUT2L_VOL [7:0]
0
0080h
0180h
OUT1R_VOL [7:0]
OUT1R_NGATE_SRC [11:0]
0
0080h
0180h
OUT1L_VOL [7:0]
0
0000h
HP2_GND_SEL [2:0]
0002h
285
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1051
(41Bh)
R1052
(41Ch)
R1053
(41Dh)
R1055
(41Fh)
R1056
(420h)
R1057
(421h)
R1058
(422h)
R1059
(423h)
R1060
(424h)
R1061
(425h)
R1063
(427h)
R1072
(430h)
R1073
(431h)
R1075
(433h)
R1076
(434h)
R1077
(435h)
R1079
(437h)
R1102
(44Eh)
R1104
(450h)
Name
Noise_Gate_Select_2L
15
14
13
12
0
0
0
0
Output_Path_Config_2R
0
OUT2R_
HIFI
0
0
0
0
DAC_Digital_Volume_2R
0
0
0
0
0
0
Noise_Gate_Select_2R
0
0
0
0
Output_Path_Config_3L
0
OUT3L_
HIFI
0
OUT3_
MONO
0
0
DAC_Digital_Volume_3L
0
0
0
0
0
0
Output_Path_Config_3
0
0
0
0
0
0
Noise_Gate_Select_3L
0
0
0
0
Output_Path_Config_3R
0
OUT3R_
HIFI
0
0
0
0
DAC_Digital_Volume_3R
0
0
0
0
0
0
Noise_Gate_Select_3R
0
0
0
0
Output_Path_Config_5L
0
OUT5L_
HIFI
OUT5_
OSR
0
0
0
DAC_Digital_Volume_5L
0
0
0
0
0
0
Noise_Gate_Select_5L
0
0
0
0
Output_Path_Config_5R
0
OUT5R_
HIFI
0
0
0
0
DAC_Digital_Volume_5R
0
0
0
0
0
0
Noise_Gate_Select_5R
0
0
0
0
Filter_Control
0
0
0
0
0
0
0
0
0
0
DAC_AEC_Control_1
0
0
0
0
0
0
0
0
0
0
R1105
(451h)
DAC_AEC_Control_2
0
0
0
0
0
0
0
0
0
0
R1112
(458h)
R1168
(490h)
Noise_Gate_Control
0
0
0
0
0
0
0
0
0
0
PDM_SPK1_CTRL_1
0
0
SPK1R_
MUTE
SPK1L_
MUTE
0
0
0
R1169
(491h)
R1280
(500h)
PDM_SPK1_CTRL_2
0
0
0
0
0
0
0
SPK1_
MUTE_
ENDIAN
0
AIF1_BCLK_Ctrl
0
0
0
0
0
0
0
0
R1281
(501h)
R1282
(502h)
AIF1_Tx_Pin_Ctrl
0
0
0
0
0
0
0
0
AIF1_Rx_Pin_Ctrl
0
0
0
0
0
0
0
0
0
0
0
R1283
(503h)
R1284
(504h)
R1286
(506h)
R1287
(507h)
R1288
(508h)
R1289
(509h)
R1290
(50Ah)
R1291
(50Bh)
R1292
(50Ch)
R1293
(50Dh)
R1294
(50Eh)
AIF1_Rate_Ctrl
0
0
0
0
AIF1_TRI
0
0
0
0
0
286
11
10
9
8
7
6
5
4
3
2
1
0
Default
0004h
0
0
0
0
0
0080h
OUT2L_NGATE_SRC [11:0]
0
0
1
0
0
OUT_VU OUT2R_
MUTE
0180h
OUT2R_VOL [7:0]
0008h
OUT2R_NGATE_SRC [11:0]
0
0
1
0
0
0
OUT_VU OUT3L_
MUTE
0
0
0
0
0
0
0180h
OUT3L_VOL [7:0]
0
0
0
0
0
0002h
HP3_GND_SEL [2:0]
0010h
OUT3L_NGATE_SRC [11:0]
0
0
1
0
0
0
OUT_VU OUT3R_
MUTE
0
0
0
0
0
0
0
0
0020h
0
OUT_VU OUT5L_
MUTE
0
0
0
0
0
0
0
0
0100h
0
OUT_VU OUT5R_
MUTE
0
0
0
0
0200h
OUT5R_NGATE_SRC [11:0]
AIF1_RATE [4:0]
0
0000h
HIFI_FIR_TYPE [3:0]
AEC1_LOOPBACK_SRC [3:0]
AEC1_
AEC1_
ENA_STS LOOPBAC
K_ENA
AEC2_LOOPBACK_SRC [3:0]
AEC2_
AEC2_
ENA_STS LOOPBAC
K_ENA
NGATE_HOLD [1:0]
NGATE_THR [2:0]
NGATE_
ENA
0
AIF1_
AIF1_
BCLK_INV BCLK_
FRC
0
0
0
0
AIF1_
BCLK_
MSTR
AIF1TX_
DAT_TRI
0
0000h
0000h
0000h
0069h
SPK1_MUTE_SEQ [7:0]
0
0000h
0180h
OUT5R_VOL [7:0]
0
0000h
0180h
OUT5L_VOL [7:0]
OUT5L_NGATE_SRC [11:0]
0
0080h
0180h
OUT3R_VOL [7:0]
OUT3R_NGATE_SRC [11:0]
0
0080h
0
0
SPK1_
FMT
0000h
000Ch
AIF1_BCLK_FREQ [4:0]
0
0
0
0
0
0000h
0
0
AIF1_
LRCLK_
INV
0
AIF1_
LRCLK_
FRC
0
AIF1_
LRCLK_
MSTR
0
0000h
0
AIF1_
LRCLK_
MODE
0
0
0
0
0000h
AIF1_Format
0
0
0
AIF1_Rx_BCLK_Rate
0
0
0
AIF1_Frame_Ctrl_1
0
0
AIF1TX_WL [5:0]
AIF1TX_SLOT_LEN [7:0]
1818h
AIF1_Frame_Ctrl_2
0
0
AIF1RX_WL [5:0]
AIF1RX_SLOT_LEN [7:0]
1818h
AIF1_Frame_Ctrl_3
0
0
0
0
0
0
0
0
0
0
AIF1TX1_SLOT [5:0]
0000h
AIF1_Frame_Ctrl_4
0
0
0
0
0
0
0
0
0
0
AIF1TX2_SLOT [5:0]
0001h
AIF1_Frame_Ctrl_5
0
0
0
0
0
0
0
0
0
0
AIF1TX3_SLOT [5:0]
0002h
AIF1_Frame_Ctrl_6
0
0
0
0
0
0
0
0
0
0
AIF1TX4_SLOT [5:0]
0003h
AIF1_Frame_Ctrl_7
0
0
0
0
0
0
0
0
0
0
AIF1TX5_SLOT [5:0]
0004h
AIF1_Frame_Ctrl_8
0
0
0
0
0
0
0
0
0
0
AIF1TX6_SLOT [5:0]
0005h
0
0
AIF1_FMT [2:0]
0000h
0040h
AIF1_BCPF [12:0]
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1295
(50Fh)
R1296
(510h)
R1297
(511h)
R1298
(512h)
R1299
(513h)
R1300
(514h)
R1301
(515h)
R1302
(516h)
R1303
(517h)
R1304
(518h)
R1305
(519h)
R1306
(51Ah)
R1344
(540h)
Name
AIF1_Frame_Ctrl_9
15
14
13
12
11
10
9
8
7
6
0
0
0
0
0
0
0
0
0
0
AIF1TX7_SLOT [5:0]
Default
0006h
AIF1_Frame_Ctrl_10
0
0
0
0
0
0
0
0
0
0
AIF1TX8_SLOT [5:0]
0007h
AIF1_Frame_Ctrl_11
0
0
0
0
0
0
0
0
0
0
AIF1RX1_SLOT [5:0]
0000h
AIF1_Frame_Ctrl_12
0
0
0
0
0
0
0
0
0
0
AIF1RX2_SLOT [5:0]
0001h
AIF1_Frame_Ctrl_13
0
0
0
0
0
0
0
0
0
0
AIF1RX3_SLOT [5:0]
0002h
AIF1_Frame_Ctrl_14
0
0
0
0
0
0
0
0
0
0
AIF1RX4_SLOT [5:0]
0003h
AIF1_Frame_Ctrl_15
0
0
0
0
0
0
0
0
0
0
AIF1RX5_SLOT [5:0]
0004h
AIF1_Frame_Ctrl_16
0
0
0
0
0
0
0
0
0
0
AIF1RX6_SLOT [5:0]
0005h
AIF1_Frame_Ctrl_17
0
0
0
0
0
0
0
0
0
0
AIF1RX7_SLOT [5:0]
0006h
AIF1_Frame_Ctrl_18
0
0
0
0
0
0
0
0
0
0
AIF1RX8_SLOT [5:0]
0007h
AIF1_Tx_Enables
0
0
0
0
0
0
0
0
AIF1TX8_ AIF1TX7_ AIF1TX6_ AIF1TX5_ AIF1TX4_ AIF1TX3_ AIF1TX2_ AIF1TX1_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0000h
AIF1_Rx_Enables
0
0
0
0
0
0
0
0
AIF1RX8_ AIF1RX7_ AIF1RX6_ AIF1RX5_ AIF1RX4_ AIF1RX3_ AIF1RX2_ AIF1RX1_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0000h
AIF2_BCLK_Ctrl
0
0
0
0
0
0
0
0
000Ch
R1345
(541h)
R1346
(542h)
AIF2_Tx_Pin_Ctrl
0
0
0
0
0
0
0
0
AIF2_
AIF2_
BCLK_INV BCLK_
FRC
0
0
AIF2_Rx_Pin_Ctrl
0
0
0
0
0
0
0
0
0
0
0
R1347
(543h)
R1348
(544h)
R1350
(546h)
R1351
(547h)
R1352
(548h)
R1353
(549h)
R1354
(54Ah)
R1355
(54Bh)
R1356
(54Ch)
R1357
(54Dh)
R1358
(54Eh)
R1359
(54Fh)
R1360
(550h)
R1361
(551h)
R1362
(552h)
R1363
(553h)
R1364
(554h)
R1365
(555h)
R1366
(556h)
R1367
(557h)
R1368
(558h)
R1369
(559h)
R1370
(55Ah)
AIF2_Rate_Ctrl
0
0
0
0
AIF2_TRI
0
0
0
0
0
AIF2_RATE [4:0]
5
4
AIF2_
BCLK_
MSTR
AIF2TX_
DAT_TRI
3
2
1
0
AIF2_BCLK_FREQ [4:0]
0
0
0
0
0
0000h
0
0
AIF2_
LRCLK_
INV
0
AIF2_
LRCLK_
FRC
0
AIF2_
LRCLK_
MSTR
0
0000h
0
AIF2_
LRCLK_
MODE
0
0
0
0
0000h
AIF2_Format
0
0
0
AIF2_Rx_BCLK_Rate
0
0
0
AIF2_Frame_Ctrl_1
0
0
AIF2TX_WL [5:0]
AIF2TX_SLOT_LEN [7:0]
1818h
AIF2_Frame_Ctrl_2
0
0
AIF2RX_WL [5:0]
AIF2RX_SLOT_LEN [7:0]
1818h
AIF2_Frame_Ctrl_3
0
0
0
0
0
0
0
0
0
0
AIF2TX1_SLOT [5:0]
0000h
AIF2_Frame_Ctrl_4
0
0
0
0
0
0
0
0
0
0
AIF2TX2_SLOT [5:0]
0001h
AIF2_Frame_Ctrl_5
0
0
0
0
0
0
0
0
0
0
AIF2TX3_SLOT [5:0]
0002h
AIF2_Frame_Ctrl_6
0
0
0
0
0
0
0
0
0
0
AIF2TX4_SLOT [5:0]
0003h
AIF2_Frame_Ctrl_7
0
0
0
0
0
0
0
0
0
0
AIF2TX5_SLOT [5:0]
0004h
AIF2_Frame_Ctrl_8
0
0
0
0
0
0
0
0
0
0
AIF2TX6_SLOT [5:0]
0005h
AIF2_Frame_Ctrl_9
0
0
0
0
0
0
0
0
0
0
AIF2TX7_SLOT [5:0]
0006h
AIF2_Frame_Ctrl_10
0
0
0
0
0
0
0
0
0
0
AIF2TX8_SLOT [5:0]
0007h
AIF2_Frame_Ctrl_11
0
0
0
0
0
0
0
0
0
0
AIF2RX1_SLOT [5:0]
0000h
AIF2_Frame_Ctrl_12
0
0
0
0
0
0
0
0
0
0
AIF2RX2_SLOT [5:0]
0001h
AIF2_Frame_Ctrl_13
0
0
0
0
0
0
0
0
0
0
AIF2RX3_SLOT [5:0]
0002h
AIF2_Frame_Ctrl_14
0
0
0
0
0
0
0
0
0
0
AIF2RX4_SLOT [5:0]
0003h
AIF2_Frame_Ctrl_15
0
0
0
0
0
0
0
0
0
0
AIF2RX5_SLOT [5:0]
0004h
AIF2_Frame_Ctrl_16
0
0
0
0
0
0
0
0
0
0
AIF2RX6_SLOT [5:0]
0005h
AIF2_Frame_Ctrl_17
0
0
0
0
0
0
0
0
0
0
AIF2RX7_SLOT [5:0]
0006h
AIF2_Frame_Ctrl_18
0
0
0
0
0
0
0
0
0
0
AIF2RX8_SLOT [5:0]
0007h
AIF2_Tx_Enables
0
0
0
0
0
0
0
0
AIF2TX8_ AIF2TX7_ AIF2TX6_ AIF2TX5_ AIF2TX4_ AIF2TX3_ AIF2TX2_ AIF2TX1_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0000h
AIF2_Rx_Enables
0
0
0
0
0
0
0
0
AIF2RX8_ AIF2RX7_ AIF2RX6_ AIF2RX5_ AIF2RX4_ AIF2RX3_ AIF2RX2_ AIF2RX1_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0000h
DS1162F1
0
0
AIF2_FMT [2:0]
0000h
0040h
AIF2_BCPF [12:0]
287
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
Name
R1408 AIF3_BCLK_Ctrl
(580h)
15
14
13
12
11
10
9
8
0
0
0
0
0
0
0
0
7
6
AIF3_
AIF3_
BCLK_INV BCLK_
FRC
0
0
5
R1409
(581h)
R1410
(582h)
AIF3_Tx_Pin_Ctrl
0
0
0
0
0
0
0
0
AIF3_Rx_Pin_Ctrl
0
0
0
0
0
0
0
0
0
0
0
R1411
(583h)
R1412
(584h)
R1414
(586h)
R1415
(587h)
R1416
(588h)
R1417
(589h)
R1418
(58Ah)
R1419
(58Bh)
R1420
(58Ch)
R1421
(58Dh)
R1422
(58Eh)
R1423
(58Fh)
R1424
(590h)
R1425
(591h)
R1426
(592h)
R1427
(593h)
R1428
(594h)
R1429
(595h)
R1430
(596h)
R1431
(597h)
R1432
(598h)
R1433
(599h)
R1434
(59Ah)
R1474
(5C2h)
R1475
(5C3h)
R1476
(5C4h)
R1477
(5C5h)
R1490
(5D2h)
R1491
(5D3h)
R1492
(5D4h)
R1493
(5D5h)
R1494
(5D6h)
R1495
(5D7h)
R1496
(5D8h)
R1497
(5D9h)
AIF3_Rate_Ctrl
0
0
0
0
AIF3_TRI
0
0
0
0
0
288
AIF3_RATE [4:0]
4
AIF3_
BCLK_
MSTR
AIF3TX_
DAT_TRI
3
2
1
0
Default
000Ch
AIF3_BCLK_FREQ [4:0]
0
0
0
0
0
0000h
0
0
AIF3_
LRCLK_
INV
0
AIF3_
LRCLK_
FRC
0
AIF3_
LRCLK_
MSTR
0
0000h
0
AIF3_
LRCLK_
MODE
0
0
0
0
0000h
AIF3_Format
0
0
0
AIF3_Rx_BCLK_Rate
0
0
0
AIF3_Frame_Ctrl_1
0
0
AIF3TX_WL [5:0]
AIF3TX_SLOT_LEN [7:0]
1818h
AIF3_Frame_Ctrl_2
0
0
AIF3RX_WL [5:0]
AIF3RX_SLOT_LEN [7:0]
1818h
AIF3_Frame_Ctrl_3
0
0
0
0
0
0
0
0
0
0
AIF3TX1_SLOT [5:0]
0000h
AIF3_Frame_Ctrl_4
0
0
0
0
0
0
0
0
0
0
AIF3TX2_SLOT [5:0]
0001h
AIF3_Frame_Ctrl_5
0
0
0
0
0
0
0
0
0
0
AIF3TX3_SLOT [5:0]
0002h
AIF3_Frame_Ctrl_6
0
0
0
0
0
0
0
0
0
0
AIF3TX4_SLOT [5:0]
0003h
AIF3_Frame_Ctrl_7
0
0
0
0
0
0
0
0
0
0
AIF3TX5_SLOT [5:0]
0004h
AIF3_Frame_Ctrl_8
0
0
0
0
0
0
0
0
0
0
AIF3TX6_SLOT [5:0]
0005h
AIF3_Frame_Ctrl_9
0
0
0
0
0
0
0
0
0
0
AIF3TX7_SLOT [5:0]
0006h
AIF3_Frame_Ctrl_10
0
0
0
0
0
0
0
0
0
0
AIF3TX8_SLOT [5:0]
0007h
AIF3_Frame_Ctrl_11
0
0
0
0
0
0
0
0
0
0
AIF3RX1_SLOT [5:0]
0000h
AIF3_Frame_Ctrl_12
0
0
0
0
0
0
0
0
0
0
AIF3RX2_SLOT [5:0]
0001h
AIF3_Frame_Ctrl_13
0
0
0
0
0
0
0
0
0
0
AIF3RX3_SLOT [5:0]
0002h
AIF3_Frame_Ctrl_14
0
0
0
0
0
0
0
0
0
0
AIF3RX4_SLOT [5:0]
0003h
AIF3_Frame_Ctrl_15
0
0
0
0
0
0
0
0
0
0
AIF3RX5_SLOT [5:0]
0004h
AIF3_Frame_Ctrl_16
0
0
0
0
0
0
0
0
0
0
AIF3RX6_SLOT [5:0]
0005h
AIF3_Frame_Ctrl_17
0
0
0
0
0
0
0
0
0
0
AIF3RX7_SLOT [5:0]
0006h
AIF3_Frame_Ctrl_18
0
0
0
0
0
0
0
0
0
0
AIF3RX8_SLOT [5:0]
0007h
AIF3_Tx_Enables
0
0
0
0
0
0
0
0
AIF3TX8_ AIF3TX7_ AIF3TX6_ AIF3TX5_ AIF3TX4_ AIF3TX3_ AIF3TX2_ AIF3TX1_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0000h
AIF3_Rx_Enables
0
0
0
0
0
0
0
0
AIF3RX8_ AIF3RX7_ AIF3RX6_ AIF3RX5_ AIF3RX4_ AIF3RX3_ AIF3RX2_ AIF3RX1_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0000h
SPD1_TX_Control
0
0
SPD1_
VAL2
SPD1_
VAL1
0
0
0
SPD1_TX_Channel_
Status_1
SPD1_TX_Channel_
Status_2
SPD1_TX_Channel_
Status_3
SLIMbus_RX_Ports0
0
0
SPD1_FREQ [3:0]
0
0
0040h
AIF3_BCPF [12:0]
SPD1_CATCODE [7:0]
0
0000h
AIF3_FMT [2:0]
SPD1_CHSTMODE
[1:0]
SPD1_CHNUM2 [3:0]
0
SPD1_RATE [4:0]
SPD1_ORGSAMP [3:0]
SPD1_PREEMPH [2:0]
SPD1_CHNUM1 [3:0]
SPD1_TXWL [2:0]
SPD1_
ENA
0000h
SPD1_
SPD1_
SPD1_
NOCOPY NOAUDIO PRO
0000h
SPD1_SRCNUM [3:0]
0001h
0
0
0
SPD1_ SPD1_CS31_30 [1:0] SPD1_CLKACU [1:0]
MAXWL
0000h
SLIMRX2_PORT_ADDR [7:0]
SLIMRX1_PORT_ADDR [7:0]
0100h
SLIMbus_RX_Ports1
SLIMRX4_PORT_ADDR [7:0]
SLIMRX3_PORT_ADDR [7:0]
0302h
SLIMbus_RX_Ports2
SLIMRX6_PORT_ADDR [7:0]
SLIMRX5_PORT_ADDR [7:0]
0504h
SLIMbus_RX_Ports3
SLIMRX8_PORT_ADDR [7:0]
SLIMRX7_PORT_ADDR [7:0]
0706h
SLIMbus_TX_Ports0
SLIMTX2_PORT_ADDR [7:0]
SLIMTX1_PORT_ADDR [7:0]
0908h
SLIMbus_TX_Ports1
SLIMTX4_PORT_ADDR [7:0]
SLIMTX3_PORT_ADDR [7:0]
0B0Ah
SLIMbus_TX_Ports2
SLIMTX6_PORT_ADDR [7:0]
SLIMTX5_PORT_ADDR [7:0]
0D0Ch
SLIMbus_TX_Ports3
SLIMTX8_PORT_ADDR [7:0]
SLIMTX7_PORT_ADDR [7:0]
0F0Eh
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1507
(5E3h)
R1509
(5E5h)
R1510
(5E6h)
R1511
(5E7h)
R1512
(5E8h)
R1513
(5E9h)
R1514
(5EAh)
R1515
(5EBh)
R1516
(5ECh)
R1520
(5F0h)
Name
SLIMbus_Framer_Ref_
Gear
SLIMbus_Rates_1
15
14
13
12
11
10
9
8
7
6
5
4
0
0
0
0
0
0
0
0
0
0
0
SLIMCLK_
SRC
Slimbus_Pad_Ctrl
0
0
0
0
R1525
(5F5h)
R1526
(5F6h)
R1527
(5F7h)
SLIMbus_RX_Channel_
Enable
SLIMbus_TX_Channel_
Enable
SLIMbus_RX_Port_
Status
0
0
0
0
0
0
R1528
(5F8h)
SLIMbus_TX_Port_
Status
R1600
(640h)
R1601
(641h)
R1602
(642h)
R1603
(643h)
R1604
(644h)
R1605
(645h)
R1606
(646h)
R1607
(647h)
R1608
(648h)
R1609
(649h)
R1610
(64Ah)
R1611
(64Bh)
R1612
(64Ch)
R1613
(64Dh)
R1614
(64Eh)
R1615
(64Fh)
R1664
(680h)
R1665
(681h)
R1666
(682h)
R1667
(683h)
R1668
(684h)
R1669
(685h)
R1670
(686h)
R1671
(687h)
PWM1MIX_Input_1_
Source
PWM1MIX_Input_1_
Volume
PWM1MIX_Input_2_
Source
PWM1MIX_Input_2_
Volume
PWM1MIX_Input_3_
Source
PWM1MIX_Input_3_
Volume
PWM1MIX_Input_4_
Source
PWM1MIX_Input_4_
Volume
PWM2MIX_Input_1_
Source
PWM2MIX_Input_1_
Volume
PWM2MIX_Input_2_
Source
PWM2MIX_Input_2_
Volume
PWM2MIX_Input_3_
Source
PWM2MIX_Input_3_
Volume
PWM2MIX_Input_4_
Source
PWM2MIX_Input_4_
Volume
OUT1LMIX_Input_1_
Source
OUT1LMIX_Input_1_
Volume
OUT1LMIX_Input_2_
Source
OUT1LMIX_Input_2_
Volume
OUT1LMIX_Input_3_
Source
OUT1LMIX_Input_3_
Volume
OUT1LMIX_Input_4_
Source
OUT1LMIX_Input_4_
Volume
SLIMRX2_RATE [4:0]
0
0
0
SLIMRX1_RATE [4:0]
0
SLIMbus_Rates_2
SLIMRX4_RATE [4:0]
0
0
0
SLIMRX3_RATE [4:0]
SLIMbus_Rates_3
SLIMRX6_RATE [4:0]
0
0
0
SLIMbus_Rates_4
SLIMRX8_RATE [4:0]
0
0
SLIMbus_Rates_5
SLIMTX2_RATE [4:0]
0
SLIMbus_Rates_6
SLIMTX4_RATE [4:0]
SLIMbus_Rates_7
SLIMbus_Rates_8
DS1162F1
3
2
1
0
Default
0000h
0
0
0000h
0
0
0
0000h
SLIMRX5_RATE [4:0]
0
0
0
0000h
0
SLIMRX7_RATE [4:0]
0
0
0
0000h
0
0
SLIMTX1_RATE [4:0]
0
0
0
0000h
0
0
0
SLIMTX3_RATE [4:0]
0
0
0
0000h
SLIMTX6_RATE [4:0]
0
0
0
SLIMTX5_RATE [4:0]
0
0
0
0000h
SLIMTX8_RATE [4:0]
0
0
0
SLIMTX7_RATE [4:0]
0
0
0
0000h
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PWM1MIX
_STS
0
0
0
0
0
0
PWM1MIX
_STS
0
0
SLIMCLK_REF_GEAR [3:0]
SLIMDAT2 SLIMDAT1 SLIMCLK_
_DRV_ _DRV_ DRV_STR
STR
STR
SLIMRX8_ SLIMRX7_ SLIMRX6_ SLIMRX5_ SLIMRX4_ SLIMRX3_ SLIMRX2_ SLIMRX1_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0007h
0
SLIMTX8_ SLIMTX7_ SLIMTX6_ SLIMTX5_ SLIMTX4_ SLIMTX3_ SLIMTX2_ SLIMTX1_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0000h
0
0
0000h
0
0
0
0
0
0
0
SLIMRX8_ SLIMRX7_ SLIMRX6_ SLIMRX5_ SLIMRX4_ SLIMRX3_ SLIMRX2_ SLIMRX1_
PORT_ PORT_ PORT_ PORT_ PORT_ PORT_ PORT_ PORT_
STS
STS
STS
STS
STS
STS
STS
STS
SLIMTX8_ SLIMTX7_ SLIMTX6_ SLIMTX5_ SLIMTX4_ SLIMTX3_ SLIMTX2_ SLIMTX1_
PORT_ PORT_ PORT_ PORT_ PORT_ PORT_ PORT_ PORT_
STS
STS
STS
STS
STS
STS
STS
STS
PWM1MIX_SRC1 [7:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PWM1MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PWM1MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PWM2MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PWM2MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PWM2MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PWM2MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PWM1MIX_VOL1 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0080h
0080h
0080h
0000h
OUT1LMIX_SRC4 [7:0]
OUT1LMIX_VOL4 [6:0]
0080h
0000h
OUT1LMIX_SRC3 [7:0]
OUT1LMIX_VOL3 [6:0]
0080h
0000h
OUT1LMIX_SRC2 [7:0]
OUT1LMIX_VOL2 [6:0]
0080h
0000h
OUT1LMIX_SRC1 [7:0]
OUT1LMIX_VOL1 [6:0]
0080h
0000h
PWM2MIX_SRC4 [7:0]
PWM2MIX_VOL4 [6:0]
0080h
0000h
PWM2MIX_SRC3 [7:0]
PWM2MIX_VOL3 [6:0]
0080h
0000h
PWM2MIX_SRC2 [7:0]
PWM2MIX_VOL2 [6:0]
0080h
0000h
PWM2MIX_SRC1 [7:0]
PWM2MIX_VOL1 [6:0]
0080h
0000h
PWM1MIX_SRC4 [7:0]
PWM1MIX_VOL4 [6:0]
0000h
0000h
PWM1MIX_SRC3 [7:0]
PWM1MIX_VOL3 [6:0]
0000h
0000h
PWM1MIX_SRC2 [7:0]
PWM1MIX_VOL2 [6:0]
0000h
0
0080h
289
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1672
(688h)
R1673
(689h)
R1674
(68Ah)
R1675
(68Bh)
R1676
(68Ch)
R1677
(68Dh)
R1678
(68Eh)
R1679
(68Fh)
R1680
(690h)
R1681
(691h)
R1682
(692h)
R1683
(693h)
R1684
(694h)
R1685
(695h)
R1686
(696h)
R1687
(697h)
R1688
(698h)
R1689
(699h)
R1690
(69Ah)
R1691
(69Bh)
R1692
(69Ch)
R1693
(69Dh)
R1694
(69Eh)
R1695
(69Fh)
R1696
(6A0h)
R1697
(6A1h)
R1698
(6A2h)
R1699
(6A3h)
R1700
(6A4h)
R1701
(6A5h)
R1702
(6A6h)
R1703
(6A7h)
R1704
(6A8h)
R1705
(6A9h)
R1706
(6AAh)
R1707
(6ABh)
R1708
(6ACh)
R1709
(6ADh)
290
Name
OUT1RMIX_Input_1_
Source
OUT1RMIX_Input_1_
Volume
OUT1RMIX_Input_2_
Source
OUT1RMIX_Input_2_
Volume
OUT1RMIX_Input_3_
Source
OUT1RMIX_Input_3_
Volume
OUT1RMIX_Input_4_
Source
OUT1RMIX_Input_4_
Volume
OUT2LMIX_Input_1_
Source
OUT2LMIX_Input_1_
Volume
OUT2LMIX_Input_2_
Source
OUT2LMIX_Input_2_
Volume
OUT2LMIX_Input_3_
Source
OUT2LMIX_Input_3_
Volume
OUT2LMIX_Input_4_
Source
OUT2LMIX_Input_4_
Volume
OUT2RMIX_Input_1_
Source
OUT2RMIX_Input_1_
Volume
OUT2RMIX_Input_2_
Source
OUT2RMIX_Input_2_
Volume
OUT2RMIX_Input_3_
Source
OUT2RMIX_Input_3_
Volume
OUT2RMIX_Input_4_
Source
OUT2RMIX_Input_4_
Volume
OUT3LMIX_Input_1_
Source
OUT3LMIX_Input_1_
Volume
OUT3LMIX_Input_2_
Source
OUT3LMIX_Input_2_
Volume
OUT3LMIX_Input_3_
Source
OUT3LMIX_Input_3_
Volume
OUT3LMIX_Input_4_
Source
OUT3LMIX_Input_4_
Volume
OUT3RMIX_Input_1_
Source
OUT3RMIX_Input_1_
Volume
OUT3RMIX_Input_2_
Source
OUT3RMIX_Input_2_
Volume
OUT3RMIX_Input_3_
Source
OUT3RMIX_Input_3_
Volume
15
14
13
12
11
10
9
8
OUT1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT2LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT2LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT2LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT2LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT2RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT2RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT2RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT2RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT3LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT3LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT3LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT3LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT3RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT3RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT3RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
OUT1RMIX_SRC1 [7:0]
OUT1RMIX_VOL1 [6:0]
0000h
OUT1RMIX_SRC2 [7:0]
OUT1RMIX_VOL2 [6:0]
0
0000h
OUT1RMIX_SRC3 [7:0]
OUT1RMIX_VOL3 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
OUT3RMIX_SRC3 [7:0]
OUT3RMIX_VOL3 [6:0]
0080h
0000h
OUT3RMIX_SRC2 [7:0]
OUT3RMIX_VOL2 [6:0]
0080h
0000h
OUT3RMIX_SRC1 [7:0]
OUT3RMIX_VOL1 [6:0]
0080h
0000h
OUT3LMIX_SRC4 [7:0]
OUT3LMIX_VOL4 [6:0]
0080h
0000h
OUT3LMIX_SRC3 [7:0]
OUT3LMIX_VOL3 [6:0]
0080h
0000h
OUT3LMIX_SRC2 [7:0]
OUT3LMIX_VOL2 [6:0]
0080h
0000h
OUT3LMIX_SRC1 [7:0]
OUT3LMIX_VOL1 [6:0]
0080h
0000h
OUT2RMIX_SRC4 [7:0]
OUT2RMIX_VOL4 [6:0]
0080h
0000h
OUT2RMIX_SRC3 [7:0]
OUT2RMIX_VOL3 [6:0]
0080h
0000h
OUT2RMIX_SRC2 [7:0]
OUT2RMIX_VOL2 [6:0]
0080h
0000h
OUT2RMIX_SRC1 [7:0]
OUT2RMIX_VOL1 [6:0]
0080h
0000h
OUT2LMIX_SRC4 [7:0]
OUT2LMIX_VOL4 [6:0]
0080h
0000h
OUT2LMIX_SRC3 [7:0]
OUT2LMIX_VOL3 [6:0]
0080h
0000h
OUT2LMIX_SRC2 [7:0]
OUT2LMIX_VOL2 [6:0]
0080h
0000h
OUT2LMIX_SRC1 [7:0]
OUT2LMIX_VOL1 [6:0]
0080h
0000h
OUT1RMIX_SRC4 [7:0]
OUT1RMIX_VOL4 [6:0]
0080h
0
0080h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1710
(6AEh)
R1711
(6AFh)
R1728
(6C0h)
R1729
(6C1h)
R1730
(6C2h)
R1731
(6C3h)
R1732
(6C4h)
R1733
(6C5h)
R1734
(6C6h)
R1735
(6C7h)
R1736
(6C8h)
R1737
(6C9h)
R1738
(6CAh)
R1739
(6CBh)
R1740
(6CCh)
R1741
(6CDh)
R1742
(6CEh)
R1743
(6CFh)
R1792
(700h)
R1793
(701h)
R1794
(702h)
R1795
(703h)
R1796
(704h)
R1797
(705h)
R1798
(706h)
R1799
(707h)
R1800
(708h)
R1801
(709h)
R1802
(70Ah)
R1803
(70Bh)
R1804
(70Ch)
R1805
(70Dh)
R1806
(70Eh)
R1807
(70Fh)
R1808
(710h)
R1809
(711h)
R1810
(712h)
R1811
(713h)
Name
OUT3RMIX_Input_4_
Source
OUT3RMIX_Input_4_
Volume
OUT5LMIX_Input_1_
Source
OUT5LMIX_Input_1_
Volume
OUT5LMIX_Input_2_
Source
OUT5LMIX_Input_2_
Volume
OUT5LMIX_Input_3_
Source
OUT5LMIX_Input_3_
Volume
OUT5LMIX_Input_4_
Source
OUT5LMIX_Input_4_
Volume
OUT5RMIX_Input_1_
Source
OUT5RMIX_Input_1_
Volume
OUT5RMIX_Input_2_
Source
OUT5RMIX_Input_2_
Volume
OUT5RMIX_Input_3_
Source
OUT5RMIX_Input_3_
Volume
OUT5RMIX_Input_4_
Source
OUT5RMIX_Input_4_
Volume
AIF1TX1MIX_Input_1_
Source
AIF1TX1MIX_Input_1_
Volume
AIF1TX1MIX_Input_2_
Source
AIF1TX1MIX_Input_2_
Volume
AIF1TX1MIX_Input_3_
Source
AIF1TX1MIX_Input_3_
Volume
AIF1TX1MIX_Input_4_
Source
AIF1TX1MIX_Input_4_
Volume
AIF1TX2MIX_Input_1_
Source
AIF1TX2MIX_Input_1_
Volume
AIF1TX2MIX_Input_2_
Source
AIF1TX2MIX_Input_2_
Volume
AIF1TX2MIX_Input_3_
Source
AIF1TX2MIX_Input_3_
Volume
AIF1TX2MIX_Input_4_
Source
AIF1TX2MIX_Input_4_
Volume
AIF1TX3MIX_Input_1_
Source
AIF1TX3MIX_Input_1_
Volume
AIF1TX3MIX_Input_2_
Source
AIF1TX3MIX_Input_2_
Volume
DS1162F1
15
14
13
12
11
10
9
8
OUT3RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT5LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT5LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT5LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT5LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT5RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT5RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT5RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
OUT5RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
OUT3RMIX_SRC4 [7:0]
OUT3RMIX_VOL4 [6:0]
0000h
OUT5LMIX_SRC1 [7:0]
OUT5LMIX_VOL1 [6:0]
0
0000h
OUT5LMIX_SRC2 [7:0]
OUT5LMIX_VOL2 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
AIF1TX3MIX_SRC2 [7:0]
AIF1TX3MIX_VOL2 [6:0]
0080h
0000h
AIF1TX3MIX_SRC1 [7:0]
AIF1TX3MIX_VOL1 [6:0]
0080h
0000h
AIF1TX2MIX_SRC4 [7:0]
AIF1TX2MIX_VOL4 [6:0]
0080h
0000h
AIF1TX2MIX_SRC3 [7:0]
AIF1TX2MIX_VOL3 [6:0]
0080h
0000h
AIF1TX2MIX_SRC2 [7:0]
AIF1TX2MIX_VOL2 [6:0]
0080h
0000h
AIF1TX2MIX_SRC1 [7:0]
AIF1TX2MIX_VOL1 [6:0]
0080h
0000h
AIF1TX1MIX_SRC4 [7:0]
AIF1TX1MIX_VOL4 [6:0]
0080h
0000h
AIF1TX1MIX_SRC3 [7:0]
AIF1TX1MIX_VOL3 [6:0]
0080h
0000h
AIF1TX1MIX_SRC2 [7:0]
AIF1TX1MIX_VOL2 [6:0]
0080h
0000h
AIF1TX1MIX_SRC1 [7:0]
AIF1TX1MIX_VOL1 [6:0]
0080h
0000h
OUT5RMIX_SRC4 [7:0]
OUT5RMIX_VOL4 [6:0]
0080h
0000h
OUT5RMIX_SRC3 [7:0]
OUT5RMIX_VOL3 [6:0]
0080h
0000h
OUT5RMIX_SRC2 [7:0]
OUT5RMIX_VOL2 [6:0]
0080h
0000h
OUT5RMIX_SRC1 [7:0]
OUT5RMIX_VOL1 [6:0]
0080h
0000h
OUT5LMIX_SRC4 [7:0]
OUT5LMIX_VOL4 [6:0]
0080h
0000h
OUT5LMIX_SRC3 [7:0]
OUT5LMIX_VOL3 [6:0]
0080h
0
0080h
291
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1812
(714h)
R1813
(715h)
R1814
(716h)
R1815
(717h)
R1816
(718h)
R1817
(719h)
R1818
(71Ah)
R1819
(71Bh)
R1820
(71Ch)
R1821
(71Dh)
R1822
(71Eh)
R1823
(71Fh)
R1824
(720h)
R1825
(721h)
R1826
(722h)
R1827
(723h)
R1828
(724h)
R1829
(725h)
R1830
(726h)
R1831
(727h)
R1832
(728h)
R1833
(729h)
R1834
(72Ah)
R1835
(72Bh)
R1836
(72Ch)
R1837
(72Dh)
R1838
(72Eh)
R1839
(72Fh)
R1840
(730h)
R1841
(731h)
R1842
(732h)
R1843
(733h)
R1844
(734h)
R1845
(735h)
R1846
(736h)
R1847
(737h)
R1848
(738h)
R1849
(739h)
292
Name
AIF1TX3MIX_Input_3_
Source
AIF1TX3MIX_Input_3_
Volume
AIF1TX3MIX_Input_4_
Source
AIF1TX3MIX_Input_4_
Volume
AIF1TX4MIX_Input_1_
Source
AIF1TX4MIX_Input_1_
Volume
AIF1TX4MIX_Input_2_
Source
AIF1TX4MIX_Input_2_
Volume
AIF1TX4MIX_Input_3_
Source
AIF1TX4MIX_Input_3_
Volume
AIF1TX4MIX_Input_4_
Source
AIF1TX4MIX_Input_4_
Volume
AIF1TX5MIX_Input_1_
Source
AIF1TX5MIX_Input_1_
Volume
AIF1TX5MIX_Input_2_
Source
AIF1TX5MIX_Input_2_
Volume
AIF1TX5MIX_Input_3_
Source
AIF1TX5MIX_Input_3_
Volume
AIF1TX5MIX_Input_4_
Source
AIF1TX5MIX_Input_4_
Volume
AIF1TX6MIX_Input_1_
Source
AIF1TX6MIX_Input_1_
Volume
AIF1TX6MIX_Input_2_
Source
AIF1TX6MIX_Input_2_
Volume
AIF1TX6MIX_Input_3_
Source
AIF1TX6MIX_Input_3_
Volume
AIF1TX6MIX_Input_4_
Source
AIF1TX6MIX_Input_4_
Volume
AIF1TX7MIX_Input_1_
Source
AIF1TX7MIX_Input_1_
Volume
AIF1TX7MIX_Input_2_
Source
AIF1TX7MIX_Input_2_
Volume
AIF1TX7MIX_Input_3_
Source
AIF1TX7MIX_Input_3_
Volume
AIF1TX7MIX_Input_4_
Source
AIF1TX7MIX_Input_4_
Volume
AIF1TX8MIX_Input_1_
Source
AIF1TX8MIX_Input_1_
Volume
15
14
13
12
11
10
9
8
AIF1TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
AIF1TX3MIX_SRC3 [7:0]
AIF1TX3MIX_VOL3 [6:0]
0000h
AIF1TX3MIX_SRC4 [7:0]
AIF1TX3MIX_VOL4 [6:0]
0
0000h
AIF1TX4MIX_SRC1 [7:0]
AIF1TX4MIX_VOL1 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
AIF1TX8MIX_SRC1 [7:0]
AIF1TX8MIX_VOL1 [6:0]
0080h
0000h
AIF1TX7MIX_SRC4 [7:0]
AIF1TX7MIX_VOL4 [6:0]
0080h
0000h
AIF1TX7MIX_SRC3 [7:0]
AIF1TX7MIX_VOL3 [6:0]
0080h
0000h
AIF1TX7MIX_SRC2 [7:0]
AIF1TX7MIX_VOL2 [6:0]
0080h
0000h
AIF1TX7MIX_SRC1 [7:0]
AIF1TX7MIX_VOL1 [6:0]
0080h
0000h
AIF1TX6MIX_SRC4 [7:0]
AIF1TX6MIX_VOL4 [6:0]
0080h
0000h
AIF1TX6MIX_SRC3 [7:0]
AIF1TX6MIX_VOL3 [6:0]
0080h
0000h
AIF1TX6MIX_SRC2 [7:0]
AIF1TX6MIX_VOL2 [6:0]
0080h
0000h
AIF1TX6MIX_SRC1 [7:0]
AIF1TX6MIX_VOL1 [6:0]
0080h
0000h
AIF1TX5MIX_SRC4 [7:0]
AIF1TX5MIX_VOL4 [6:0]
0080h
0000h
AIF1TX5MIX_SRC3 [7:0]
AIF1TX5MIX_VOL3 [6:0]
0080h
0000h
AIF1TX5MIX_SRC2 [7:0]
AIF1TX5MIX_VOL2 [6:0]
0080h
0000h
AIF1TX5MIX_SRC1 [7:0]
AIF1TX5MIX_VOL1 [6:0]
0080h
0000h
AIF1TX4MIX_SRC4 [7:0]
AIF1TX4MIX_VOL4 [6:0]
0080h
0000h
AIF1TX4MIX_SRC3 [7:0]
AIF1TX4MIX_VOL3 [6:0]
0080h
0000h
AIF1TX4MIX_SRC2 [7:0]
AIF1TX4MIX_VOL2 [6:0]
0080h
0
0080h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1850
(73Ah)
R1851
(73Bh)
R1852
(73Ch)
R1853
(73Dh)
R1854
(73Eh)
R1855
(73Fh)
R1856
(740h)
R1857
(741h)
R1858
(742h)
R1859
(743h)
R1860
(744h)
R1861
(745h)
R1862
(746h)
R1863
(747h)
R1864
(748h)
R1865
(749h)
R1866
(74Ah)
R1867
(74Bh)
R1868
(74Ch)
R1869
(74Dh)
R1870
(74Eh)
R1871
(74Fh)
R1872
(750h)
R1873
(751h)
R1874
(752h)
R1875
(753h)
R1876
(754h)
R1877
(755h)
R1878
(756h)
R1879
(757h)
R1880
(758h)
R1881
(759h)
R1882
(75Ah)
R1883
(75Bh)
R1884
(75Ch)
R1885
(75Dh)
R1886
(75Eh)
R1887
(75Fh)
Name
AIF1TX8MIX_Input_2_
Source
AIF1TX8MIX_Input_2_
Volume
AIF1TX8MIX_Input_3_
Source
AIF1TX8MIX_Input_3_
Volume
AIF1TX8MIX_Input_4_
Source
AIF1TX8MIX_Input_4_
Volume
AIF2TX1MIX_Input_1_
Source
AIF2TX1MIX_Input_1_
Volume
AIF2TX1MIX_Input_2_
Source
AIF2TX1MIX_Input_2_
Volume
AIF2TX1MIX_Input_3_
Source
AIF2TX1MIX_Input_3_
Volume
AIF2TX1MIX_Input_4_
Source
AIF2TX1MIX_Input_4_
Volume
AIF2TX2MIX_Input_1_
Source
AIF2TX2MIX_Input_1_
Volume
AIF2TX2MIX_Input_2_
Source
AIF2TX2MIX_Input_2_
Volume
AIF2TX2MIX_Input_3_
Source
AIF2TX2MIX_Input_3_
Volume
AIF2TX2MIX_Input_4_
Source
AIF2TX2MIX_Input_4_
Volume
AIF2TX3MIX_Input_1_
Source
AIF2TX3MIX_Input_1_
Volume
AIF2TX3MIX_Input_2_
Source
AIF2TX3MIX_Input_2_
Volume
AIF2TX3MIX_Input_3_
Source
AIF2TX3MIX_Input_3_
Volume
AIF2TX3MIX_Input_4_
Source
AIF2TX3MIX_Input_4_
Volume
AIF2TX4MIX_Input_1_
Source
AIF2TX4MIX_Input_1_
Volume
AIF2TX4MIX_Input_2_
Source
AIF2TX4MIX_Input_2_
Volume
AIF2TX4MIX_Input_3_
Source
AIF2TX4MIX_Input_3_
Volume
AIF2TX4MIX_Input_4_
Source
AIF2TX4MIX_Input_4_
Volume
DS1162F1
15
14
13
12
11
10
9
8
AIF1TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF1TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
AIF1TX8MIX_SRC2 [7:0]
AIF1TX8MIX_VOL2 [6:0]
0000h
AIF1TX8MIX_SRC3 [7:0]
AIF1TX8MIX_VOL3 [6:0]
0
0000h
AIF1TX8MIX_SRC4 [7:0]
AIF1TX8MIX_VOL4 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
AIF2TX4MIX_SRC4 [7:0]
AIF2TX4MIX_VOL4 [6:0]
0080h
0000h
AIF2TX4MIX_SRC3 [7:0]
AIF2TX4MIX_VOL3 [6:0]
0080h
0000h
AIF2TX4MIX_SRC2 [7:0]
AIF2TX4MIX_VOL2 [6:0]
0080h
0000h
AIF2TX4MIX_SRC1 [7:0]
AIF2TX4MIX_VOL1 [6:0]
0080h
0000h
AIF2TX3MIX_SRC4 [7:0]
AIF2TX3MIX_VOL4 [6:0]
0080h
0000h
AIF2TX3MIX_SRC3 [7:0]
AIF2TX3MIX_VOL3 [6:0]
0080h
0000h
AIF2TX3MIX_SRC2 [7:0]
AIF2TX3MIX_VOL2 [6:0]
0080h
0000h
AIF2TX3MIX_SRC1 [7:0]
AIF2TX3MIX_VOL1 [6:0]
0080h
0000h
AIF2TX2MIX_SRC4 [7:0]
AIF2TX2MIX_VOL4 [6:0]
0080h
0000h
AIF2TX2MIX_SRC3 [7:0]
AIF2TX2MIX_VOL3 [6:0]
0080h
0000h
AIF2TX2MIX_SRC2 [7:0]
AIF2TX2MIX_VOL2 [6:0]
0080h
0000h
AIF2TX2MIX_SRC1 [7:0]
AIF2TX2MIX_VOL1 [6:0]
0080h
0000h
AIF2TX1MIX_SRC4 [7:0]
AIF2TX1MIX_VOL4 [6:0]
0080h
0000h
AIF2TX1MIX_SRC3 [7:0]
AIF2TX1MIX_VOL3 [6:0]
0080h
0000h
AIF2TX1MIX_SRC2 [7:0]
AIF2TX1MIX_VOL2 [6:0]
0080h
0000h
AIF2TX1MIX_SRC1 [7:0]
AIF2TX1MIX_VOL1 [6:0]
0080h
0
0080h
293
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1888
(760h)
R1889
(761h)
R1890
(762h)
R1891
(763h)
R1892
(764h)
R1893
(765h)
R1894
(766h)
R1895
(767h)
R1896
(768h)
R1897
(769h)
R1898
(76Ah)
R1899
(76Bh)
R1900
(76Ch)
R1901
(76Dh)
R1902
(76Eh)
R1903
(76Fh)
R1904
(770h)
R1905
(771h)
R1906
(772h)
R1907
(773h)
R1908
(774h)
R1909
(775h)
R1910
(776h)
R1911
(777h)
R1912
(778h)
R1913
(779h)
R1914
(77Ah)
R1915
(77Bh)
R1916
(77Ch)
R1917
(77Dh)
R1918
(77Eh)
R1919
(77Fh)
R1920
(780h)
R1921
(781h)
R1922
(782h)
R1923
(783h)
R1924
(784h)
R1925
(785h)
294
Name
AIF2TX5MIX_Input_1_
Source
AIF2TX5MIX_Input_1_
Volume
AIF2TX5MIX_Input_2_
Source
AIF2TX5MIX_Input_2_
Volume
AIF2TX5MIX_Input_3_
Source
AIF2TX5MIX_Input_3_
Volume
AIF2TX5MIX_Input_4_
Source
AIF2TX5MIX_Input_4_
Volume
AIF2TX6MIX_Input_1_
Source
AIF2TX6MIX_Input_1_
Volume
AIF2TX6MIX_Input_2_
Source
AIF2TX6MIX_Input_2_
Volume
AIF2TX6MIX_Input_3_
Source
AIF2TX6MIX_Input_3_
Volume
AIF2TX6MIX_Input_4_
Source
AIF2TX6MIX_Input_4_
Volume
AIF2TX7MIX_Input_1_
Source
AIF2TX7MIX_Input_1_
Volume
AIF2TX7MIX_Input_2_
Source
AIF2TX7MIX_Input_2_
Volume
AIF2TX7MIX_Input_3_
Source
AIF2TX7MIX_Input_3_
Volume
AIF2TX7MIX_Input_4_
Source
AIF2TX7MIX_Input_4_
Volume
AIF2TX8MIX_Input_1_
Source
AIF2TX8MIX_Input_1_
Volume
AIF2TX8MIX_Input_2_
Source
AIF2TX8MIX_Input_2_
Volume
AIF2TX8MIX_Input_3_
Source
AIF2TX8MIX_Input_3_
Volume
AIF2TX8MIX_Input_4_
Source
AIF2TX8MIX_Input_4_
Volume
AIF3TX1MIX_Input_1_
Source
AIF3TX1MIX_Input_1_
Volume
AIF3TX1MIX_Input_2_
Source
AIF3TX1MIX_Input_2_
Volume
AIF3TX1MIX_Input_3_
Source
AIF3TX1MIX_Input_3_
Volume
15
14
13
12
11
10
9
8
AIF2TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF2TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
AIF2TX5MIX_SRC1 [7:0]
AIF2TX5MIX_VOL1 [6:0]
0000h
AIF2TX5MIX_SRC2 [7:0]
AIF2TX5MIX_VOL2 [6:0]
0
0000h
AIF2TX5MIX_SRC3 [7:0]
AIF2TX5MIX_VOL3 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
AIF3TX1MIX_SRC3 [7:0]
AIF3TX1MIX_VOL3 [6:0]
0080h
0000h
AIF3TX1MIX_SRC2 [7:0]
AIF3TX1MIX_VOL2 [6:0]
0080h
0000h
AIF3TX1MIX_SRC1 [7:0]
AIF3TX1MIX_VOL1 [6:0]
0080h
0000h
AIF2TX8MIX_SRC4 [7:0]
AIF2TX8MIX_VOL4 [6:0]
0080h
0000h
AIF2TX8MIX_SRC3 [7:0]
AIF2TX8MIX_VOL3 [6:0]
0080h
0000h
AIF2TX8MIX_SRC2 [7:0]
AIF2TX8MIX_VOL2 [6:0]
0080h
0000h
AIF2TX8MIX_SRC1 [7:0]
AIF2TX8MIX_VOL1 [6:0]
0080h
0000h
AIF2TX7MIX_SRC4 [7:0]
AIF2TX7MIX_VOL4 [6:0]
0080h
0000h
AIF2TX7MIX_SRC3 [7:0]
AIF2TX7MIX_VOL3 [6:0]
0080h
0000h
AIF2TX7MIX_SRC2 [7:0]
AIF2TX7MIX_VOL2 [6:0]
0080h
0000h
AIF2TX7MIX_SRC1 [7:0]
AIF2TX7MIX_VOL1 [6:0]
0080h
0000h
AIF2TX6MIX_SRC4 [7:0]
AIF2TX6MIX_VOL4 [6:0]
0080h
0000h
AIF2TX6MIX_SRC3 [7:0]
AIF2TX6MIX_VOL3 [6:0]
0080h
0000h
AIF2TX6MIX_SRC2 [7:0]
AIF2TX6MIX_VOL2 [6:0]
0080h
0000h
AIF2TX6MIX_SRC1 [7:0]
AIF2TX6MIX_VOL1 [6:0]
0080h
0000h
AIF2TX5MIX_SRC4 [7:0]
AIF2TX5MIX_VOL4 [6:0]
0080h
0
0080h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1926
(786h)
R1927
(787h)
R1928
(788h)
R1929
(789h)
R1930
(78Ah)
R1931
(78Bh)
R1932
(78Ch)
R1933
(78Dh)
R1934
(78Eh)
R1935
(78Fh)
R1936
(790h)
R1937
(791h)
R1938
(792h)
R1939
(793h)
R1940
(794h)
R1941
(795h)
R1942
(796h)
R1943
(797h)
R1944
(798h)
R1945
(799h)
R1946
(79Ah)
R1947
(79Bh)
R1948
(79Ch)
R1949
(79Dh)
R1950
(79Eh)
R1951
(79Fh)
R1952
(7A0h)
R1953
(7A1h)
R1954
(7A2h)
R1955
(7A3h)
R1956
(7A4h)
R1957
(7A5h)
R1958
(7A6h)
R1959
(7A7h)
R1960
(7A8h)
R1961
(7A9h)
R1962
(7AAh)
R1963
(7ABh)
Name
AIF3TX1MIX_Input_4_
Source
AIF3TX1MIX_Input_4_
Volume
AIF3TX2MIX_Input_1_
Source
AIF3TX2MIX_Input_1_
Volume
AIF3TX2MIX_Input_2_
Source
AIF3TX2MIX_Input_2_
Volume
AIF3TX2MIX_Input_3_
Source
AIF3TX2MIX_Input_3_
Volume
AIF3TX2MIX_Input_4_
Source
AIF3TX2MIX_Input_4_
Volume
AIF3TX3MIX_Input_1_
Source
AIF3TX3MIX_Input_1_
Volume
AIF3TX3MIX_Input_2_
Source
AIF3TX3MIX_Input_2_
Volume
AIF3TX3MIX_Input_3_
Source
AIF3TX3MIX_Input_3_
Volume
AIF3TX3MIX_Input_4_
Source
AIF3TX3MIX_Input_4_
Volume
AIF3TX4MIX_Input_1_
Source
AIF3TX4MIX_Input_1_
Volume
AIF3TX4MIX_Input_2_
Source
AIF3TX4MIX_Input_2_
Volume
AIF3TX4MIX_Input_3_
Source
AIF3TX4MIX_Input_3_
Volume
AIF3TX4MIX_Input_4_
Source
AIF3TX4MIX_Input_4_
Volume
AIF3TX5MIX_Input_1_
Source
AIF3TX5MIX_Input_1_
Volume
AIF3TX5MIX_Input_2_
Source
AIF3TX5MIX_Input_2_
Volume
AIF3TX5MIX_Input_3_
Source
AIF3TX5MIX_Input_3_
Volume
AIF3TX5MIX_Input_4_
Source
AIF3TX5MIX_Input_4_
Volume
AIF3TX6MIX_Input_1_
Source
AIF3TX6MIX_Input_1_
Volume
AIF3TX6MIX_Input_2_
Source
AIF3TX6MIX_Input_2_
Volume
DS1162F1
15
14
13
12
11
10
9
8
AIF3TX1MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX2MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX3MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX4MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX5MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
AIF3TX1MIX_SRC4 [7:0]
AIF3TX1MIX_VOL4 [6:0]
0000h
AIF3TX2MIX_SRC1 [7:0]
AIF3TX2MIX_VOL1 [6:0]
0
0000h
AIF3TX2MIX_SRC2 [7:0]
AIF3TX2MIX_VOL2 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
AIF3TX6MIX_SRC2 [7:0]
AIF3TX6MIX_VOL2 [6:0]
0080h
0000h
AIF3TX6MIX_SRC1 [7:0]
AIF3TX6MIX_VOL1 [6:0]
0080h
0000h
AIF3TX5MIX_SRC4 [7:0]
AIF3TX5MIX_VOL4 [6:0]
0080h
0000h
AIF3TX5MIX_SRC3 [7:0]
AIF3TX5MIX_VOL3 [6:0]
0080h
0000h
AIF3TX5MIX_SRC2 [7:0]
AIF3TX5MIX_VOL2 [6:0]
0080h
0000h
AIF3TX5MIX_SRC1 [7:0]
AIF3TX5MIX_VOL1 [6:0]
0080h
0000h
AIF3TX4MIX_SRC4 [7:0]
AIF3TX4MIX_VOL4 [6:0]
0080h
0000h
AIF3TX4MIX_SRC3 [7:0]
AIF3TX4MIX_VOL3 [6:0]
0080h
0000h
AIF3TX4MIX_SRC2 [7:0]
AIF3TX4MIX_VOL2 [6:0]
0080h
0000h
AIF3TX4MIX_SRC1 [7:0]
AIF3TX4MIX_VOL1 [6:0]
0080h
0000h
AIF3TX3MIX_SRC4 [7:0]
AIF3TX3MIX_VOL4 [6:0]
0080h
0000h
AIF3TX3MIX_SRC3 [7:0]
AIF3TX3MIX_VOL3 [6:0]
0080h
0000h
AIF3TX3MIX_SRC2 [7:0]
AIF3TX3MIX_VOL2 [6:0]
0080h
0000h
AIF3TX3MIX_SRC1 [7:0]
AIF3TX3MIX_VOL1 [6:0]
0080h
0000h
AIF3TX2MIX_SRC4 [7:0]
AIF3TX2MIX_VOL4 [6:0]
0080h
0000h
AIF3TX2MIX_SRC3 [7:0]
AIF3TX2MIX_VOL3 [6:0]
0080h
0
0080h
295
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R1964
(7ACh)
R1965
(7ADh)
R1966
(7AEh)
R1967
(7AFh)
R1968
(7B0h)
R1969
(7B1h)
R1970
(7B2h)
R1971
(7B3h)
R1972
(7B4h)
R1973
(7B5h)
R1974
(7B6h)
R1975
(7B7h)
R1976
(7B8h)
R1977
(7B9h)
R1978
(7BAh)
R1979
(7BBh)
R1980
(7BCh)
R1981
(7BDh)
R1982
(7BEh)
R1983
(7BFh)
R1984
(7C0h)
R1985
(7C1h)
R1986
(7C2h)
R1987
(7C3h)
R1988
(7C4h)
R1989
(7C5h)
R1990
(7C6h)
R1991
(7C7h)
R1992
(7C8h)
R1993
(7C9h)
R1994
(7CAh)
R1995
(7CBh)
R1996
(7CCh)
R1997
(7CDh)
R1998
(7CEh)
R1999
(7CFh)
R2000
(7D0h)
R2001
(7D1h)
296
Name
AIF3TX6MIX_Input_3_
Source
AIF3TX6MIX_Input_3_
Volume
AIF3TX6MIX_Input_4_
Source
AIF3TX6MIX_Input_4_
Volume
AIF3TX7MIX_Input_1_
Source
AIF3TX7MIX_Input_1_
Volume
AIF3TX7MIX_Input_2_
Source
AIF3TX7MIX_Input_2_
Volume
AIF3TX7MIX_Input_3_
Source
AIF3TX7MIX_Input_3_
Volume
AIF3TX7MIX_Input_4_
Source
AIF3TX7MIX_Input_4_
Volume
AIF3TX8MIX_Input_1_
Source
AIF3TX8MIX_Input_1_
Volume
AIF3TX8MIX_Input_2_
Source
AIF3TX8MIX_Input_2_
Volume
AIF3TX8MIX_Input_3_
Source
AIF3TX8MIX_Input_3_
Volume
AIF3TX8MIX_Input_4_
Source
AIF3TX8MIX_Input_4_
Volume
SLIMTX1MIX_Input_1_
Source
SLIMTX1MIX_Input_1_
Volume
SLIMTX1MIX_Input_2_
Source
SLIMTX1MIX_Input_2_
Volume
SLIMTX1MIX_Input_3_
Source
SLIMTX1MIX_Input_3_
Volume
SLIMTX1MIX_Input_4_
Source
SLIMTX1MIX_Input_4_
Volume
SLIMTX2MIX_Input_1_
Source
SLIMTX2MIX_Input_1_
Volume
SLIMTX2MIX_Input_2_
Source
SLIMTX2MIX_Input_2_
Volume
SLIMTX2MIX_Input_3_
Source
SLIMTX2MIX_Input_3_
Volume
SLIMTX2MIX_Input_4_
Source
SLIMTX2MIX_Input_4_
Volume
SLIMTX3MIX_Input_1_
Source
SLIMTX3MIX_Input_1_
Volume
15
14
13
12
11
10
9
8
AIF3TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX6MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX7MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AIF3TX8MI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX1M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX1M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX1M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX1M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX2M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX2M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX2M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX2M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX3M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
AIF3TX6MIX_SRC3 [7:0]
AIF3TX6MIX_VOL3 [6:0]
0000h
AIF3TX6MIX_SRC4 [7:0]
AIF3TX6MIX_VOL4 [6:0]
0
0000h
AIF3TX7MIX_SRC1 [7:0]
AIF3TX7MIX_VOL1 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
SLIMTX3MIX_SRC1 [7:0]
SLIMTX3MIX_VOL1 [6:0]
0080h
0000h
SLIMTX2MIX_SRC4 [7:0]
SLIMTX2MIX_VOL4 [6:0]
0080h
0000h
SLIMTX2MIX_SRC3 [7:0]
SLIMTX2MIX_VOL3 [6:0]
0080h
0000h
SLIMTX2MIX_SRC2 [7:0]
SLIMTX2MIX_VOL2 [6:0]
0080h
0000h
SLIMTX2MIX_SRC1 [7:0]
SLIMTX2MIX_VOL1 [6:0]
0080h
0000h
SLIMTX1MIX_SRC4 [7:0]
SLIMTX1MIX_VOL4 [6:0]
0080h
0000h
SLIMTX1MIX_SRC3 [7:0]
SLIMTX1MIX_VOL3 [6:0]
0080h
0000h
SLIMTX1MIX_SRC2 [7:0]
SLIMTX1MIX_VOL2 [6:0]
0080h
0000h
SLIMTX1MIX_SRC1 [7:0]
SLIMTX1MIX_VOL1 [6:0]
0080h
0000h
AIF3TX8MIX_SRC4 [7:0]
AIF3TX8MIX_VOL4 [6:0]
0080h
0000h
AIF3TX8MIX_SRC3 [7:0]
AIF3TX8MIX_VOL3 [6:0]
0080h
0000h
AIF3TX8MIX_SRC2 [7:0]
AIF3TX8MIX_VOL2 [6:0]
0080h
0000h
AIF3TX8MIX_SRC1 [7:0]
AIF3TX8MIX_VOL1 [6:0]
0080h
0000h
AIF3TX7MIX_SRC4 [7:0]
AIF3TX7MIX_VOL4 [6:0]
0080h
0000h
AIF3TX7MIX_SRC3 [7:0]
AIF3TX7MIX_VOL3 [6:0]
0080h
0000h
AIF3TX7MIX_SRC2 [7:0]
AIF3TX7MIX_VOL2 [6:0]
0080h
0
0080h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R2002
(7D2h)
R2003
(7D3h)
R2004
(7D4h)
R2005
(7D5h)
R2006
(7D6h)
R2007
(7D7h)
R2008
(7D8h)
R2009
(7D9h)
R2010
(7DAh)
R2011
(7DBh)
R2012
(7DCh)
R2013
(7DDh)
R2014
(7DEh)
R2015
(7DFh)
R2016
(7E0h)
R2017
(7E1h)
R2018
(7E2h)
R2019
(7E3h)
R2020
(7E4h)
R2021
(7E5h)
R2022
(7E6h)
R2023
(7E7h)
R2024
(7E8h)
R2025
(7E9h)
R2026
(7EAh)
R2027
(7EBh)
R2028
(7ECh)
R2029
(7EDh)
R2030
(7EEh)
R2031
(7EFh)
R2032
(7F0h)
R2033
(7F1h)
R2034
(7F2h)
R2035
(7F3h)
R2036
(7F4h)
R2037
(7F5h)
R2038
(7F6h)
R2039
(7F7h)
Name
SLIMTX3MIX_Input_2_
Source
SLIMTX3MIX_Input_2_
Volume
SLIMTX3MIX_Input_3_
Source
SLIMTX3MIX_Input_3_
Volume
SLIMTX3MIX_Input_4_
Source
SLIMTX3MIX_Input_4_
Volume
SLIMTX4MIX_Input_1_
Source
SLIMTX4MIX_Input_1_
Volume
SLIMTX4MIX_Input_2_
Source
SLIMTX4MIX_Input_2_
Volume
SLIMTX4MIX_Input_3_
Source
SLIMTX4MIX_Input_3_
Volume
SLIMTX4MIX_Input_4_
Source
SLIMTX4MIX_Input_4_
Volume
SLIMTX5MIX_Input_1_
Source
SLIMTX5MIX_Input_1_
Volume
SLIMTX5MIX_Input_2_
Source
SLIMTX5MIX_Input_2_
Volume
SLIMTX5MIX_Input_3_
Source
SLIMTX5MIX_Input_3_
Volume
SLIMTX5MIX_Input_4_
Source
SLIMTX5MIX_Input_4_
Volume
SLIMTX6MIX_Input_1_
Source
SLIMTX6MIX_Input_1_
Volume
SLIMTX6MIX_Input_2_
Source
SLIMTX6MIX_Input_2_
Volume
SLIMTX6MIX_Input_3_
Source
SLIMTX6MIX_Input_3_
Volume
SLIMTX6MIX_Input_4_
Source
SLIMTX6MIX_Input_4_
Volume
SLIMTX7MIX_Input_1_
Source
SLIMTX7MIX_Input_1_
Volume
SLIMTX7MIX_Input_2_
Source
SLIMTX7MIX_Input_2_
Volume
SLIMTX7MIX_Input_3_
Source
SLIMTX7MIX_Input_3_
Volume
SLIMTX7MIX_Input_4_
Source
SLIMTX7MIX_Input_4_
Volume
DS1162F1
15
14
13
12
11
10
9
8
SLIMTX3M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX3M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX3M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX4M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX4M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX4M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX4M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX5M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX5M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX5M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX5M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX6M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX6M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX6M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX6M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX7M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX7M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX7M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX7M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
SLIMTX3MIX_SRC2 [7:0]
SLIMTX3MIX_VOL2 [6:0]
0000h
SLIMTX3MIX_SRC3 [7:0]
SLIMTX3MIX_VOL3 [6:0]
0
0000h
SLIMTX3MIX_SRC4 [7:0]
SLIMTX3MIX_VOL4 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
SLIMTX7MIX_SRC4 [7:0]
SLIMTX7MIX_VOL4 [6:0]
0080h
0000h
SLIMTX7MIX_SRC3 [7:0]
SLIMTX7MIX_VOL3 [6:0]
0080h
0000h
SLIMTX7MIX_SRC2 [7:0]
SLIMTX7MIX_VOL2 [6:0]
0080h
0000h
SLIMTX7MIX_SRC1 [7:0]
SLIMTX7MIX_VOL1 [6:0]
0080h
0000h
SLIMTX6MIX_SRC4 [7:0]
SLIMTX6MIX_VOL4 [6:0]
0080h
0000h
SLIMTX6MIX_SRC3 [7:0]
SLIMTX6MIX_VOL3 [6:0]
0080h
0000h
SLIMTX6MIX_SRC2 [7:0]
SLIMTX6MIX_VOL2 [6:0]
0080h
0000h
SLIMTX6MIX_SRC1 [7:0]
SLIMTX6MIX_VOL1 [6:0]
0080h
0000h
SLIMTX5MIX_SRC4 [7:0]
SLIMTX5MIX_VOL4 [6:0]
0080h
0000h
SLIMTX5MIX_SRC3 [7:0]
SLIMTX5MIX_VOL3 [6:0]
0080h
0000h
SLIMTX5MIX_SRC2 [7:0]
SLIMTX5MIX_VOL2 [6:0]
0080h
0000h
SLIMTX5MIX_SRC1 [7:0]
SLIMTX5MIX_VOL1 [6:0]
0080h
0000h
SLIMTX4MIX_SRC4 [7:0]
SLIMTX4MIX_VOL4 [6:0]
0080h
0000h
SLIMTX4MIX_SRC3 [7:0]
SLIMTX4MIX_VOL3 [6:0]
0080h
0000h
SLIMTX4MIX_SRC2 [7:0]
SLIMTX4MIX_VOL2 [6:0]
0080h
0000h
SLIMTX4MIX_SRC1 [7:0]
SLIMTX4MIX_VOL1 [6:0]
0080h
0
0080h
297
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R2040
(7F8h)
R2041
(7F9h)
R2042
(7FAh)
R2043
(7FBh)
R2044
(7FCh)
R2045
(7FDh)
R2046
(7FEh)
R2047
(7FFh)
R2048
(800h)
R2049
(801h)
R2056
(808h)
R2057
(809h)
R2176
(880h)
R2177
(881h)
R2178
(882h)
R2179
(883h)
R2180
(884h)
R2181
(885h)
R2182
(886h)
R2183
(887h)
R2184
(888h)
R2185
(889h)
R2186
(88Ah)
R2187
(88Bh)
R2188
(88Ch)
R2189
(88Dh)
R2190
(88Eh)
R2191
(88Fh)
R2192
(890h)
R2193
(891h)
R2194
(892h)
R2195
(893h)
R2196
(894h)
R2197
(895h)
R2198
(896h)
R2199
(897h)
R2200
(898h)
R2201
(899h)
298
Name
SLIMTX8MIX_Input_1_
Source
SLIMTX8MIX_Input_1_
Volume
SLIMTX8MIX_Input_2_
Source
SLIMTX8MIX_Input_2_
Volume
SLIMTX8MIX_Input_3_
Source
SLIMTX8MIX_Input_3_
Volume
SLIMTX8MIX_Input_4_
Source
SLIMTX8MIX_Input_4_
Volume
SPDIF1TX1MIX_Input_
1_Source
SPDIF1TX1MIX_Input_
1_Volume
SPDIF1TX2MIX_Input_
1_Source
SPDIF1TX2MIX_Input_
1_Volume
EQ1MIX_Input_1_
Source
EQ1MIX_Input_1_
Volume
EQ1MIX_Input_2_
Source
EQ1MIX_Input_2_
Volume
EQ1MIX_Input_3_
Source
EQ1MIX_Input_3_
Volume
EQ1MIX_Input_4_
Source
EQ1MIX_Input_4_
Volume
EQ2MIX_Input_1_
Source
EQ2MIX_Input_1_
Volume
EQ2MIX_Input_2_
Source
EQ2MIX_Input_2_
Volume
EQ2MIX_Input_3_
Source
EQ2MIX_Input_3_
Volume
EQ2MIX_Input_4_
Source
EQ2MIX_Input_4_
Volume
EQ3MIX_Input_1_
Source
EQ3MIX_Input_1_
Volume
EQ3MIX_Input_2_
Source
EQ3MIX_Input_2_
Volume
EQ3MIX_Input_3_
Source
EQ3MIX_Input_3_
Volume
EQ3MIX_Input_4_
Source
EQ3MIX_Input_4_
Volume
EQ4MIX_Input_1_
Source
EQ4MIX_Input_1_
Volume
15
14
13
12
11
10
9
8
SLIMTX8M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX8M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX8M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SLIMTX8M
IX_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SPDIF1TX
1_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
SPDIF1TX
2_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ1MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ1MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ1MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ1MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ2MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ2MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ2MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ2MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ3MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ3MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ3MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ3MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ4MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
SLIMTX8MIX_SRC1 [7:0]
SLIMTX8MIX_VOL1 [6:0]
0000h
SLIMTX8MIX_SRC2 [7:0]
SLIMTX8MIX_VOL2 [6:0]
0
0000h
SLIMTX8MIX_SRC3 [7:0]
SLIMTX8MIX_VOL3 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
EQ4MIX_SRC1 [7:0]
EQ4MIX_VOL1 [6:0]
0080h
0000h
EQ3MIX_SRC4 [7:0]
EQ3MIX_VOL4 [6:0]
0080h
0000h
EQ3MIX_SRC3 [7:0]
EQ3MIX_VOL3 [6:0]
0080h
0000h
EQ3MIX_SRC2 [7:0]
EQ3MIX_VOL2 [6:0]
0080h
0000h
EQ3MIX_SRC1 [7:0]
EQ3MIX_VOL1 [6:0]
0080h
0000h
EQ2MIX_SRC4 [7:0]
EQ2MIX_VOL4 [6:0]
0080h
0000h
EQ2MIX_SRC3 [7:0]
EQ2MIX_VOL3 [6:0]
0080h
0000h
EQ2MIX_SRC2 [7:0]
EQ2MIX_VOL2 [6:0]
0080h
0000h
EQ2MIX_SRC1 [7:0]
EQ2MIX_VOL1 [6:0]
0080h
0000h
EQ1MIX_SRC4 [7:0]
EQ1MIX_VOL4 [6:0]
0080h
0000h
EQ1MIX_SRC3 [7:0]
EQ1MIX_VOL3 [6:0]
0080h
0000h
EQ1MIX_SRC2 [7:0]
EQ1MIX_VOL2 [6:0]
0080h
0000h
EQ1MIX_SRC1 [7:0]
EQ1MIX_VOL1 [6:0]
0080h
0000h
SPDIF1TX2_SRC [7:0]
SPDIF1TX2_VOL [6:0]
0080h
0000h
SPDIF1TX1_SRC [7:0]
SPDIF1TX1_VOL [6:0]
0080h
0000h
SLIMTX8MIX_SRC4 [7:0]
SLIMTX8MIX_VOL4 [6:0]
0080h
0
0080h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R2202
(89Ah)
R2203
(89Bh)
R2204
(89Ch)
R2205
(89Dh)
R2206
(89Eh)
R2207
(89Fh)
R2240
(8C0h)
R2241
(8C1h)
R2242
(8C2h)
R2243
(8C3h)
R2244
(8C4h)
R2245
(8C5h)
R2246
(8C6h)
R2247
(8C7h)
R2248
(8C8h)
R2249
(8C9h)
R2250
(8CAh)
R2251
(8CBh)
R2252
(8CCh)
R2253
(8CDh)
R2254
(8CEh)
R2255
(8CFh)
R2256
(8D0h)
R2257
(8D1h)
R2258
(8D2h)
R2259
(8D3h)
R2260
(8D4h)
R2261
(8D5h)
R2262
(8D6h)
R2263
(8D7h)
R2264
(8D8h)
R2265
(8D9h)
R2266
(8DAh)
R2267
(8DBh)
R2268
(8DCh)
R2269
(8DDh)
R2270
(8DEh)
R2271
(8DFh)
Name
EQ4MIX_Input_2_
Source
EQ4MIX_Input_2_
Volume
EQ4MIX_Input_3_
Source
EQ4MIX_Input_3_
Volume
EQ4MIX_Input_4_
Source
EQ4MIX_Input_4_
Volume
DRC1LMIX_Input_1_
Source
DRC1LMIX_Input_1_
Volume
DRC1LMIX_Input_2_
Source
DRC1LMIX_Input_2_
Volume
DRC1LMIX_Input_3_
Source
DRC1LMIX_Input_3_
Volume
DRC1LMIX_Input_4_
Source
DRC1LMIX_Input_4_
Volume
DRC1RMIX_Input_1_
Source
DRC1RMIX_Input_1_
Volume
DRC1RMIX_Input_2_
Source
DRC1RMIX_Input_2_
Volume
DRC1RMIX_Input_3_
Source
DRC1RMIX_Input_3_
Volume
DRC1RMIX_Input_4_
Source
DRC1RMIX_Input_4_
Volume
DRC2LMIX_Input_1_
Source
DRC2LMIX_Input_1_
Volume
DRC2LMIX_Input_2_
Source
DRC2LMIX_Input_2_
Volume
DRC2LMIX_Input_3_
Source
DRC2LMIX_Input_3_
Volume
DRC2LMIX_Input_4_
Source
DRC2LMIX_Input_4_
Volume
DRC2RMIX_Input_1_
Source
DRC2RMIX_Input_1_
Volume
DRC2RMIX_Input_2_
Source
DRC2RMIX_Input_2_
Volume
DRC2RMIX_Input_3_
Source
DRC2RMIX_Input_3_
Volume
DRC2RMIX_Input_4_
Source
DRC2RMIX_Input_4_
Volume
DS1162F1
15
14
13
12
11
10
9
8
EQ4MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ4MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EQ4MIX_
STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC2LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC2LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC2LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC2LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC2RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC2RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC2RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DRC2RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
EQ4MIX_SRC2 [7:0]
EQ4MIX_VOL2 [6:0]
0000h
EQ4MIX_SRC3 [7:0]
EQ4MIX_VOL3 [6:0]
0
0000h
EQ4MIX_SRC4 [7:0]
EQ4MIX_VOL4 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
DRC2RMIX_SRC4 [7:0]
DRC2RMIX_VOL4 [6:0]
0080h
0000h
DRC2RMIX_SRC3 [7:0]
DRC2RMIX_VOL3 [6:0]
0080h
0000h
DRC2RMIX_SRC2 [7:0]
DRC2RMIX_VOL2 [6:0]
0080h
0000h
DRC2RMIX_SRC1 [7:0]
DRC2RMIX_VOL1 [6:0]
0080h
0000h
DRC2LMIX_SRC4 [7:0]
DRC2LMIX_VOL4 [6:0]
0080h
0000h
DRC2LMIX_SRC3 [7:0]
DRC2LMIX_VOL3 [6:0]
0080h
0000h
DRC2LMIX_SRC2 [7:0]
DRC2LMIX_VOL2 [6:0]
0080h
0000h
DRC2LMIX_SRC1 [7:0]
DRC2LMIX_VOL1 [6:0]
0080h
0000h
DRC1RMIX_SRC4 [7:0]
DRC1RMIX_VOL4 [6:0]
0080h
0000h
DRC1RMIX_SRC3 [7:0]
DRC1RMIX_VOL3 [6:0]
0080h
0000h
DRC1RMIX_SRC2 [7:0]
DRC1RMIX_VOL2 [6:0]
0080h
0000h
DRC1RMIX_SRC1 [7:0]
DRC1RMIX_VOL1 [6:0]
0080h
0000h
DRC1LMIX_SRC4 [7:0]
DRC1LMIX_VOL4 [6:0]
0080h
0000h
DRC1LMIX_SRC3 [7:0]
DRC1LMIX_VOL3 [6:0]
0080h
0000h
DRC1LMIX_SRC2 [7:0]
DRC1LMIX_VOL2 [6:0]
0080h
0000h
DRC1LMIX_SRC1 [7:0]
DRC1LMIX_VOL1 [6:0]
0080h
0
0080h
299
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R2304
(900h)
R2305
(901h)
R2306
(902h)
R2307
(903h)
R2308
(904h)
R2309
(905h)
R2310
(906h)
R2311
(907h)
R2312
(908h)
R2313
(909h)
R2314
(90Ah)
R2315
(90Bh)
R2316
(90Ch)
R2317
(90Dh)
R2318
(90Eh)
R2319
(90Fh)
R2320
(910h)
R2321
(911h)
R2322
(912h)
R2323
(913h)
R2324
(914h)
R2325
(915h)
R2326
(916h)
R2327
(917h)
R2328
(918h)
R2329
(919h)
R2330
(91Ah)
R2331
(91Bh)
R2332
(91Ch)
R2333
(91Dh)
R2334
(91Eh)
R2335
(91Fh)
R2368
(940h)
R2369
(941h)
R2370
(942h)
R2371
(943h)
R2372
(944h)
R2373
(945h)
300
Name
HPLP1MIX_Input_1_
Source
HPLP1MIX_Input_1_
Volume
HPLP1MIX_Input_2_
Source
HPLP1MIX_Input_2_
Volume
HPLP1MIX_Input_3_
Source
HPLP1MIX_Input_3_
Volume
HPLP1MIX_Input_4_
Source
HPLP1MIX_Input_4_
Volume
HPLP2MIX_Input_1_
Source
HPLP2MIX_Input_1_
Volume
HPLP2MIX_Input_2_
Source
HPLP2MIX_Input_2_
Volume
HPLP2MIX_Input_3_
Source
HPLP2MIX_Input_3_
Volume
HPLP2MIX_Input_4_
Source
HPLP2MIX_Input_4_
Volume
HPLP3MIX_Input_1_
Source
HPLP3MIX_Input_1_
Volume
HPLP3MIX_Input_2_
Source
HPLP3MIX_Input_2_
Volume
HPLP3MIX_Input_3_
Source
HPLP3MIX_Input_3_
Volume
HPLP3MIX_Input_4_
Source
HPLP3MIX_Input_4_
Volume
HPLP4MIX_Input_1_
Source
HPLP4MIX_Input_1_
Volume
HPLP4MIX_Input_2_
Source
HPLP4MIX_Input_2_
Volume
HPLP4MIX_Input_3_
Source
HPLP4MIX_Input_3_
Volume
HPLP4MIX_Input_4_
Source
HPLP4MIX_Input_4_
Volume
DSP1LMIX_Input_1_
Source
DSP1LMIX_Input_1_
Volume
DSP1LMIX_Input_2_
Source
DSP1LMIX_Input_2_
Volume
DSP1LMIX_Input_3_
Source
DSP1LMIX_Input_3_
Volume
15
14
13
12
11
10
9
8
LHPF1MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF1MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF1MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF1MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF2MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF2MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF2MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF2MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF3MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF3MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF3MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF3MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF4MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF4MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF4MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
LHPF4MIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
LHPF1MIX_SRC1 [7:0]
LHPF1MIX_VOL1 [6:0]
0000h
LHPF1MIX_SRC2 [7:0]
LHPF1MIX_VOL2 [6:0]
0
0000h
LHPF1MIX_SRC3 [7:0]
LHPF1MIX_VOL3 [6:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0080h
0000h
DSP1LMIX_SRC3 [7:0]
DSP1LMIX_VOL3 [6:0]
0080h
0000h
DSP1LMIX_SRC2 [7:0]
DSP1LMIX_VOL2 [6:0]
0080h
0000h
DSP1LMIX_SRC1 [7:0]
DSP1LMIX_VOL1 [6:0]
0080h
0000h
LHPF4MIX_SRC4 [7:0]
LHPF4MIX_VOL4 [6:0]
0080h
0000h
LHPF4MIX_SRC3 [7:0]
LHPF4MIX_VOL3 [6:0]
0080h
0000h
LHPF4MIX_SRC2 [7:0]
LHPF4MIX_VOL2 [6:0]
0080h
0000h
LHPF4MIX_SRC1 [7:0]
LHPF4MIX_VOL1 [6:0]
0080h
0000h
LHPF3MIX_SRC4 [7:0]
LHPF3MIX_VOL4 [6:0]
0080h
0000h
LHPF3MIX_SRC3 [7:0]
LHPF3MIX_VOL3 [6:0]
0080h
0000h
LHPF3MIX_SRC2 [7:0]
LHPF3MIX_VOL2 [6:0]
0080h
0000h
LHPF3MIX_SRC1 [7:0]
LHPF3MIX_VOL1 [6:0]
0080h
0000h
LHPF2MIX_SRC4 [7:0]
LHPF2MIX_VOL4 [6:0]
0080h
0000h
LHPF2MIX_SRC3 [7:0]
LHPF2MIX_VOL3 [6:0]
0080h
0000h
LHPF2MIX_SRC2 [7:0]
LHPF2MIX_VOL2 [6:0]
0080h
0000h
LHPF2MIX_SRC1 [7:0]
LHPF2MIX_VOL1 [6:0]
0080h
0000h
LHPF1MIX_SRC4 [7:0]
LHPF1MIX_VOL4 [6:0]
0080h
0
0080h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R2374
(946h)
R2375
(947h)
R2376
(948h)
R2377
(949h)
R2378
(94Ah)
R2379
(94Bh)
R2380
(94Ch)
R2381
(94Dh)
R2382
(94Eh)
R2383
(94Fh)
R2384
(950h)
R2392
(958h)
R2400
(960h)
R2408
(968h)
R2416
(970h)
R2424
(978h)
R2688
(A80h)
R2696
(A88h)
R2704
(A90h)
R2712
(A98h)
R2816
(B00h)
R2824
(B08h)
R2848
(B20h)
R2856
(B28h)
R2880
(B40h)
R2888
(B48h)
R2912
(B60h)
R2920
(B68h)
R3520
(DC0h)
R3528
(DC8h)
R3536
(DD0h)
R3544
(DD8h)
R3552
(DE0h)
R3560
(DE8h)
R3568
(DF0h)
R3576
(DF8h)
R3584
(E00h)
R3585
(E01h)
Name
DSP1LMIX_Input_4_
Source
DSP1LMIX_Input_4_
Volume
DSP1RMIX_Input_1_
Source
DSP1RMIX_Input_1_
Volume
DSP1RMIX_Input_2_
Source
DSP1RMIX_Input_2_
Volume
DSP1RMIX_Input_3_
Source
DSP1RMIX_Input_3_
Volume
DSP1RMIX_Input_4_
Source
DSP1RMIX_Input_4_
Volume
DSP1AUX1MIX_Input_
1_Source
DSP1AUX2MIX_Input_
1_Source
DSP1AUX3MIX_Input_
1_Source
DSP1AUX4MIX_Input_
1_Source
DSP1AUX5MIX_Input_
1_Source
DSP1AUX6MIX_Input_
1_Source
ASRC1_1LMIX_Input_
1_Source
ASRC1_1RMIX_Input_
1_Source
ASRC1_2LMIX_Input_
1_Source
ASRC1_2RMIX_Input_
1_Source
ISRC1DEC1MIX_Input_
1_Source
ISRC1DEC2MIX_Input_
1_Source
ISRC1INT1MIX_Input_
1_Source
ISRC1INT2MIX_Input_
1_Source
ISRC2DEC1MIX_Input_
1_Source
ISRC2DEC2MIX_Input_
1_Source
ISRC2INT1MIX_Input_
1_Source
ISRC2INT2MIX_Input_
1_Source
DFC1MIX_Input_1_
Source
DFC2MIX_Input_1_
Source
DFC3MIX_Input_1_
Source
DFC4MIX_Input_1_
Source
DFC5MIX_Input_1_
Source
DFC6MIX_Input_1_
Source
DFC7MIX_Input_1_
Source
DFC8MIX_Input_1_
Source
FX_Ctrl1
FX_Ctrl2
DS1162F1
15
14
13
12
11
10
9
8
DSP1LMIX
_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1RMI
X_STS
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1AUX
1_STS
0
0
0
0
0
0
0
DSP1AUX1_SRC [7:0]
0000h
DSP1AUX
2_STS
0
0
0
0
0
0
0
DSP1AUX2_SRC [7:0]
0000h
DSP1AUX
3_STS
0
0
0
0
0
0
0
DSP1AUX3_SRC [7:0]
0000h
DSP1AUX
4_STS
0
0
0
0
0
0
0
DSP1AUX4_SRC [7:0]
0000h
DSP1AUX
5_STS
0
0
0
0
0
0
0
DSP1AUX5_SRC [7:0]
0000h
DSP1AUX
6_STS
0
0
0
0
0
0
0
DSP1AUX6_SRC [7:0]
0000h
ASRC1_
IN1L_STS
0
0
0
0
0
0
0
ASRC1_IN1L_SRC [7:0]
0000h
ASRC1_
IN1R_STS
0
0
0
0
0
0
0
ASRC1_IN1R_SRC [7:0]
0000h
ASRC1_
IN2L_STS
0
0
0
0
0
0
0
ASRC1_IN2L_SRC [7:0]
0000h
ASRC1_
IN2R_STS
0
0
0
0
0
0
0
ASRC1_IN2R_SRC [7:0]
0000h
ISRC1DEC
1_STS
0
0
0
0
0
0
0
ISRC1DEC1_SRC [7:0]
0000h
ISRC1DEC
2_STS
0
0
0
0
0
0
0
ISRC1DEC2_SRC [7:0]
0000h
ISRC1INT
1_STS
0
0
0
0
0
0
0
ISRC1INT1_SRC [7:0]
0000h
ISRC1INT
2_STS
0
0
0
0
0
0
0
ISRC1INT2_SRC [7:0]
0000h
ISRC2DEC
1_STS
0
0
0
0
0
0
0
ISRC2DEC1_SRC [7:0]
0000h
ISRC2DEC
2_STS
0
0
0
0
0
0
0
ISRC2DEC2_SRC [7:0]
0000h
ISRC2INT
1_STS
0
0
0
0
0
0
0
ISRC2INT1_SRC [7:0]
0000h
ISRC2INT
2_STS
0
0
0
0
0
0
0
ISRC2INT2_SRC [7:0]
0000h
DFC1_
STS
0
0
0
0
0
0
0
DFC1_SRC [7:0]
0000h
DFC2_
STS
0
0
0
0
0
0
0
DFC2_SRC [7:0]
0000h
DFC3_
STS
0
0
0
0
0
0
0
DFC3_SRC [7:0]
0000h
DFC4_
STS
0
0
0
0
0
0
0
DFC4_SRC [7:0]
0000h
DFC5_
STS
0
0
0
0
0
0
0
DFC5_SRC [7:0]
0000h
DFC6_
STS
0
0
0
0
0
0
0
DFC6_SRC [7:0]
0000h
DFC7_
STS
0
0
0
0
0
0
0
DFC7_SRC [7:0]
0000h
DFC8_
STS
0
0
0
0
0
0
0
DFC8_SRC [7:0]
0000h
0
0
0
FX_RATE [4:0]
FX_STS [11:0]
7
6
5
4
3
2
1
0
Default
0000h
0
0080h
DSP1LMIX_SRC4 [7:0]
DSP1LMIX_VOL4 [6:0]
0000h
DSP1RMIX_SRC1 [7:0]
DSP1RMIX_VOL1 [6:0]
0
0000h
DSP1RMIX_SRC2 [7:0]
DSP1RMIX_VOL2 [6:0]
0
DSP1RMIX_VOL3 [6:0]
0
DSP1RMIX_VOL4 [6:0]
0
0
0080h
0000h
DSP1RMIX_SRC4 [7:0]
0
0080h
0000h
DSP1RMIX_SRC3 [7:0]
0
0080h
0
0080h
0
0
0
0
0000h
0
0
1
0
0002h
301
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R3600
(E10h)
R3601
(E11h)
R3602
(E12h)
R3603
(E13h)
R3604
(E14h)
R3605
(E15h)
R3606
(E16h)
R3607
(E17h)
R3608
(E18h)
R3609
(E19h)
R3610
(E1Ah)
R3611
(E1Bh)
R3612
(E1Ch)
R3613
(E1Dh)
R3614
(E1Eh)
R3615
(E1Fh)
R3616
(E20h)
R3617
(E21h)
R3618
(E22h)
R3619
(E23h)
R3620
(E24h)
R3622
(E26h)
R3623
(E27h)
R3624
(E28h)
R3625
(E29h)
R3626
(E2Ah)
R3627
(E2Bh)
R3628
(E2Ch)
R3629
(E2Dh)
R3630
(E2Eh)
R3631
(E2Fh)
R3632
(E30h)
R3633
(E31h)
R3634
(E32h)
R3635
(E33h)
R3636
(E34h)
R3637
(E35h)
R3638
(E36h)
302
Name
15
14
13
12
11
10
9
8
EQ1_1
EQ1_B1_GAIN [4:0]
EQ1_B2_GAIN [4:0]
EQ1_2
EQ1_B4_GAIN [4:0]
EQ1_B5_GAIN [4:0]
7
6
5
4
3
2
1
EQ1_B3_GAIN [4:0]
0
0
0
0
EQ1_ENA
0
0
EQ1_B1_
MODE
Default
6318h
6300h
EQ1_3
EQ1_B1_A [15:0]
0FC8h
EQ1_4
EQ1_B1_B [15:0]
03FEh
EQ1_5
EQ1_B1_PG [15:0]
00E0h
EQ1_6
EQ1_B2_A [15:0]
1EC4h
EQ1_7
EQ1_B2_B [15:0]
F136h
EQ1_8
EQ1_B2_C [15:0]
0409h
EQ1_9
EQ1_B2_PG [15:0]
04CCh
EQ1_10
EQ1_B3_A [15:0]
1C9Bh
EQ1_11
EQ1_B3_B [15:0]
F337h
EQ1_12
EQ1_B3_C [15:0]
040Bh
EQ1_13
EQ1_B3_PG [15:0]
0CBBh
EQ1_14
EQ1_B4_A [15:0]
16F8h
EQ1_15
EQ1_B4_B [15:0]
F7D9h
EQ1_16
EQ1_B4_C [15:0]
040Ah
EQ1_17
EQ1_B4_PG [15:0]
1F14h
EQ1_18
EQ1_B5_A [15:0]
058Ch
EQ1_19
EQ1_B5_B [15:0]
0563h
EQ1_20
EQ1_B5_PG [15:0]
4000h
EQ1_21
EQ1_B1_C [15:0]
0B75h
EQ2_1
EQ2_B1_GAIN [4:0]
EQ2_B2_GAIN [4:0]
EQ2_2
EQ2_B4_GAIN [4:0]
EQ2_B5_GAIN [4:0]
EQ2_B3_GAIN [4:0]
0
0
0
0
0
EQ2_ENA
6318h
EQ2_B1_
MODE
6300h
EQ2_3
EQ2_B1_A [15:0]
0FC8h
EQ2_4
EQ2_B1_B [15:0]
03FEh
EQ2_5
EQ2_B1_PG [15:0]
00E0h
EQ2_6
EQ2_B2_A [15:0]
1EC4h
EQ2_7
EQ2_B2_B [15:0]
F136h
EQ2_8
EQ2_B2_C [15:0]
0409h
EQ2_9
EQ2_B2_PG [15:0]
04CCh
EQ2_10
EQ2_B3_A [15:0]
1C9Bh
EQ2_11
EQ2_B3_B [15:0]
F337h
EQ2_12
EQ2_B3_C [15:0]
040Bh
EQ2_13
EQ2_B3_PG [15:0]
0CBBh
EQ2_14
EQ2_B4_A [15:0]
16F8h
EQ2_15
EQ2_B4_B [15:0]
F7D9h
EQ2_16
EQ2_B4_C [15:0]
040Ah
EQ2_17
EQ2_B4_PG [15:0]
1F14h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R3639
(E37h)
R3640
(E38h)
R3641
(E39h)
R3642
(E3Ah)
R3644
(E3Ch)
R3645
(E3Dh)
R3646
(E3Eh)
R3647
(E3Fh)
R3648
(E40h)
R3649
(E41h)
R3650
(E42h)
R3651
(E43h)
R3652
(E44h)
R3653
(E45h)
R3654
(E46h)
R3655
(E47h)
R3656
(E48h)
R3657
(E49h)
R3658
(E4Ah)
R3659
(E4Bh)
R3660
(E4Ch)
R3661
(E4Dh)
R3662
(E4Eh)
R3663
(E4Fh)
R3664
(E50h)
R3666
(E52h)
R3667
(E53h)
R3668
(E54h)
R3669
(E55h)
R3670
(E56h)
R3671
(E57h)
R3672
(E58h)
R3673
(E59h)
R3674
(E5Ah)
R3675
(E5Bh)
R3676
(E5Ch)
R3677
(E5Dh)
R3678
(E5Eh)
Name
15
14
EQ2_18
13
12
11
10
9
EQ2_B5_A [15:0]
8
Default
058Ch
EQ2_19
EQ2_B5_B [15:0]
0563h
EQ2_20
EQ2_B5_PG [15:0]
4000h
EQ2_21
EQ2_B1_C [15:0]
0B75h
EQ3_1
EQ3_B1_GAIN [4:0]
EQ3_B2_GAIN [4:0]
EQ3_2
EQ3_B4_GAIN [4:0]
EQ3_B5_GAIN [4:0]
7
6
5
4
3
2
1
EQ3_B3_GAIN [4:0]
0
0
0
0
0
0
EQ3_ENA
6318h
EQ3_B1_
MODE
6300h
EQ3_3
EQ3_B1_A [15:0]
0FC8h
EQ3_4
EQ3_B1_B [15:0]
03FEh
EQ3_5
EQ3_B1_PG [15:0]
00E0h
EQ3_6
EQ3_B2_A [15:0]
1EC4h
EQ3_7
EQ3_B2_B [15:0]
F136h
EQ3_8
EQ3_B2_C [15:0]
0409h
EQ3_9
EQ3_B2_PG [15:0]
04CCh
EQ3_10
EQ3_B3_A [15:0]
1C9Bh
EQ3_11
EQ3_B3_B [15:0]
F337h
EQ3_12
EQ3_B3_C [15:0]
040Bh
EQ3_13
EQ3_B3_PG [15:0]
0CBBh
EQ3_14
EQ3_B4_A [15:0]
16F8h
EQ3_15
EQ3_B4_B [15:0]
F7D9h
EQ3_16
EQ3_B4_C [15:0]
040Ah
EQ3_17
EQ3_B4_PG [15:0]
1F14h
EQ3_18
EQ3_B5_A [15:0]
058Ch
EQ3_19
EQ3_B5_B [15:0]
0563h
EQ3_20
EQ3_B5_PG [15:0]
4000h
EQ3_21
EQ3_B1_C [15:0]
0B75h
EQ4_1
EQ4_B1_GAIN [4:0]
EQ4_B2_GAIN [4:0]
EQ4_2
EQ4_B4_GAIN [4:0]
EQ4_B5_GAIN [4:0]
EQ4_B3_GAIN [4:0]
0
0
0
0
0
EQ4_ENA
6318h
EQ4_B1_
MODE
6300h
EQ4_3
EQ4_B1_A [15:0]
0FC8h
EQ4_4
EQ4_B1_B [15:0]
03FEh
EQ4_5
EQ4_B1_PG [15:0]
00E0h
EQ4_6
EQ4_B2_A [15:0]
1EC4h
EQ4_7
EQ4_B2_B [15:0]
F136h
EQ4_8
EQ4_B2_C [15:0]
0409h
EQ4_9
EQ4_B2_PG [15:0]
04CCh
EQ4_10
EQ4_B3_A [15:0]
1C9Bh
EQ4_11
EQ4_B3_B [15:0]
F337h
EQ4_12
EQ4_B3_C [15:0]
040Bh
EQ4_13
EQ4_B3_PG [15:0]
0CBBh
DS1162F1
303
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R3679
(E5Fh)
R3680
(E60h)
R3681
(E61h)
R3682
(E62h)
R3683
(E63h)
R3684
(E64h)
R3685
(E65h)
R3686
(E66h)
R3712
(E80h)
Name
15
EQ4_14
EQ4_B4_A [15:0]
Default
16F8h
EQ4_15
EQ4_B4_B [15:0]
F7D9h
EQ4_16
EQ4_B4_C [15:0]
040Ah
EQ4_17
EQ4_B4_PG [15:0]
1F14h
EQ4_18
EQ4_B5_A [15:0]
058Ch
EQ4_19
EQ4_B5_B [15:0]
0563h
EQ4_20
EQ4_B5_PG [15:0]
4000h
EQ4_21
EQ4_B1_C [15:0]
0B75h
DRC1_ctrl1
14
13
DRC1_SIG_DET_RMS [4:0]
R3713
(E81h)
R3714
(E82h)
R3715
(E83h)
R3716
(E84h)
R3720
(E88h)
DRC1_ctrl2
R3721
(E89h)
R3722
(E8Ah)
R3723
(E8Bh)
R3724
(E8Ch)
R3776
(EC0h)
R3777
(EC1h)
R3780
(EC4h)
R3781
(EC5h)
R3784
(EC8h)
R3785
(EC9h)
R3788
(ECCh)
R3789
(ECDh)
R3808
(EE0h)
R3809
(EE1h)
DRC2_ctrl2
R3810
(EE2h)
R3811
(EE3h)
R3824
(EF0h)
R3825
(EF1h)
R3826
(EF2h)
ASRC1_RATE1
R3827
(EF3h)
R3828
(EF4h)
R3829
(EF5h)
ISRC2_CTRL_1
ISRC2_FSH [4:0]
ISRC2_CTRL_2
ISRC2_FSL [4:0]
0
DRC1_ctrl3
0
0
DRC1_NG_MINGAIN [3:0]
11
0
0
0
0
DRC1_ctrl5
0
0
0
0
0
DRC2_SIG_DET_RMS [4:0]
0
DRC2_ctrl3
0
9
0
DRC2_NG_MINGAIN [3:0]
0
5
4
3
DRC1_HI_COMP [2:0]
DRC1_KNEE2_IP [4:0]
DRC2_NG_EXP [1:0] DRC2_QR_THR [1:0] DRC2_QR_DCY [1:0]
0
0
0
0
DRC2_ctrl5
0
0
0
0
0
0
HPLPF1_1
0
0
0
0
0
0
2
1
0
DRC1_LO_COMP [2:0]
DRC2_KNEE2_IP [4:0]
0
0
0
0
0
0
0
0
0
0
0
0
HPLPF2_2
0
0
0
0
0
0
0
0
HPLPF3_2
0
0
0000h
DRC2L_ DRC2R_
ENA
ENA
0018h
DRC2_MAXGAIN [1:0]
0933h
DRC2_LO_COMP [2:0]
0
0
0
0
0
0
HPLPF4_2
0
0
0018h
DRC2_KNEE_OP [4:0]
0000h
DRC2_KNEE2_OP [4:0]
0000h
0
0
LHPF1_
MODE
LHPF1_
ENA
0000h
0000h
0
0
0
0
0
LHPF2_
MODE
LHPF2_
ENA
0000h
0000h
0
0
0
0
0
LHPF3_
MODE
LHPF3_
ENA
0000h
0000h
LHPF3_COEFF [15:0]
0
0018h
DRC1_KNEE2_OP [4:0]
LHPF2_COEFF [15:0]
0
0933h
0000h
LHPF1_COEFF [15:0]
0
0018h
DRC1_KNEE_OP [4:0]
DRC2_HI_COMP [2:0]
DRC2_KNEE_IP [5:0]
HPLPF1_2
HPLPF4_1
6
DRC2_SIG_DET_PK DRC2_ DRC2_ DRC2_ DRC2_ DRC2_QR DRC2_
0
[1:0]
NG_ENA SIG_DET_ SIG_DET KNEE2_
ANTICLIP
MODE
OP_ENA
DRC2_ATK [3:0]
DRC2_DCY [3:0]
DRC2_MINGAIN [2:0]
0
HPLPF3_1
7
DRC1_KNEE_IP [5:0]
DRC2_ctrl4
HPLPF2_1
8
DRC1_NG_EXP [1:0] DRC1_QR_THR [1:0] DRC1_QR_DCY [1:0]
0
DRC2_ctrl1
10
DRC1_SIG_DET_PK DRC1_ DRC1_ DRC1_ DRC1_ DRC1_QR DRC1_ DRC1_ DRC1L_ DRC1R_
[1:0]
NG_ENA SIG_DET_ SIG_DET KNEE2_
ANTICLIP WSEQ_
ENA
ENA
MODE
OP_ENA
SIG_DET_
ENA
DRC1_ATK [3:0]
DRC1_DCY [3:0]
DRC1_MINGAIN [2:0]
DRC1_MAXGAIN [1:0]
DRC1_ctrl4
0
0
0
0
0
LHPF4_
MODE
LHPF4_
ENA
0000h
0000h
LHPF4_COEFF [15:0]
ASRC1_ENABLE
0
0
0
0
0
0
0
0
0
0
0
0
ASRC1_ ASRC1_ ASRC1_ ASRC1_
IN2L_ENA IN2R_ENA IN1L_ENA IN1R_ENA
0000h
ASRC1_STATUS
0
0
0
0
0
0
0
0
0
0
0
0
0000h
ASRC1_RATE1 [4:0]
0
0
0
0
0
0
0
ASRC1_ ASRC1_ ASRC1_ ASRC1_
IN2L_
IN2R_
IN1L_
IN1R_
ENA_STS ENA_STS ENA_STS ENA_STS
0
0
0
0
ASRC1_RATE2
ASRC1_RATE2 [4:0]
0
0
0
0
0
0
0
0
0
0
0
4000h
ISRC1_CTRL_1
ISRC1_FSH [4:0]
0
0
0
0
0
0
0
0
0
0
0
0000h
ISRC1_CTRL_2
ISRC1_FSL [4:0]
0
0
0
0
0
0
0
0
0
0
1
0001h
0
ISRC1_
DEC2_
ENA
0
0
0
0
0
0
0
0
0
0000h
0
ISRC1_
DEC1_
ENA
0
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0
0
1
0001h
ISRC2_
DEC2_
ENA
0
0
0
0
0
0
0
0
0000h
0
0
0
US1_ENA
2030h
ISRC1_CTRL_3
ISRC2_CTRL_3
R4224 US1_Ctrl_0
(1080h)
304
12
ISRC1_ ISRC1_
INT1_ENA INT2_ENA
ISRC2_ ISRC2_
INT1_ENA INT2_ENA
0
0
0
0
0
0
US1_GAIN [1:0]
0
0
0
ISRC2_
DEC1_
ENA
US1_SRC [3:0]
0
US1_FREQ [2:0]
0000h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R4225
(1081h)
R4226
(1082h)
R4227
(1083h)
R4288
(10C0h)
R4289
(10C1h)
R5248
(1480h)
R5250
(1482h)
R5252
(1484h)
R5254
(1486h)
R5256
(1488h)
R5258
(148Ah)
R5260
(148Ch)
R5262
(148Eh)
R5264
(1490h)
R5266
(1492h)
R5268
(1494h)
R5270
(1496h)
R5272
(1498h)
R5274
(149Ah)
R5276
(149Ch)
R5278
(149Eh)
R5280
(14A0h)
R5282
(14A2h)
R5284
(14A4h)
R5286
(14A6h)
R5288
(14A8h)
R5290
(14AAh)
R5292
(14ACh)
R5294
(14AEh)
R5302
(14B6h)
R5303
(14B7h)
R5632
(1600h)
R5633
(1601h)
R5634
(1602h)
R5635
(1603h)
R5636
(1604h)
R5637
(1605h)
R5638
(1606h)
Name
US1_Ctrl_1
15
US2_Ctrl_0
0
14
0
US2_Ctrl_1
AUXPDM1_Ctrl_0
AUXPDM1_Ctrl_1
13
12
11
US1_RATE [4:0]
US2_GAIN [1:0]
0
AUXPDM1_CLK_
FREQ[1:0]
9
8
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
0
0
0
Default
0000h
0
0
0
US2_ENA
2030h
0
0
0
0
0000h
0
AUXPDM1
_ENA
0008h
0
0
4000h
US2_SRC [3:0]
US2_RATE [4:0]
0
10
0
0
0
0
AUXPDM1_SRC[3:0]
US2_FREQ [2:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
AUXPDM1 AUXPDM1 AUXPDM1
_TXEDGE _MSTR _MUTE
0
0
0
DFC1_CTRL_W0
0
0
0
DFC1_RX_W0
0
0
0
DFC1_RX_DATA_WIDTH [4:0]
0
0
0
0
DFC1_TX_W0
0
0
0
DFC1_TX_DATA_WIDTH [4:0]
0
0
0
0
DFC2_CTRL_W0
0
0
0
DFC2_RX_W0
0
0
0
DFC2_RX_DATA_WIDTH [4:0]
0
0
0
0
DFC2_TX_W0
0
0
0
DFC2_TX_DATA_WIDTH [4:0]
0
0
0
0
DFC3_CTRL_W0
0
0
0
DFC3_RX_W0
0
0
0
DFC3_RX_DATA_WIDTH [4:0]
0
0
0
0
DFC3_TX_W0
0
0
0
DFC3_TX_DATA_WIDTH [4:0]
0
0
0
0
DFC4_CTRL_W0
0
0
0
DFC4_RX_W0
0
0
0
DFC4_RX_DATA_WIDTH [4:0]
0
0
0
0
DFC4_TX_W0
0
0
0
DFC4_TX_DATA_WIDTH [4:0]
0
0
0
0
DFC5_CTRL_W0
0
0
0
DFC5_RX_W0
0
0
0
DFC5_RX_DATA_WIDTH [4:0]
0
0
0
0
DFC5_TX_W0
0
0
0
DFC5_TX_DATA_WIDTH [4:0]
0
0
0
0
DFC6_CTRL_W0
0
0
0
DFC6_RX_W0
0
0
0
DFC6_RX_DATA_WIDTH [4:0]
0
0
0
0
DFC6_TX_W0
0
0
0
DFC6_TX_DATA_WIDTH [4:0]
0
0
0
0
DFC7_CTRL_W0
0
0
0
DFC7_RX_W0
0
0
0
DFC7_RX_DATA_WIDTH [4:0]
0
0
0
0
DFC7_TX_W0
0
0
0
DFC7_TX_DATA_WIDTH [4:0]
0
0
0
0
DFC8_CTRL_W0
0
0
0
DFC8_RX_W0
0
0
0
DFC8_RX_DATA_WIDTH [4:0]
0
0
0
0
DFC8_TX_W0
0
0
0
DFC8_TX_DATA_WIDTH [4:0]
0
0
0
0
DFC_STATUS_W0
0
0
0
0
0
0
0
0
DFC_STATUS_W1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DFC_DITH_TYPE
[1:0]
0000h
ADSP2_IRQ0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP_IRQ2DSP_IRQ1
0000h
ADSP2_IRQ1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP_IRQ4DSP_IRQ3
0000h
ADSP2_IRQ2
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP_IRQ6DSP_IRQ5
0000h
ADSP2_IRQ3
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP_IRQ8DSP_IRQ7
0000h
ADSP2_IRQ4
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP_ DSP_IRQ9
IRQ10
0000h
ADSP2_IRQ5
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP_
IRQ12
DSP_
IRQ11
0000h
ADSP2_IRQ6
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP_
IRQ14
DSP_
IRQ13
0000h
DS1162F1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DFC1_
DFC1_
DITH_ENA ENA
0000h
0
DFC1_RX_DATA_TYPE [2:0]
1F00h
0
DFC1_TX_DATA_TYPE [2:0]
1F00h
DFC2_
DFC2_
DITH_ENA ENA
0000h
0
DFC2_RX_DATA_TYPE [2:0]
1F00h
0
DFC2_TX_DATA_TYPE [2:0]
1F00h
DFC3_
DFC3_
DITH_ENA ENA
0000h
0
DFC3_RX_DATA_TYPE [2:0]
1F00h
0
DFC3_TX_DATA_TYPE [2:0]
1F00h
DFC4_
DFC4_
DITH_ENA ENA
0000h
0
DFC4_RX_DATA_TYPE [2:0]
1F00h
0
DFC4_TX_DATA_TYPE [2:0]
1F00h
DFC5_
DFC5_
DITH_ENA ENA
0000h
0
DFC5_RX_DATA_TYPE [2:0]
1F00h
0
DFC5_TX_DATA_TYPE [2:0]
1F00h
DFC6_
DFC6_
DITH_ENA ENA
0000h
0
DFC6_RX_DATA_TYPE [2:0]
1F00h
0
DFC6_TX_DATA_TYPE [2:0]
1F00h
DFC7_
DFC7_
DITH_ENA ENA
0000h
0
DFC7_RX_DATA_TYPE [2:0]
1F00h
0
DFC7_TX_DATA_TYPE [2:0]
1F00h
DFC8_
DFC8_
DITH_ENA ENA
0000h
0
DFC8_RX_DATA_TYPE [2:0]
1F00h
0
DFC8_TX_DATA_TYPE [2:0]
1F00h
DFC1_RATE [4:0]
0
DFC2_RATE [4:0]
0
DFC3_RATE [4:0]
0
DFC4_RATE [4:0]
0
DFC5_RATE [4:0]
0
DFC6_RATE [4:0]
0
DFC7_RATE [4:0]
0
DFC8_RATE [4:0]
0000h
DFC_ERR_CHAN [7:0]
305
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
R5639
(1607h)
R5888
(1700h)
R5889
(1701h)
R5890
(1702h)
R5891
(1703h)
R5892
(1704h)
R5893
(1705h)
R5894
(1706h)
R5895
(1707h)
R5896
(1708h)
R5897
(1709h)
R5898
(170Ah)
R5899
(170Bh)
R5900
(170Ch)
R5901
(170Dh)
R5902
(170Eh)
R5903
(170Fh)
R5904
(1710h)
R5905
(1711h)
R5906
(1712h)
R5907
(1713h)
R5908
(1714h)
R5909
(1715h)
R5910
(1716h)
R5911
(1717h)
R5912
(1718h)
R5913
(1719h)
R5914
(171Ah)
R5915
(171Bh)
R5916
(171Ch)
R5917
(171Dh)
R5918
(171Eh)
R5919
(171Fh)
R6144
(1800h)
Name
ADSP2_IRQ7
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP_
IRQ16
DSP_
IRQ15
GPIO1_CTRL_1
GP1_LVL GP1_OP_ GP1_DB GP1_POL
CFG
0
0
GPIO1_CTRL_2
GP1_DIR GP1_PU GP1_PD
GP1_
DRV_STR
0
0
GPIO2_CTRL_1
GP2_LVL GP2_OP_ GP2_DB GP2_POL
CFG
0
0
GPIO2_CTRL_2
GP2_DIR GP2_PU GP2_PD
GP2_
DRV_STR
0
0
GPIO3_CTRL_1
GP3_LVL GP3_OP_ GP3_DB GP3_POL
CFG
0
0
GPIO3_CTRL_2
GP3_DIR GP3_PU GP3_PD
GP3_
DRV_STR
0
0
GPIO4_CTRL_1
GP4_LVL GP4_OP_ GP4_DB GP4_POL
CFG
0
0
GPIO4_CTRL_2
GP4_DIR GP4_PU GP4_PD
GP4_
DRV_STR
0
0
GPIO5_CTRL_1
GP5_LVL GP5_OP_ GP5_DB GP5_POL
CFG
0
0
GPIO5_CTRL_2
GP5_DIR GP5_PU GP5_PD
GP5_
DRV_STR
0
0
GPIO6_CTRL_1
GP6_LVL GP6_OP_ GP6_DB GP6_POL
CFG
0
0
GPIO6_CTRL_2
GP6_DIR GP6_PU GP6_PD
GP6_
DRV_STR
0
0
GPIO7_CTRL_1
GP7_LVL GP7_OP_ GP7_DB GP7_POL
CFG
0
0
GPIO7_CTRL_2
GP7_DIR GP7_PU GP7_PD
GP7_
DRV_STR
0
0
GPIO8_CTRL_1
GP8_LVL GP8_OP_ GP8_DB GP8_POL
CFG
0
0
GPIO8_CTRL_2
GP8_DIR GP8_PU GP8_PD
GP8_
DRV_STR
0
0
GPIO9_CTRL_1
GP9_LVL GP9_OP_ GP9_DB GP9_POL
CFG
0
0
GPIO9_CTRL_2
GP9_DIR GP9_PU GP9_PD
GP9_
DRV_STR
0
0
GPIO10_CTRL_1
GP10_LVL GP10_ GP10_DB
OP_CFG
GP10_
POL
0
0
GPIO10_CTRL_2
GP10_DIR GP10_PU GP10_PD
GP10_
DRV_STR
0
0
GPIO11_CTRL_1
GP11_LVL GP11_OP_ GP11_DB GP11_POL
CFG
0
0
GPIO11_CTRL_2
GP11_DIR GP11_PU GP11_PD
GP11_
DRV_STR
0
0
GPIO12_CTRL_1
GP12_LVL GP12_ GP12_DB
OP_CFG
GP12_
POL
0
0
GPIO12_CTRL_2
GP12_DIR GP12_PU GP12_PD
GP12_
DRV_STR
0
0
GPIO13_CTRL_1
GP13_LVL GP13_ GP13_DB
OP_CFG
GP13_
POL
0
0
GPIO13_CTRL_2
GP13_DIR GP13_PU GP13_PD
GP13_
DRV_STR
0
0
GPIO14_CTRL_1
GP14_LVL GP14_ GP14_DB
OP_CFG
GP14_
POL
0
0
GPIO14_CTRL_2
GP14_DIR GP14_PU GP14_PD
GP14_
DRV_STR
0
0
GPIO15_CTRL_1
GP15_LVL GP15_ GP15_DB
OP_CFG
GP15_
POL
0
0
GPIO15_CTRL_2
GP15_DIR GP15_PU GP15_PD
GP15_
DRV_STR
0
0
GPIO16_CTRL_1
GP16_LVL GP16_ GP16_DB
OP_CFG
GP16_
POL
0
0
GPIO16_CTRL_2
GP16_DIR GP16_PU GP16_PD
GP16_
DRV_STR
0
0
CTRLIF_
ERR_
EINT1
CLK_ CLK_SYS_
ASYNC_ ERR_
ERR_
EINT1
EINT1
0
0
0
0
0
0
0
0
IRQ1_Status_1
0
0
R6145 IRQ1_Status_2
(1801h)
0
0
R6149 IRQ1_Status_6
(1805h)
R6150 IRQ1_Status_7
(1806h)
0
0
0
0
306
0
0
0
MICD_
MICD_
CLAMP2_ CLAMP2_
FALL_
RISE_
EINT1
EINT1
2001h
GP1_FN [9:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
F000h
2001h
GP15_FN [9:0]
0
F000h
2001h
GP14_FN [9:0]
0
F000h
2001h
GP13_FN [9:0]
0
F000h
2001h
GP12_FN [9:0]
0
F000h
2001h
GP11_FN [9:0]
0
F000h
2001h
GP10_FN [9:0]
0
F000h
2001h
GP9_FN [9:0]
0
F000h
2001h
GP8_FN [9:0]
0
F000h
2001h
GP7_FN [9:0]
0
F000h
2001h
GP6_FN [9:0]
0
F000h
2001h
GP5_FN [9:0]
0
F000h
2001h
GP4_FN [9:0]
0
F000h
2001h
GP3_FN [9:0]
0
F000h
2001h
GP2_FN [9:0]
0
Default
0000h
0
0
0
0
F000h
2001h
GP16_FN [9:0]
0
0
0
0
0
0
0
0
F000h
SYSCLK_
0
FAIL_
EINT1
FLL2_
FLL1_
LOCK_ LOCK_
EINT1
EINT1
BOOT_
DONE_
EINT1
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0000h
0
FLL1_
REF_
LOST_
EINT1
0
0
MICDET2_ MICDET1_
EINT1
EINT1
FLL2_
REF_
LOST_
EINT1
0
0
0
0
0
HPDET_
EINT1
0000h
0
0
JD2_
FALL_
EINT1
JD2_
RISE_
EINT1
JD1_
FALL_
EINT1
JD1_
RISE_
EINT1
0000h
0
JD3_
FALL_
EINT1
0
JD3_
RISE_
EINT1
MICD_
MICD_
CLAMP1_ CLAMP1_
FALL_
RISE_
EINT1
EINT1
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
Name
R6152 IRQ1_Status_9
(1808h)
15
14
13
12
11
10
0
0
0
0
0
0
9
8
R6154 IRQ1_Status_11
(180Ah)
DSP_
IRQ16_
EINT1
0
DSP_
IRQ15_
EINT1
0
DSP_
IRQ14_
EINT1
0
DSP_
IRQ13_
EINT1
0
DSP_
IRQ12_
EINT1
0
0
0
0
0
0
0
0
0
R6157 IRQ1_Status_14
(180Dh)
0
0
0
0
0
0
0
R6158 IRQ1_Status_15
(180Eh)
0
0
0
0
0
R6160 IRQ1_Status_17
(1810h)
R6164 IRQ1_Status_21
(1814h)
R6165 IRQ1_Status_22
(1815h)
GP16_
EINT1
GP15_
EINT1
GP12_
EINT1
0
0
0
0
0
0
0
R6166 IRQ1_Status_23
(1816h)
0
0
R6167 IRQ1_Status_24
(1817h)
0
R6168 IRQ1_Status_25
(1818h)
7
ASRC1_ ASRC1_
0
IN2_
IN1_
LOCK_ LOCK_
EINT1
EINT1
DSP_
DSP_
DSP_
DSP_
IRQ11_ IRQ10_
IRQ9_
IRQ8_
EINT1
EINT1
EINT1
EINT1
0
HP4R_ HP4L_SC_
0
SC_EINT1 EINT1
6
5
4
3
0
0
0
0
2
1
0
INPUTS_ DRC2_ DRC1_
SIG_DET_ SIG_DET_ SIG_DET_
EINT1
EINT1
EINT1
Default
0000h
DSP_
IRQ7_
EINT1
0
DSP_
DSP_
DSP_
DSP_
DSP_
DSP_
IRQ6_
IRQ5_
IRQ4_
IRQ3_
IRQ2_
IRQ1_
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
HP3R_ HP3L_SC_ HP2R_ HP2L_SC_ HP1R_ HP1L_SC_
SC_EINT1 EINT1 SC_EINT1 EINT1 SC_EINT1 EINT1
0000h
0
0
0000h
0
0
0
0
0
0
0
HP3R_
HP3L_
HP2R_
HP2L_
HP1R_
HP1L_
ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
HP3R_
HP3L_
HP2R_
HP2L_
HP1R_
HP1L_
DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
0
0
0
0
0
0
GP11_
EINT1
GP10_
EINT1
GP9_
EINT1
GP8_
EINT1
GP7_
EINT1
GP6_
EINT1
GP5_
EINT1
GP4_
EINT1
GP3_
EINT1
GP2_
EINT1
GP1_
EINT1
0000h
0
0
0
0
0
0
0
0
0
0
0
TIMER1_
EINT1
0000h
0
0
0
0
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6170 IRQ1_Status_27
(181Ah)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6171 IRQ1_Status_28
(181Bh)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6173 IRQ1_Status_30
(181Dh)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6176 IRQ1_Status_33
(1820h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6179 IRQ1_Status_36
(1823h)
0
0
0
0
0
0
0
0
0
0
0
0
R6183 IRQ1_Status_40
(1827h)
0
0
0
0
0
0
0
0
0
TIMER_
ALM1_
CH3_
EINT1
0
R6208 IRQ1_Mask_1
(1840h)
0
0
0
0
0
0
0
0
0
0
0
0
1200h
R6209 IRQ1_Mask_2
(1841h)
0
1
0
0
FLL2_
SYNC_
ACTIVE_
EINT1
IM_
SYSCLK_
FAIL_
EINT1
IM_FLL2_
LOCK_
EINT1
TIMER_
ALM1_
CH4_
EINT1
0
EVENT1_
NOT_
EMPTY_
EINT1
0
EVENT1_
FULL_
EINT1
0
EVENT1_
WMARK_
EINT1
0
DSP1_
DMA_
EINT1
0
DSP1_
START1_
EINT1
0
DSP1_
START2_
EINT1
0
DSP1_
BUSY_
EINT1
0
DSP1_
BUS_
ERR_
EINT1
TIMER_ TIMER_
ALM1_
ALM1_
CH2_
CH1_
EINT1
EINT1
0
0
0
0
0
0
0
77E0h
R6213 IRQ1_Mask_6
(1845h)
0
0
0
0
R6155 IRQ1_Status_12
(180Bh)
R6156 IRQ1_Status_13
(180Ch)
R6214 IRQ1_Mask_7
(1846h)
R6216 IRQ1_Mask_9
(1848h)
R6218 IRQ1_Mask_11
(184Ah)
R6219 IRQ1_Mask_12
(184Bh)
R6220 IRQ1_Mask_13
(184Ch)
DFC_
SATURAT
E_EINT1
GP14_
GP13_
EINT1
EINT1
IM_
CTRLIF_
ERR_
EINT1
IM_CLK_ IM_CLK_
ASYNC_ SYS_
ERR_
ERR_
EINT1
EINT1
0
0
FLL1_
0
SYNC_
ACTIVE_
EINT1
0
IM_BOOT_
DONE_
EINT1
IM_FLL1_
LOCK_
EINT1
0
IM_FLL2_ IM_FLL1_
REF_
REF_
LOST_
LOST_
EINT1
EINT1
0
0
IM_
IM_
0
0
0
0
0
IM_
MICDET2_ MICDET1_
HPDET_
EINT1
EINT1
EINT1
0
0
0
0
IM_MICD_ IM_MICD_ IM_JD3_ IM_JD3_
0
0
IM_MICD_ IM_MICD_ IM_JD2_ IM_JD2_ IM_JD1_ IM_JD1_
CLAMP2_ CLAMP2_ FALL_
RISE_
CLAMP1_ CLAMP1_ FALL_
RISE_
FALL_
RISE_
FALL_
RISE_
EINT1
EINT1
FALL_
RISE_
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
0
0
0
0
0
0
IM_
IM_
0
0
0
1
1
IM_ IM_DRC2_ IM_DRC1_
ASRC1_ ASRC1_
INPUTS_ SIG_DET_ SIG_DET_
IN2_
IN1_
SIG_DET_ EINT1
EINT1
LOCK_ LOCK_
EINT1
EINT1
EINT1
IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_
IRQ16_ IRQ15_ IRQ14_ IRQ13_ IRQ12_ IRQ11_ IRQ10_
IRQ9_
IRQ8_
IRQ7_
IRQ6_
IRQ5_
IRQ4_
IRQ3_
IRQ2_
IRQ1_
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
0
0
0
0
0
0
IM_HP4R_ IM_HP4L_
0
0
IM_HP3R_ IM_HP3L_ IM_HP2R_ IM_HP2L_ IM_HP1R_ IM_HP1L_
SC_EINT1 SC_EINT1
SC_EINT1 SC_EINT1 SC_EINT1 SC_EINT1 SC_EINT1 SC_EINT1
0
0
0
0
0
0
0
0
0
0
R6221 IRQ1_Mask_14
(184Dh)
0
0
0
0
0
0
0
0
0
0
R6222 IRQ1_Mask_15
(184Eh)
0
0
0
IM_DFC_
SATURAT
E_EINT1
0
0
0
0
0
0
DS1162F1
IM_HP3R_ IM_HP3L_ IM_HP2R_ IM_HP2L_ IM_HP1R_ IM_HP1L_
ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
IM_HP3R_ IM_HP3L_ IM_HP2R_ IM_HP2L_ IM_HP1R_ IM_HP1L_
DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
0
0
0
0
0
0
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0301h
0F3Fh
031Fh
FFFFh
033Fh
003Fh
003Fh
1000h
307
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
Name
R6224 IRQ1_Mask_17
(1850h)
R6228 IRQ1_Mask_21
(1854h)
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
IM_GP16_ IM_GP15_ IM_GP14_ IM_GP13_ IM_GP12_ IM_GP11_ IM_GP10_ IM_GP9_ IM_GP8_ IM_GP7_ IM_GP6_ IM_GP5_ IM_GP4_ IM_GP3_ IM_GP2_ IM_GP1_
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
EINT1
0
0
0
0
0
0
0
0
0
0
0
0
0
R6229 IRQ1_Mask_22
(1855h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6230 IRQ1_Mask_23
(1856h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6231 IRQ1_Mask_24
(1857h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6232 IRQ1_Mask_25
(1858h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6234 IRQ1_Mask_27
(185Ah)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6235 IRQ1_Mask_28
(185Bh)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6237 IRQ1_Mask_30
(185Dh)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6240 IRQ1_Mask_33
(1860h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6243 IRQ1_Mask_36
(1863h)
0
0
0
0
0
0
0
0
0
0
0
0
R6247 IRQ1_Mask_40
(1867h)
0
0
0
0
0
0
0
0
0
IM_
TIMER_
ALM1_
CH4_
EINT1
0
IM_
TIMER_
ALM1_
CH3_
EINT1
0
R6272 IRQ1_Raw_Status_1
(1880h)
0
0
0
0
0
0
0
0
0
0
0
0
0000h
R6273 IRQ1_Raw_Status_2
(1881h)
0
0
0
0
0
0
0
0
0
0000h
R6278 IRQ1_Raw_Status_7
(1886h)
0
0
0
0
FLL1_
REF_
LOST_
STS1
0
0
JD2_STS1
0
JD1_STS1
0000h
R6280 IRQ1_Raw_Status_9
(1888h)
0
0
0
0
0
0
0
MICD_
CLAMP_
STS1
0
0
INPUTS_ DRC2_ DRC1_
SIG_DET_ SIG_DET_ SIG_DET_
STS1
STS1
STS1
0000h
R6283 IRQ1_Raw_Status_12
(188Bh)
R6284 IRQ1_Raw_Status_13
(188Ch)
0
0
0
0
0
0
HP3R_ HP3L_SC_ HP2R_ HP2L_SC_ HP1R_ HP1L_SC_
SC_STS1 STS1 SC_STS1 STS1 SC_STS1 STS1
0000h
0
0
0
0
0
0
0000h
R6285 IRQ1_Raw_Status_14
(188Dh)
0
0
0
0
0
0
R6288 IRQ1_Raw_Status_17
(1890h)
R6292 IRQ1_Raw_Status_21
(1894h)
R6293 IRQ1_Raw_Status_22
(1895h)
GP16_
STS1
GP15_
STS1
GP14_
STS1
GP13_
STS1
GP12_
STS1
GP11_
STS1
HP3R_
HP3L_
HP2R_
HP2L_
HP1R_
HP1L_
ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
STS1
STS1
STS1
STS1
STS1
STS1
0
0
0
0
HP3R_
HP3L_
HP2R_
HP2L_
HP1R_
HP1L_
DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
STS1
STS1
STS1
STS1
STS1
STS1
GP10_ GP9_STS1GP8_STS1GP7_STS1GP6_STS1GP5_STS1GP4_STS1GP3_STS1GP2_STS1GP1_STS1
STS1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6294 IRQ1_Raw_Status_23
(1896h)
0
0
0
0
0
0
0
0
0
0
0
0
R6295 IRQ1_Raw_Status_24
(1897h)
0
0
0
0
0
0
0
0
0
0
0
0
R6296 IRQ1_Raw_Status_25
(1898h)
0
0
0
0
0
0
0
0
0
0
0
0
R6301 IRQ1_Raw_Status_30
(189Dh)
0
0
0
0
0
0
0
0
0
0
0
0
R6304 IRQ1_Raw_Status_33
(18A0h)
0
0
0
0
0
0
0
0
0
0
0
0
R6307 IRQ1_Raw_Status_36
(18A3h)
0
0
0
0
0
0
0
0
0
0
0
0
308
CTRLIF_
ERR_
STS1
CLK_ CLK_SYS_
ASYNC_ ERR_
ERR_
STS1
STS1
0
0
JD3_STS1
0
FLL2_
REF_
LOST_
STS1
0
ASRC1_ ASRC1_
IN2_
IN1_
LOCK_ LOCK_
STS1
STS1
HP4R_ HP4L_SC_
SC_STS1 STS1
0
0
0
0
0
0
0
0
0
IM_
TIMER1_
EINT1
0
IM_
EVENT1_
NOT_
EMPTY_
EINT1
0
IM_
EVENT1_
FULL_
EINT1
0
IM_
EVENT1_
WMARK_
EINT1
0
IM_DSP1_
DMA_
EINT1
0
IM_DSP1_
START1_
EINT1
0
IM_DSP1_
START2_
EINT1
0
IM_DSP1_
BUSY_
EINT1
0
IM_DSP1_
BUS_
ERR_
EINT1
IM_
IM_
TIMER_ TIMER_
ALM1_
ALM1_
CH2_
CH1_
EINT1
EINT1
0
0
0001h
0
IM_FLL2_ IM_FLL1_
0
SYNC_ SYNC_
ACTIVE_ ACTIVE_
EINT1
EINT1
0
0
BOOT_
DONE_
STS1
FLL2_
FLL1_
0
LOCK_ LOCK_
STS1
STS1
0
Default
FFFFh
TIMER1_
STS1
EVENT1_
NOT_
EMPTY_
STS1
0
0
0
EVENT1_
FULL_
STS1
0
0
0
EVENT1_
WMARK_
STS1
0
0
0
DSP1_
DMA_
STS1
0
0
0
DSP1_
BUSY_
STS1
0
0
0
DSP1_
BUS_
ERR_
STS1
TIMER_ TIMER_ TIMER_ TIMER_
ALM1_
ALM1_
ALM1_
ALM1_
CH4_STS1CH3_STS1CH2_STS1CH1_STS1
0001h
0001h
0001h
0001h
0001h
0001h
0001h
0001h
000Fh
0300h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
Name
R6311 IRQ1_Raw_Status_40
(18A7h)
15
14
13
12
11
10
0
0
0
0
0
0
R6400 IRQ2_Status_1
(1900h)
0
0
0
0
0
R6401 IRQ2_Status_2
(1901h)
0
0
0
0
R6405 IRQ2_Status_6
(1905h)
R6406 IRQ2_Status_7
(1906h)
0
0
0
0
0
0
0
0
0
0
R6408 IRQ2_Status_9
(1908h)
0
0
0
0
0
0
R6410 IRQ2_Status_11
(190Ah)
DSP_
IRQ16_
EINT2
0
DSP_
IRQ15_
EINT2
0
DSP_
IRQ14_
EINT2
0
DSP_
IRQ13_
EINT2
0
DSP_
IRQ12_
EINT2
0
0
0
0
0
0
0
0
0
R6413 IRQ2_Status_14
(190Dh)
0
0
0
0
0
0
0
R6414 IRQ2_Status_15
(190Eh)
0
0
0
0
0
R6416 IRQ2_Status_17
(1910h)
R6420 IRQ2_Status_21
(1914h)
R6421 IRQ2_Status_22
(1915h)
GP16_
EINT2
GP15_
EINT2
GP12_
EINT2
0
0
0
0
0
0
0
R6422 IRQ2_Status_23
(1916h)
0
0
R6423 IRQ2_Status_24
(1917h)
0
R6424 IRQ2_Status_25
(1918h)
CTRLIF_
ERR_
EINT2
CLK_ CLK_SYS_
ASYNC_ ERR_
ERR_
EINT2
EINT2
0
0
9
8
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
Default
0000h
0
0
0
0
0
0
0
0000h
FLL1_
REF_
LOST_
EINT2
0
0
0
0
0
0
0000h
0
FLL2_
REF_
LOST_
EINT2
0
0
0
0
0
HPDET_
EINT2
0000h
0
0
JD2_
FALL_
EINT2
JD2_
RISE_
EINT2
JD1_
FALL_
EINT2
JD1_
RISE_
EINT2
0000h
FLL2_
FLL1_
0
SYNC_ SYNC_
ACTIVE_ ACTIVE_
STS1
STS1
SYSCLK_
0
BOOT_
FAIL_
DONE_
EINT2
EINT2
FLL2_
FLL1_
0
LOCK_ LOCK_
EINT2
EINT2
MICDET2_ MICDET1_
EINT2
EINT2
JD3_
FALL_
EINT2
JD3_
RISE_
EINT2
MICD_
MICD_
CLAMP_ CLAMP_
FALL_
RISE_
EINT2
EINT2
0
0
INPUTS_ DRC2_ DRC1_
SIG_DET_ SIG_DET_ SIG_DET_
EINT2
EINT2
EINT2
0000h
DSP_
IRQ7_
EINT2
0
DSP_
DSP_
DSP_
DSP_
DSP_
DSP_
IRQ6_
IRQ5_
IRQ4_
IRQ3_
IRQ2_
IRQ1_
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
HP3R_ HP3L_SC_ HP2R_ HP2L_SC_ HP1R_ HP1L_SC_
SC_EINT2 EINT2 SC_EINT2 EINT2 SC_EINT2 EINT2
0000h
0
0
0000h
0
0
0
0
0
0
0
HP3R_
HP3L_
HP2R_
HP2L_
HP1R_
HP1L_
ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
HP3R_
HP3L_
HP2R_
HP2L_
HP1R_
HP1L_
DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
0
0
0
0
0
0
GP11_
EINT2
GP10_
EINT2
GP9_
EINT2
GP8_
EINT2
GP7_
EINT2
GP6_
EINT2
GP5_
EINT2
GP4_
EINT2
GP3_
EINT2
GP2_
EINT2
GP1_
EINT2
0000h
0
0
0
0
0
0
0
0
0
0
0
TIMER1_
EINT2
0000h
0
0
0
0
0
0
0
0
0
0
0
0
0000h
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6426 IRQ2_Status_27
(191Ah)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6427 IRQ2_Status_28
(191Bh)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6429 IRQ2_Status_30
(191Dh)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6432 IRQ2_Status_33
(1920h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6435 IRQ2_Status_36
(1923h)
0
0
0
0
0
0
0
0
0
0
0
0
R6439 IRQ2_Status_40
(1927h)
0
0
0
0
0
0
0
0
0
TIMER_
ALM1_
CH3_
EINT2
0
R6464 IRQ2_Mask_1
(1940h)
0
0
0
0
0
0
0
0
0
0
0
0
1280h
R6465 IRQ2_Mask_2
(1941h)
0
1
0
0
FLL2_
SYNC_
ACTIVE_
EINT2
IM_
SYSCLK_
FAIL_
EINT2
IM_FLL2_
LOCK_
EINT2
TIMER_
ALM1_
CH4_
EINT2
0
EVENT1_
NOT_
EMPTY_
EINT2
0
EVENT1_
FULL_
EINT2
0
EVENT1_
WMARK_
EINT2
0
DSP1_
DMA_
EINT2
0
DSP1_
START1_
EINT2
0
DSP1_
START2_
EINT2
0
DSP1_
BUSY_
EINT2
0
DSP1_
BUS_
ERR_
EINT2
TIMER_ TIMER_
ALM1_
ALM1_
CH2_
CH1_
EINT2
EINT2
0
0
0
0
0
0
0
77E0h
R6469 IRQ2_Mask_6
(1945h)
0
0
0
0
0
0
0
0
R6470 IRQ2_Mask_7
(1946h)
0
0
0
0
R6411 IRQ2_Status_12
(190Bh)
R6412 IRQ2_Status_13
(190Ch)
DS1162F1
DFC_
SATURAT
E_EINT2
GP14_
GP13_
EINT2
EINT2
IM_
CTRLIF_
ERR_
EINT2
IM_CLK_ IM_CLK_
ASYNC_ SYS_
ERR_
ERR_
EINT2
EINT2
0
0
0
0
ASRC1_ ASRC1_
0
IN2_
IN1_
LOCK_ LOCK_
EINT2
EINT2
DSP_
DSP_
DSP_
DSP_
IRQ11_ IRQ10_
IRQ9_
IRQ8_
EINT2
EINT2
EINT2
EINT2
0
HP4R_ HP4L_SC_
0
SC_EINT2 EINT2
FLL1_
0
SYNC_
ACTIVE_
EINT2
0
IM_BOOT_
DONE_
EINT2
IM_FLL1_
LOCK_
EINT2
0
IM_
IM_
MICDET2_ MICDET1_
EINT2
EINT2
IM_JD3_ IM_JD3_
FALL_
RISE_
EINT2
EINT2
0
0
0
IM_FLL2_ IM_FLL1_
REF_
REF_
LOST_
LOST_
EINT2
EINT2
0
0
0
0
IM_
HPDET_
EINT2
IM_MICD_ IM_MICD_ IM_JD2_ IM_JD2_ IM_JD1_ IM_JD1_
CLAMP_ CLAMP_ FALL_
RISE_
FALL_
RISE_
FALL_
RISE_
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0301h
033Fh
309
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
Name
R6472 IRQ2_Mask_9
(1948h)
R6474 IRQ2_Mask_11
(194Ah)
R6475 IRQ2_Mask_12
(194Bh)
R6476 IRQ2_Mask_13
(194Ch)
15
14
13
12
11
10
0
0
0
0
0
0
9
8
7
6
0
0
0
0
0
0
0
0
0
0
R6477 IRQ2_Mask_14
(194Dh)
0
0
0
0
0
0
0
0
0
0
R6478 IRQ2_Mask_15
(194Eh)
0
0
0
R6480 IRQ2_Mask_17
(1950h)
R6484 IRQ2_Mask_21
(1954h)
5
4
3
2
1
0
IM_
IM_
0
0
0
1
1
IM_ IM_DRC2_ IM_DRC1_
ASRC1_ ASRC1_
INPUTS_ SIG_DET_ SIG_DET_
IN2_
IN1_
SIG_DET_ EINT2
EINT2
LOCK_ LOCK_
EINT2
EINT2
EINT2
IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_ IM_DSP_
IRQ16_ IRQ15_ IRQ14_ IRQ13_ IRQ12_ IRQ11_ IRQ10_
IRQ9_
IRQ8_
IRQ7_
IRQ6_
IRQ5_
IRQ4_
IRQ3_
IRQ2_
IRQ1_
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
0
0
0
0
0
0
IM_HP4R_ IM_HP4L_
0
0
IM_HP3R_ IM_HP3L_ IM_HP2R_ IM_HP2L_ IM_HP1R_ IM_HP1L_
SC_EINT2 SC_EINT2
SC_EINT2 SC_EINT2 SC_EINT2 SC_EINT2 SC_EINT2 SC_EINT2
IM_HP3R_ IM_HP3L_ IM_HP2R_ IM_HP2L_ IM_HP1R_ IM_HP1L_
ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
IM_HP3R_ IM_HP3L_ IM_HP2R_ IM_HP2L_ IM_HP1R_ IM_HP1L_
DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
0
0
0
0
0
0
IM_DFC_
0
0
0
0
0
0
SATURAT
E_EINT2
IM_GP16_ IM_GP15_ IM_GP14_ IM_GP13_ IM_GP12_ IM_GP11_ IM_GP10_ IM_GP9_ IM_GP8_ IM_GP7_ IM_GP6_ IM_GP5_ IM_GP4_ IM_GP3_ IM_GP2_ IM_GP1_
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
EINT2
033Fh
003Fh
003Fh
1000h
FFFFh
0001h
0
0
0
0
0
0
0
0
0
0
0
0
0
R6485 IRQ2_Mask_22
(1955h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6486 IRQ2_Mask_23
(1956h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6487 IRQ2_Mask_24
(1957h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6488 IRQ2_Mask_25
(1958h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6490 IRQ2_Mask_27
(195Ah)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6491 IRQ2_Mask_28
(195Bh)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6493 IRQ2_Mask_30
(195Dh)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6496 IRQ2_Mask_33
(1960h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6499 IRQ2_Mask_36
(1963h)
0
0
0
0
0
0
0
0
0
0
0
0
R6503 IRQ2_Mask_40
(1967h)
0
0
0
0
0
0
0
0
0
IM_
TIMER_
ALM1_
CH4_
EINT2
0
IM_
TIMER_
ALM1_
CH3_
EINT2
0
R6528 IRQ2_Raw_Status_1
(1980h)
0
0
0
0
0
0
0
0
0
0
0
0
0000h
R6529 IRQ2_Raw_Status_2
(1981h)
0
0
0
0
0
0
0
0
0
0000h
R6534 IRQ2_Raw_Status_7
(1986h)
0
0
0
0
FLL1_
REF_
LOST_
STS2
0
0
JD2_STS2
0
JD1_STS2
0000h
R6536 IRQ2_Raw_Status_9
(1988h)
0
0
0
0
0
0
0
MICD_
CLAMP_
STS2
0
0
INPUTS_ DRC2_ DRC1_
SIG_DET_ SIG_DET_ SIG_DET_
STS2
STS2
STS2
0000h
R6539 IRQ2_Raw_Status_12
(198Bh)
R6540 IRQ2_Raw_Status_13
(198Ch)
0
0
0
0
0
0
HP3R_ HP3L_SC_ HP2R_ HP2L_SC_ HP1R_ HP1L_SC_
SC_STS2 STS2 SC_STS2 STS2 SC_STS2 STS2
0000h
0
0
0
0
0
0
0000h
R6541 IRQ2_Raw_Status_14
(198Dh)
0
0
0
0
0
0
R6544 IRQ2_Raw_Status_17
(1990h)
R6548 IRQ2_Raw_Status_21
(1994h)
GP16_
STS2
GP15_
STS2
GP14_
STS2
GP13_
STS2
GP12_
STS2
GP11_
STS2
HP3R_
HP3L_
HP2R_
HP2L_
HP1R_
HP1L_
ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_ ENABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
STS2
STS2
STS2
STS2
STS2
STS2
0
0
0
0
HP3R_
HP3L_
HP2R_
HP2L_
HP1R_
HP1L_
DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_ DISABLE_
DONE_ DONE_ DONE_ DONE_ DONE_ DONE_
STS2
STS2
STS2
STS2
STS2
STS2
GP10_ GP9_STS2GP8_STS2GP7_STS2GP6_STS2GP5_STS2GP4_STS2GP3_STS2GP2_STS2GP1_STS2
STS2
0
0
0
0
0
0
310
CTRLIF_
ERR_
STS2
CLK_ CLK_SYS_
ASYNC_ ERR_
ERR_
STS2
STS2
0
0
JD3_STS2
0
FLL2_
REF_
LOST_
STS2
0
ASRC1_ ASRC1_
IN2_
IN1_
LOCK_ LOCK_
STS2
STS2
HP4R_ HP4L_SC_
SC_STS2 STS2
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
IM_
TIMER1_
EINT2
0
IM_
EVENT1_
NOT_
EMPTY_
EINT2
0
IM_
EVENT1_
FULL_
EINT2
0
IM_
EVENT1_
WMARK_
EINT2
0
IM_DSP1_
DMA_
EINT2
0
IM_DSP1_
START1_
EINT2
0
IM_DSP1_
START2_
EINT2
0
IM_DSP1_
BUSY_
EINT2
0
IM_DSP1_
BUS_
ERR_
EINT2
IM_
IM_
TIMER_ TIMER_
ALM1_
ALM1_
CH2_
CH1_
EINT2
EINT2
0
0
FFFFh
0
IM_FLL2_ IM_FLL1_
0
SYNC_ SYNC_
ACTIVE_ ACTIVE_
EINT2
EINT2
0
0
BOOT_
DONE_
STS2
FLL2_
FLL1_
0
LOCK_ LOCK_
STS2
STS2
0
Default
031Fh
0
TIMER1_
STS2
0001h
0001h
0001h
0001h
0001h
0001h
0001h
0001h
000Fh
0300h
0000h
0000h
0000h
DS1162F1
CS42L92
6 Register Map
Table 6-1. Register Map Definition—16-bit region (Cont.)
Register
Name
R6549 IRQ2_Raw_Status_22
(1995h)
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R6550 IRQ2_Raw_Status_23
(1996h)
0
0
0
0
0
0
0
0
0
0
0
0
R6551 IRQ2_Raw_Status_24
(1997h)
0
0
0
0
0
0
0
0
0
0
0
0
R6552 IRQ2_Raw_Status_25
(1998h)
0
0
0
0
0
0
0
0
0
0
0
0
R6557 IRQ2_Raw_Status_30
(199Dh)
0
0
0
0
0
0
0
0
0
0
0
0
R6560 IRQ2_Raw_Status_33
(19A0h)
0
0
0
0
0
0
0
0
0
0
0
0
R6563 IRQ2_Raw_Status_36
(19A3h)
0
0
0
0
0
0
0
0
0
0
0
0
R6567 IRQ2_Raw_Status_40
(19A7h)
0
0
0
0
0
0
0
0
0
0
R6662 Interrupt_Debounce_7
(1A06h)
0
0
0
0
0
0
0
0
0
0
JD2_DB
0
JD1_DB
0000h
R6784
(1A80h)
R6786
(1A82h)
R6816
(1AA0h)
R6848
(1AC0h)
R6864
(1AD0h)
IRQ1_CTRL
0
1
0
0
IM_IRQ1 IRQ_POL IRQ_OP_
CFG
0
0
0
0
MICD_
CLAMP_
DB
0
0
0
0
0
4400h
IRQ2_CTRL
0
0
0
0
IM_IRQ2
0
0
0
0
0
0
0
0
0
0
0
0000h
Interrupt_Raw_Status_1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
GPIO_Debounce_Config
0
0
0
0
0
0
0
0
0
0
0
0
AOD_Pad_Ctrl
0
1
0
0
0
0
0
0
0
0
0
0
0
0
20
4
19
3
18
2
FLL2_
FLL1_
SYNC_ SYNC_
ACTIVE_ ACTIVE_
STS2
STS2
0
JD3_DB
0
EVENT1_
NOT_
EMPTY_
STS2
0
0
0
EVENT1_
FULL_
STS2
0
0
0
EVENT1_
WMARK_
STS2
0
0
0
DSP1_
DMA_
STS2
0
0
0
DSP1_
BUSY_
STS2
0
0
0
DSP1_
BUS_
ERR_
STS2
TIMER_ TIMER_ TIMER_ TIMER_
ALM1_
ALM1_
ALM1_
ALM1_
CH4_STS2CH3_STS2CH2_STS2CH1_STS2
0
0
0
0
IRQ2_STS IRQ1_STS
Default
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
0000h
GP_DBTIME [3:0]
RESET_ RESET_
PU
PD
4002h
The 32-bit register space is described in Table 6-2.
Table 6-2. Register Map Definition—32-bit region
Register
Name
R12288 WSEQ_Sequence_1
(3000h)
R12290 WSEQ_Sequence_2
(3002h)
R12292 WSEQ_Sequence_3
(3004h)
R12294 WSEQ_Sequence_4
(3006h)
R12296 WSEQ_Sequence_5
(3008h)
R12298 WSEQ_Sequence_6
(300Ah)
R12300 WSEQ_Sequence_7
(300Ch)
R12302 WSEQ_Sequence_8
(300Eh)
R12304 WSEQ_Sequence_9
(3010h)
R12306 WSEQ_Sequence_10
(3012h)
R12308 WSEQ_Sequence_11
(3014h)
R12310 WSEQ_Sequence_12
(3016h)
R12312 WSEQ_Sequence_13
(3018h)
R12314 WSEQ_Sequence_14
(301Ah)
R12316 WSEQ_Sequence_15
(301Ch)
R12318 WSEQ_Sequence_16
(301Eh)
DS1162F1
31
15
30
14
29
13
WSEQ_DATA_WIDTH0 [2:0]
WSEQ_DELAY0 [3:0]
WSEQ_DATA_WIDTH1 [2:0]
WSEQ_DELAY1 [3:0]
WSEQ_DATA_WIDTH2 [2:0]
WSEQ_DELAY2 [3:0]
WSEQ_DATA_WIDTH3 [2:0]
WSEQ_DELAY3 [3:0]
WSEQ_DATA_WIDTH4 [2:0]
WSEQ_DELAY4 [3:0]
WSEQ_DATA_WIDTH5 [2:0]
WSEQ_DELAY5 [3:0]
WSEQ_DATA_WIDTH6 [2:0]
WSEQ_DELAY6 [3:0]
WSEQ_DATA_WIDTH7 [2:0]
WSEQ_DELAY7 [3:0]
WSEQ_DATA_WIDTH8 [2:0]
WSEQ_DELAY8 [3:0]
WSEQ_DATA_WIDTH9 [2:0]
WSEQ_DELAY9 [3:0]
WSEQ_DATA_WIDTH10 [2:0]
WSEQ_DELAY10 [3:0]
WSEQ_DATA_WIDTH11 [2:0]
WSEQ_DELAY11 [3:0]
WSEQ_DATA_WIDTH12 [2:0]
WSEQ_DELAY12 [3:0]
WSEQ_DATA_WIDTH13 [2:0]
WSEQ_DELAY13 [3:0]
WSEQ_DATA_WIDTH14 [2:0]
WSEQ_DELAY14 [3:0]
WSEQ_DATA_WIDTH15 [2:0]
WSEQ_DELAY15 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
Default
WSEQ_DATA0 [7:0]
0000F000h
WSEQ_ADDR1 [12:0]
WSEQ_DATA_START1 [3:0]
WSEQ_DATA1 [7:0]
0000F000h
WSEQ_ADDR2 [12:0]
WSEQ_DATA_START2 [3:0]
WSEQ_DATA2 [7:0]
0000F000h
WSEQ_ADDR3 [12:0]
WSEQ_DATA_START3 [3:0]
WSEQ_DATA3 [7:0]
82253719h
WSEQ_ADDR4 [12:0]
WSEQ_DATA_START4 [3:0]
WSEQ_DATA4 [7:0]
C2300001h
WSEQ_ADDR5 [12:0]
WSEQ_DATA_START5 [3:0]
WSEQ_DATA5 [7:0]
02251301h
WSEQ_ADDR6 [12:0]
WSEQ_DATA_START6 [3:0]
WSEQ_DATA6 [7:0]
8225191Fh
WSEQ_ADDR7 [12:0]
WSEQ_DATA_START7 [3:0]
WSEQ_DATA7 [7:0]
82310B00h
WSEQ_ADDR8 [12:0]
WSEQ_DATA_START8 [3:0]
WSEQ_DATA8 [7:0]
E231023Bh
WSEQ_ADDR9 [12:0]
WSEQ_DATA_START9 [3:0]
WSEQ_DATA9 [7:0]
02313B01h
WSEQ_ADDR10 [12:0]
WSEQ_DATA_START10 [3:0]
WSEQ_DATA10 [7:0]
62300000h
WSEQ_ADDR11 [12:0]
WSEQ_DATA_START11 [3:0]
WSEQ_DATA11 [7:0]
E2314288h
WSEQ_ADDR12 [12:0]
WSEQ_DATA_START12 [3:0]
WSEQ_DATA12 [7:0]
02310B00h
WSEQ_ADDR13 [12:0]
WSEQ_DATA_START13 [3:0]
WSEQ_DATA13 [7:0]
02310B00h
WSEQ_ADDR14 [12:0]
WSEQ_DATA_START14 [3:0]
WSEQ_DATA14 [7:0]
02250E01h
WSEQ_ADDR15 [12:0]
WSEQ_DATA_START15 [3:0]
16
0
0000F000h
WSEQ_ADDR0 [12:0]
WSEQ_DATA_START0 [3:0]
17
1
WSEQ_DATA15 [7:0]
311
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12320 WSEQ_Sequence_17
(3020h)
R12322 WSEQ_Sequence_18
(3022h)
R12324 WSEQ_Sequence_19
(3024h)
R12326 WSEQ_Sequence_20
(3026h)
R12328 WSEQ_Sequence_21
(3028h)
R12330 WSEQ_Sequence_22
(302Ah)
R12332 WSEQ_Sequence_23
(302Ch)
R12334 WSEQ_Sequence_24
(302Eh)
R12336 WSEQ_Sequence_25
(3030h)
R12338 WSEQ_Sequence_26
(3032h)
R12340 WSEQ_Sequence_27
(3034h)
R12342 WSEQ_Sequence_28
(3036h)
R12344 WSEQ_Sequence_29
(3038h)
R12346 WSEQ_Sequence_30
(303Ah)
R12348 WSEQ_Sequence_31
(303Ch)
R12350 WSEQ_Sequence_32
(303Eh)
R12352 WSEQ_Sequence_33
(3040h)
R12354 WSEQ_Sequence_34
(3042h)
R12356 WSEQ_Sequence_35
(3044h)
R12358 WSEQ_Sequence_36
(3046h)
R12360 WSEQ_Sequence_37
(3048h)
R12362 WSEQ_Sequence_38
(304Ah)
R12364 WSEQ_Sequence_39
(304Ch)
R12366 WSEQ_Sequence_40
(304Eh)
R12368 WSEQ_Sequence_41
(3050h)
R12370 WSEQ_Sequence_42
(3052h)
R12372 WSEQ_Sequence_43
(3054h)
R12374 WSEQ_Sequence_44
(3056h)
R12376 WSEQ_Sequence_45
(3058h)
R12378 WSEQ_Sequence_46
(305Ah)
R12380 WSEQ_Sequence_47
(305Ch)
R12382 WSEQ_Sequence_48
(305Eh)
R12384 WSEQ_Sequence_49
(3060h)
R12386 WSEQ_Sequence_50
(3062h)
R12388 WSEQ_Sequence_51
(3064h)
R12390 WSEQ_Sequence_52
(3066h)
312
31
15
30
14
29
13
WSEQ_DATA_WIDTH16 [2:0]
WSEQ_DELAY16 [3:0]
WSEQ_DATA_WIDTH17 [2:0]
WSEQ_DELAY17 [3:0]
WSEQ_DATA_WIDTH18 [2:0]
WSEQ_DELAY18 [3:0]
WSEQ_DATA_WIDTH19 [2:0]
WSEQ_DELAY19 [3:0]
WSEQ_DATA_WIDTH20 [2:0]
WSEQ_DELAY20 [3:0]
WSEQ_DATA_WIDTH21 [2:0]
WSEQ_DELAY21 [3:0]
WSEQ_DATA_WIDTH22 [2:0]
WSEQ_DELAY22 [3:0]
WSEQ_DATA_WIDTH23 [2:0]
WSEQ_DELAY23 [3:0]
WSEQ_DATA_WIDTH24 [2:0]
WSEQ_DELAY24 [3:0]
WSEQ_DATA_WIDTH25 [2:0]
WSEQ_DELAY25 [3:0]
WSEQ_DATA_WIDTH26 [2:0]
WSEQ_DELAY26 [3:0]
WSEQ_DATA_WIDTH27 [2:0]
WSEQ_DELAY27 [3:0]
WSEQ_DATA_WIDTH28 [2:0]
WSEQ_DELAY28 [3:0]
WSEQ_DATA_WIDTH29 [2:0]
WSEQ_DELAY29 [3:0]
WSEQ_DATA_WIDTH30 [2:0]
WSEQ_DELAY30 [3:0]
WSEQ_DATA_WIDTH31 [2:0]
WSEQ_DELAY31 [3:0]
WSEQ_DATA_WIDTH32 [2:0]
WSEQ_DELAY32 [3:0]
WSEQ_DATA_WIDTH33 [2:0]
WSEQ_DELAY33 [3:0]
WSEQ_DATA_WIDTH34 [2:0]
WSEQ_DELAY34 [3:0]
WSEQ_DATA_WIDTH35 [2:0]
WSEQ_DELAY35 [3:0]
WSEQ_DATA_WIDTH36 [2:0]
WSEQ_DELAY36 [3:0]
WSEQ_DATA_WIDTH37 [2:0]
WSEQ_DELAY37 [3:0]
WSEQ_DATA_WIDTH38 [2:0]
WSEQ_DELAY38 [3:0]
WSEQ_DATA_WIDTH39 [2:0]
WSEQ_DELAY39 [3:0]
WSEQ_DATA_WIDTH40 [2:0]
WSEQ_DELAY40 [3:0]
WSEQ_DATA_WIDTH41 [2:0]
WSEQ_DELAY41 [3:0]
WSEQ_DATA_WIDTH42 [2:0]
WSEQ_DELAY42 [3:0]
WSEQ_DATA_WIDTH43 [2:0]
WSEQ_DELAY43 [3:0]
WSEQ_DATA_WIDTH44 [2:0]
WSEQ_DELAY44 [3:0]
WSEQ_DATA_WIDTH45 [2:0]
WSEQ_DELAY45 [3:0]
WSEQ_DATA_WIDTH46 [2:0]
WSEQ_DELAY46 [3:0]
WSEQ_DATA_WIDTH47 [2:0]
WSEQ_DELAY47 [3:0]
WSEQ_DATA_WIDTH48 [2:0]
WSEQ_DELAY48 [3:0]
WSEQ_DATA_WIDTH49 [2:0]
WSEQ_DELAY49 [3:0]
WSEQ_DATA_WIDTH50 [2:0]
WSEQ_DELAY50 [3:0]
WSEQ_DATA_WIDTH51 [2:0]
WSEQ_DELAY51 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA16 [7:0]
E2310227h
WSEQ_ADDR17 [12:0]
WSEQ_DATA_START17 [3:0]
WSEQ_DATA17 [7:0]
02313B01h
WSEQ_ADDR18 [12:0]
WSEQ_DATA_START18 [3:0]
WSEQ_DATA18 [7:0]
E2314266h
WSEQ_ADDR19 [12:0]
WSEQ_DATA_START19 [3:0]
WSEQ_DATA19 [7:0]
E2315294h
WSEQ_ADDR20 [12:0]
WSEQ_DATA_START20 [3:0]
WSEQ_DATA20 [7:0]
02310B00h
WSEQ_ADDR21 [12:0]
WSEQ_DATA_START21 [3:0]
WSEQ_DATA21 [7:0]
02310B00h
WSEQ_ADDR22 [12:0]
WSEQ_DATA_START22 [3:0]
WSEQ_DATA22 [7:0]
E2251734h
WSEQ_ADDR23 [12:0]
WSEQ_DATA_START23 [3:0]
WSEQ_DATA23 [7:0]
0225F501h
WSEQ_ADDR24 [12:0]
WSEQ_DATA_START24 [3:0]
WSEQ_DATA24 [7:0]
0000F000h
WSEQ_ADDR25 [12:0]
WSEQ_DATA_START25 [3:0]
WSEQ_DATA25 [7:0]
0000F000h
WSEQ_ADDR26 [12:0]
WSEQ_DATA_START26 [3:0]
WSEQ_DATA26 [7:0]
0000F000h
WSEQ_ADDR27 [12:0]
WSEQ_DATA_START27 [3:0]
WSEQ_DATA27 [7:0]
0000F000h
WSEQ_ADDR28 [12:0]
WSEQ_DATA_START28 [3:0]
WSEQ_DATA28 [7:0]
0000F000h
WSEQ_ADDR29 [12:0]
WSEQ_DATA_START29 [3:0]
WSEQ_DATA29 [7:0]
0000F000h
WSEQ_ADDR30 [12:0]
WSEQ_DATA_START30 [3:0]
WSEQ_DATA30 [7:0]
02253A01h
WSEQ_ADDR31 [12:0]
WSEQ_DATA_START31 [3:0]
WSEQ_DATA31 [7:0]
C2251300h
WSEQ_ADDR32 [12:0]
WSEQ_DATA_START32 [3:0]
WSEQ_DATA32 [7:0]
02250B00h
WSEQ_ADDR33 [12:0]
WSEQ_DATA_START33 [3:0]
WSEQ_DATA33 [7:0]
0225FF01h
WSEQ_ADDR34 [12:0]
WSEQ_DATA_START34 [3:0]
WSEQ_DATA34 [7:0]
0000F000h
WSEQ_ADDR35 [12:0]
WSEQ_DATA_START35 [3:0]
WSEQ_DATA35 [7:0]
0000F000h
WSEQ_ADDR36 [12:0]
WSEQ_DATA_START36 [3:0]
WSEQ_DATA36 [7:0]
0000F000h
WSEQ_ADDR37 [12:0]
WSEQ_DATA_START37 [3:0]
WSEQ_DATA37 [7:0]
0000F000h
WSEQ_ADDR38 [12:0]
WSEQ_DATA_START38 [3:0]
WSEQ_DATA38 [7:0]
0000F000h
WSEQ_ADDR39 [12:0]
WSEQ_DATA_START39 [3:0]
WSEQ_DATA39 [7:0]
0000F000h
WSEQ_ADDR40 [12:0]
WSEQ_DATA_START40 [3:0]
WSEQ_DATA40 [7:0]
0000F000h
WSEQ_ADDR41 [12:0]
WSEQ_DATA_START41 [3:0]
WSEQ_DATA41 [7:0]
0000F000h
WSEQ_ADDR42 [12:0]
WSEQ_DATA_START42 [3:0]
WSEQ_DATA42 [7:0]
0000F000h
WSEQ_ADDR43 [12:0]
WSEQ_DATA_START43 [3:0]
WSEQ_DATA43 [7:0]
82263719h
WSEQ_ADDR44 [12:0]
WSEQ_DATA_START44 [3:0]
WSEQ_DATA44 [7:0]
C2300001h
WSEQ_ADDR45 [12:0]
WSEQ_DATA_START45 [3:0]
WSEQ_DATA45 [7:0]
02261301h
WSEQ_ADDR46 [12:0]
WSEQ_DATA_START46 [3:0]
WSEQ_DATA46 [7:0]
8226191Fh
WSEQ_ADDR47 [12:0]
WSEQ_DATA_START47 [3:0]
WSEQ_DATA47 [7:0]
82310B02h
WSEQ_ADDR48 [12:0]
WSEQ_DATA_START48 [3:0]
WSEQ_DATA48 [7:0]
E231023Bh
WSEQ_ADDR49 [12:0]
WSEQ_DATA_START49 [3:0]
WSEQ_DATA49 [7:0]
02313B01h
WSEQ_ADDR50 [12:0]
WSEQ_DATA_START50 [3:0]
WSEQ_DATA50 [7:0]
62300000h
WSEQ_ADDR51 [12:0]
WSEQ_DATA_START51 [3:0]
17
1
42310C02h
WSEQ_ADDR16 [12:0]
WSEQ_DATA_START16 [3:0]
18
2
WSEQ_DATA51 [7:0]
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12392 WSEQ_Sequence_53
(3068h)
R12394 WSEQ_Sequence_54
(306Ah)
R12396 WSEQ_Sequence_55
(306Ch)
R12398 WSEQ_Sequence_56
(306Eh)
R12400 WSEQ_Sequence_57
(3070h)
R12402 WSEQ_Sequence_58
(3072h)
R12404 WSEQ_Sequence_59
(3074h)
R12406 WSEQ_Sequence_60
(3076h)
R12408 WSEQ_Sequence_61
(3078h)
R12410 WSEQ_Sequence_62
(307Ah)
R12412 WSEQ_Sequence_63
(307Ch)
R12414 WSEQ_Sequence_64
(307Eh)
R12416 WSEQ_Sequence_65
(3080h)
R12418 WSEQ_Sequence_66
(3082h)
R12420 WSEQ_Sequence_67
(3084h)
R12422 WSEQ_Sequence_68
(3086h)
R12424 WSEQ_Sequence_69
(3088h)
R12426 WSEQ_Sequence_70
(308Ah)
R12428 WSEQ_Sequence_71
(308Ch)
R12430 WSEQ_Sequence_72
(308Eh)
R12432 WSEQ_Sequence_73
(3090h)
R12434 WSEQ_Sequence_74
(3092h)
R12436 WSEQ_Sequence_75
(3094h)
R12438 WSEQ_Sequence_76
(3096h)
R12440 WSEQ_Sequence_77
(3098h)
R12442 WSEQ_Sequence_78
(309Ah)
R12444 WSEQ_Sequence_79
(309Ch)
R12446 WSEQ_Sequence_80
(309Eh)
R12448 WSEQ_Sequence_81
(30A0h)
R12450 WSEQ_Sequence_82
(30A2h)
R12452 WSEQ_Sequence_83
(30A4h)
R12454 WSEQ_Sequence_84
(30A6h)
R12456 WSEQ_Sequence_85
(30A8h)
R12458 WSEQ_Sequence_86
(30AAh)
R12460 WSEQ_Sequence_87
(30ACh)
R12462 WSEQ_Sequence_88
(30AEh)
DS1162F1
31
15
30
14
29
13
WSEQ_DATA_WIDTH52 [2:0]
WSEQ_DELAY52 [3:0]
WSEQ_DATA_WIDTH53 [2:0]
WSEQ_DELAY53 [3:0]
WSEQ_DATA_WIDTH54 [2:0]
WSEQ_DELAY54 [3:0]
WSEQ_DATA_WIDTH55 [2:0]
WSEQ_DELAY55 [3:0]
WSEQ_DATA_WIDTH56 [2:0]
WSEQ_DELAY56 [3:0]
WSEQ_DATA_WIDTH57 [2:0]
WSEQ_DELAY57 [3:0]
WSEQ_DATA_WIDTH58 [2:0]
WSEQ_DELAY58 [3:0]
WSEQ_DATA_WIDTH59 [2:0]
WSEQ_DELAY59 [3:0]
WSEQ_DATA_WIDTH60 [2:0]
WSEQ_DELAY60 [3:0]
WSEQ_DATA_WIDTH61 [2:0]
WSEQ_DELAY61 [3:0]
WSEQ_DATA_WIDTH62 [2:0]
WSEQ_DELAY62 [3:0]
WSEQ_DATA_WIDTH63 [2:0]
WSEQ_DELAY63 [3:0]
WSEQ_DATA_WIDTH64 [2:0]
WSEQ_DELAY64 [3:0]
WSEQ_DATA_WIDTH65 [2:0]
WSEQ_DELAY65 [3:0]
WSEQ_DATA_WIDTH66 [2:0]
WSEQ_DELAY66 [3:0]
WSEQ_DATA_WIDTH67 [2:0]
WSEQ_DELAY67 [3:0]
WSEQ_DATA_WIDTH68 [2:0]
WSEQ_DELAY68 [3:0]
WSEQ_DATA_WIDTH69 [2:0]
WSEQ_DELAY69 [3:0]
WSEQ_DATA_WIDTH70 [2:0]
WSEQ_DELAY70 [3:0]
WSEQ_DATA_WIDTH71 [2:0]
WSEQ_DELAY71 [3:0]
WSEQ_DATA_WIDTH72 [2:0]
WSEQ_DELAY72 [3:0]
WSEQ_DATA_WIDTH73 [2:0]
WSEQ_DELAY73 [3:0]
WSEQ_DATA_WIDTH74 [2:0]
WSEQ_DELAY74 [3:0]
WSEQ_DATA_WIDTH75 [2:0]
WSEQ_DELAY75 [3:0]
WSEQ_DATA_WIDTH76 [2:0]
WSEQ_DELAY76 [3:0]
WSEQ_DATA_WIDTH77 [2:0]
WSEQ_DELAY77 [3:0]
WSEQ_DATA_WIDTH78 [2:0]
WSEQ_DELAY78 [3:0]
WSEQ_DATA_WIDTH79 [2:0]
WSEQ_DELAY79 [3:0]
WSEQ_DATA_WIDTH80 [2:0]
WSEQ_DELAY80 [3:0]
WSEQ_DATA_WIDTH81 [2:0]
WSEQ_DELAY81 [3:0]
WSEQ_DATA_WIDTH82 [2:0]
WSEQ_DELAY82 [3:0]
WSEQ_DATA_WIDTH83 [2:0]
WSEQ_DELAY83 [3:0]
WSEQ_DATA_WIDTH84 [2:0]
WSEQ_DELAY84 [3:0]
WSEQ_DATA_WIDTH85 [2:0]
WSEQ_DELAY85 [3:0]
WSEQ_DATA_WIDTH86 [2:0]
WSEQ_DELAY86 [3:0]
WSEQ_DATA_WIDTH87 [2:0]
WSEQ_DELAY87 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA52 [7:0]
02310B00h
WSEQ_ADDR53 [12:0]
WSEQ_DATA_START53 [3:0]
WSEQ_DATA53 [7:0]
02310B00h
WSEQ_ADDR54 [12:0]
WSEQ_DATA_START54 [3:0]
WSEQ_DATA54 [7:0]
02260E01h
WSEQ_ADDR55 [12:0]
WSEQ_DATA_START55 [3:0]
WSEQ_DATA55 [7:0]
42310C03h
WSEQ_ADDR56 [12:0]
WSEQ_DATA_START56 [3:0]
WSEQ_DATA56 [7:0]
E2310227h
WSEQ_ADDR57 [12:0]
WSEQ_DATA_START57 [3:0]
WSEQ_DATA57 [7:0]
02313B01h
WSEQ_ADDR58 [12:0]
WSEQ_DATA_START58 [3:0]
WSEQ_DATA58 [7:0]
E2314266h
WSEQ_ADDR59 [12:0]
WSEQ_DATA_START59 [3:0]
WSEQ_DATA59 [7:0]
E2315294h
WSEQ_ADDR60 [12:0]
WSEQ_DATA_START60 [3:0]
WSEQ_DATA60 [7:0]
02310B00h
WSEQ_ADDR61 [12:0]
WSEQ_DATA_START61 [3:0]
WSEQ_DATA61 [7:0]
02310B00h
WSEQ_ADDR62 [12:0]
WSEQ_DATA_START62 [3:0]
WSEQ_DATA62 [7:0]
E2261734h
WSEQ_ADDR63 [12:0]
WSEQ_DATA_START63 [3:0]
WSEQ_DATA63 [7:0]
0226F501h
WSEQ_ADDR64 [12:0]
WSEQ_DATA_START64 [3:0]
WSEQ_DATA64 [7:0]
0000F000h
WSEQ_ADDR65 [12:0]
WSEQ_DATA_START65 [3:0]
WSEQ_DATA65 [7:0]
0000F000h
WSEQ_ADDR66 [12:0]
WSEQ_DATA_START66 [3:0]
WSEQ_DATA66 [7:0]
0000F000h
WSEQ_ADDR67 [12:0]
WSEQ_DATA_START67 [3:0]
WSEQ_DATA67 [7:0]
0000F000h
WSEQ_ADDR68 [12:0]
WSEQ_DATA_START68 [3:0]
WSEQ_DATA68 [7:0]
0000F000h
WSEQ_ADDR69 [12:0]
WSEQ_DATA_START69 [3:0]
WSEQ_DATA69 [7:0]
0000F000h
WSEQ_ADDR70 [12:0]
WSEQ_DATA_START70 [3:0]
WSEQ_DATA70 [7:0]
02263A01h
WSEQ_ADDR71 [12:0]
WSEQ_DATA_START71 [3:0]
WSEQ_DATA71 [7:0]
C2261300h
WSEQ_ADDR72 [12:0]
WSEQ_DATA_START72 [3:0]
WSEQ_DATA72 [7:0]
02260B00h
WSEQ_ADDR73 [12:0]
WSEQ_DATA_START73 [3:0]
WSEQ_DATA73 [7:0]
0226FF01h
WSEQ_ADDR74 [12:0]
WSEQ_DATA_START74 [3:0]
WSEQ_DATA74 [7:0]
0000F000h
WSEQ_ADDR75 [12:0]
WSEQ_DATA_START75 [3:0]
WSEQ_DATA75 [7:0]
0000F000h
WSEQ_ADDR76 [12:0]
WSEQ_DATA_START76 [3:0]
WSEQ_DATA76 [7:0]
0000F000h
WSEQ_ADDR77 [12:0]
WSEQ_DATA_START77 [3:0]
WSEQ_DATA77 [7:0]
0000F000h
WSEQ_ADDR78 [12:0]
WSEQ_DATA_START78 [3:0]
WSEQ_DATA78 [7:0]
0000F000h
WSEQ_ADDR79 [12:0]
WSEQ_DATA_START79 [3:0]
WSEQ_DATA79 [7:0]
0000F000h
WSEQ_ADDR80 [12:0]
WSEQ_DATA_START80 [3:0]
WSEQ_DATA80 [7:0]
0000F000h
WSEQ_ADDR81 [12:0]
WSEQ_DATA_START81 [3:0]
WSEQ_DATA81 [7:0]
0000F000h
WSEQ_ADDR82 [12:0]
WSEQ_DATA_START82 [3:0]
WSEQ_DATA82 [7:0]
0000F000h
WSEQ_ADDR83 [12:0]
WSEQ_DATA_START83 [3:0]
WSEQ_DATA83 [7:0]
82273719h
WSEQ_ADDR84 [12:0]
WSEQ_DATA_START84 [3:0]
WSEQ_DATA84 [7:0]
C2400001h
WSEQ_ADDR85 [12:0]
WSEQ_DATA_START85 [3:0]
WSEQ_DATA85 [7:0]
02271301h
WSEQ_ADDR86 [12:0]
WSEQ_DATA_START86 [3:0]
WSEQ_DATA86 [7:0]
8227191Fh
WSEQ_ADDR87 [12:0]
WSEQ_DATA_START87 [3:0]
17
1
E2314288h
WSEQ_ADDR52 [12:0]
WSEQ_DATA_START52 [3:0]
18
2
WSEQ_DATA87 [7:0]
313
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12464 WSEQ_Sequence_89
(30B0h)
R12466 WSEQ_Sequence_90
(30B2h)
R12468 WSEQ_Sequence_91
(30B4h)
R12470 WSEQ_Sequence_92
(30B6h)
R12472 WSEQ_Sequence_93
(30B8h)
R12474 WSEQ_Sequence_94
(30BAh)
R12476 WSEQ_Sequence_95
(30BCh)
R12478 WSEQ_Sequence_96
(30BEh)
R12480 WSEQ_Sequence_97
(30C0h)
R12482 WSEQ_Sequence_98
(30C2h)
R12484 WSEQ_Sequence_99
(30C4h)
R12486 WSEQ_Sequence_100
(30C6h)
R12488 WSEQ_Sequence_101
(30C8h)
R12490 WSEQ_Sequence_102
(30CAh)
R12492 WSEQ_Sequence_103
(30CCh)
R12494 WSEQ_Sequence_104
(30CEh)
R12496 WSEQ_Sequence_105
(30D0h)
R12498 WSEQ_Sequence_106
(30D2h)
R12500 WSEQ_Sequence_107
(30D4h)
R12502 WSEQ_Sequence_108
(30D6h)
R12504 WSEQ_Sequence_109
(30D8h)
R12506 WSEQ_Sequence_110
(30DAh)
R12508 WSEQ_Sequence_111
(30DCh)
R12510 WSEQ_Sequence_112
(30DEh)
R12512 WSEQ_Sequence_113
(30E0h)
R12514 WSEQ_Sequence_114
(30E2h)
R12516 WSEQ_Sequence_115
(30E4h)
R12518 WSEQ_Sequence_116
(30E6h)
R12520 WSEQ_Sequence_117
(30E8h)
R12522 WSEQ_Sequence_118
(30EAh)
R12524 WSEQ_Sequence_119
(30ECh)
R12526 WSEQ_Sequence_120
(30EEh)
R12528 WSEQ_Sequence_121
(30F0h)
R12530 WSEQ_Sequence_122
(30F2h)
R12532 WSEQ_Sequence_123
(30F4h)
R12534 WSEQ_Sequence_124
(30F6h)
314
31
15
30
14
29
13
WSEQ_DATA_WIDTH88 [2:0]
WSEQ_DELAY88 [3:0]
WSEQ_DATA_WIDTH89 [2:0]
WSEQ_DELAY89 [3:0]
WSEQ_DATA_WIDTH90 [2:0]
WSEQ_DELAY90 [3:0]
WSEQ_DATA_WIDTH91 [2:0]
WSEQ_DELAY91 [3:0]
WSEQ_DATA_WIDTH92 [2:0]
WSEQ_DELAY92 [3:0]
WSEQ_DATA_WIDTH93 [2:0]
WSEQ_DELAY93 [3:0]
WSEQ_DATA_WIDTH94 [2:0]
WSEQ_DELAY94 [3:0]
WSEQ_DATA_WIDTH95 [2:0]
WSEQ_DELAY95 [3:0]
WSEQ_DATA_WIDTH96 [2:0]
WSEQ_DELAY96 [3:0]
WSEQ_DATA_WIDTH97 [2:0]
WSEQ_DELAY97 [3:0]
WSEQ_DATA_WIDTH98 [2:0]
WSEQ_DELAY98 [3:0]
WSEQ_DATA_WIDTH99 [2:0]
WSEQ_DELAY99 [3:0]
WSEQ_DATA_WIDTH100 [2:0]
WSEQ_DELAY100 [3:0]
WSEQ_DATA_WIDTH101 [2:0]
WSEQ_DELAY101 [3:0]
WSEQ_DATA_WIDTH102 [2:0]
WSEQ_DELAY102 [3:0]
WSEQ_DATA_WIDTH103 [2:0]
WSEQ_DELAY103 [3:0]
WSEQ_DATA_WIDTH104 [2:0]
WSEQ_DELAY104 [3:0]
WSEQ_DATA_WIDTH105 [2:0]
WSEQ_DELAY105 [3:0]
WSEQ_DATA_WIDTH106 [2:0]
WSEQ_DELAY106 [3:0]
WSEQ_DATA_WIDTH107 [2:0]
WSEQ_DELAY107 [3:0]
WSEQ_DATA_WIDTH108 [2:0]
WSEQ_DELAY108 [3:0]
WSEQ_DATA_WIDTH109 [2:0]
WSEQ_DELAY109 [3:0]
WSEQ_DATA_WIDTH110 [2:0]
WSEQ_DELAY110 [3:0]
WSEQ_DATA_WIDTH111 [2:0]
WSEQ_DELAY111 [3:0]
WSEQ_DATA_WIDTH112 [2:0]
WSEQ_DELAY112 [3:0]
WSEQ_DATA_WIDTH113 [2:0]
WSEQ_DELAY113 [3:0]
WSEQ_DATA_WIDTH114 [2:0]
WSEQ_DELAY114 [3:0]
WSEQ_DATA_WIDTH115 [2:0]
WSEQ_DELAY115 [3:0]
WSEQ_DATA_WIDTH116 [2:0]
WSEQ_DELAY116 [3:0]
WSEQ_DATA_WIDTH117 [2:0]
WSEQ_DELAY117 [3:0]
WSEQ_DATA_WIDTH118 [2:0]
WSEQ_DELAY118 [3:0]
WSEQ_DATA_WIDTH119 [2:0]
WSEQ_DELAY119 [3:0]
WSEQ_DATA_WIDTH120 [2:0]
WSEQ_DELAY120 [3:0]
WSEQ_DATA_WIDTH121 [2:0]
WSEQ_DELAY121 [3:0]
WSEQ_DATA_WIDTH122 [2:0]
WSEQ_DELAY122 [3:0]
WSEQ_DATA_WIDTH123 [2:0]
WSEQ_DELAY123 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA88 [7:0]
E241023Bh
WSEQ_ADDR89 [12:0]
WSEQ_DATA_START89 [3:0]
WSEQ_DATA89 [7:0]
02413B01h
WSEQ_ADDR90 [12:0]
WSEQ_DATA_START90 [3:0]
WSEQ_DATA90 [7:0]
62400000h
WSEQ_ADDR91 [12:0]
WSEQ_DATA_START91 [3:0]
WSEQ_DATA91 [7:0]
E2414288h
WSEQ_ADDR92 [12:0]
WSEQ_DATA_START92 [3:0]
WSEQ_DATA92 [7:0]
02410B00h
WSEQ_ADDR93 [12:0]
WSEQ_DATA_START93 [3:0]
WSEQ_DATA93 [7:0]
02410B00h
WSEQ_ADDR94 [12:0]
WSEQ_DATA_START94 [3:0]
WSEQ_DATA94 [7:0]
02270E01h
WSEQ_ADDR95 [12:0]
WSEQ_DATA_START95 [3:0]
WSEQ_DATA95 [7:0]
42410C02h
WSEQ_ADDR96 [12:0]
WSEQ_DATA_START96 [3:0]
WSEQ_DATA96 [7:0]
E2410227h
WSEQ_ADDR97 [12:0]
WSEQ_DATA_START97 [3:0]
WSEQ_DATA97 [7:0]
02413B01h
WSEQ_ADDR98 [12:0]
WSEQ_DATA_START98 [3:0]
WSEQ_DATA98 [7:0]
E2414266h
WSEQ_ADDR99 [12:0]
WSEQ_DATA_START99 [3:0]
WSEQ_DATA99 [7:0]
E2415294h
WSEQ_ADDR100 [12:0]
WSEQ_DATA_START100 [3:0]
WSEQ_DATA100 [7:0]
02410B00h
WSEQ_ADDR101 [12:0]
WSEQ_DATA_START101 [3:0]
WSEQ_DATA101 [7:0]
02410B00h
WSEQ_ADDR102 [12:0]
WSEQ_DATA_START102 [3:0]
WSEQ_DATA102 [7:0]
E2271734h
WSEQ_ADDR103 [12:0]
WSEQ_DATA_START103 [3:0]
WSEQ_DATA103 [7:0]
0227F501h
WSEQ_ADDR104 [12:0]
WSEQ_DATA_START104 [3:0]
WSEQ_DATA104 [7:0]
0000F000h
WSEQ_ADDR105 [12:0]
WSEQ_DATA_START105 [3:0]
WSEQ_DATA105 [7:0]
0000F000h
WSEQ_ADDR106 [12:0]
WSEQ_DATA_START106 [3:0]
WSEQ_DATA106 [7:0]
0000F000h
WSEQ_ADDR107 [12:0]
WSEQ_DATA_START107 [3:0]
WSEQ_DATA107 [7:0]
0000F000h
WSEQ_ADDR108 [12:0]
WSEQ_DATA_START108 [3:0]
WSEQ_DATA108 [7:0]
0000F000h
WSEQ_ADDR109 [12:0]
WSEQ_DATA_START109 [3:0]
WSEQ_DATA109 [7:0]
0000F000h
WSEQ_ADDR110 [12:0]
WSEQ_DATA_START110 [3:0]
WSEQ_DATA110 [7:0]
02273A01h
WSEQ_ADDR111 [12:0]
WSEQ_DATA_START111 [3:0]
WSEQ_DATA111 [7:0]
C2271300h
WSEQ_ADDR112 [12:0]
WSEQ_DATA_START112 [3:0]
WSEQ_DATA112 [7:0]
02270B00h
WSEQ_ADDR113 [12:0]
WSEQ_DATA_START113 [3:0]
WSEQ_DATA113 [7:0]
0227FF01h
WSEQ_ADDR114 [12:0]
WSEQ_DATA_START114 [3:0]
WSEQ_DATA114 [7:0]
0000F000h
WSEQ_ADDR115 [12:0]
WSEQ_DATA_START115 [3:0]
WSEQ_DATA115 [7:0]
0000F000h
WSEQ_ADDR116 [12:0]
WSEQ_DATA_START116 [3:0]
WSEQ_DATA116 [7:0]
0000F000h
WSEQ_ADDR117 [12:0]
WSEQ_DATA_START117 [3:0]
WSEQ_DATA117 [7:0]
0000F000h
WSEQ_ADDR118 [12:0]
WSEQ_DATA_START118 [3:0]
WSEQ_DATA118 [7:0]
0000F000h
WSEQ_ADDR119 [12:0]
WSEQ_DATA_START119 [3:0]
WSEQ_DATA119 [7:0]
0000F000h
WSEQ_ADDR120 [12:0]
WSEQ_DATA_START120 [3:0]
WSEQ_DATA120 [7:0]
0000F000h
WSEQ_ADDR121 [12:0]
WSEQ_DATA_START121 [3:0]
WSEQ_DATA121 [7:0]
0000F000h
WSEQ_ADDR122 [12:0]
WSEQ_DATA_START122 [3:0]
WSEQ_DATA122 [7:0]
0000F000h
WSEQ_ADDR123 [12:0]
WSEQ_DATA_START123 [3:0]
17
1
82410B00h
WSEQ_ADDR88 [12:0]
WSEQ_DATA_START88 [3:0]
18
2
WSEQ_DATA123 [7:0]
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12536 WSEQ_Sequence_125
(30F8h)
R12538 WSEQ_Sequence_126
(30FAh)
R12540 WSEQ_Sequence_127
(30FCh)
R12542 WSEQ_Sequence_128
(30FEh)
R12544 WSEQ_Sequence_129
(3100h)
R12546 WSEQ_Sequence_130
(3102h)
R12548 WSEQ_Sequence_131
(3104h)
R12550 WSEQ_Sequence_132
(3106h)
R12552 WSEQ_Sequence_133
(3108h)
R12554 WSEQ_Sequence_134
(310Ah)
R12556 WSEQ_Sequence_135
(310Ch)
R12558 WSEQ_Sequence_136
(310Eh)
R12560 WSEQ_Sequence_137
(3110h)
R12562 WSEQ_Sequence_138
(3112h)
R12564 WSEQ_Sequence_139
(3114h)
R12566 WSEQ_Sequence_140
(3116h)
R12568 WSEQ_Sequence_141
(3118h)
R12570 WSEQ_Sequence_142
(311Ah)
R12572 WSEQ_Sequence_143
(311Ch)
R12574 WSEQ_Sequence_144
(311Eh)
R12576 WSEQ_Sequence_145
(3120h)
R12578 WSEQ_Sequence_146
(3122h)
R12580 WSEQ_Sequence_147
(3124h)
R12582 WSEQ_Sequence_148
(3126h)
R12584 WSEQ_Sequence_149
(3128h)
R12586 WSEQ_Sequence_150
(312Ah)
R12588 WSEQ_Sequence_151
(312Ch)
R12590 WSEQ_Sequence_152
(312Eh)
R12592 WSEQ_Sequence_153
(3130h)
R12594 WSEQ_Sequence_154
(3132h)
R12596 WSEQ_Sequence_155
(3134h)
R12598 WSEQ_Sequence_156
(3136h)
R12600 WSEQ_Sequence_157
(3138h)
R12602 WSEQ_Sequence_158
(313Ah)
R12604 WSEQ_Sequence_159
(313Ch)
R12606 WSEQ_Sequence_160
(313Eh)
DS1162F1
31
15
30
14
29
13
WSEQ_DATA_WIDTH124 [2:0]
WSEQ_DELAY124 [3:0]
WSEQ_DATA_WIDTH125 [2:0]
WSEQ_DELAY125 [3:0]
WSEQ_DATA_WIDTH126 [2:0]
WSEQ_DELAY126 [3:0]
WSEQ_DATA_WIDTH127 [2:0]
WSEQ_DELAY127 [3:0]
WSEQ_DATA_WIDTH128 [2:0]
WSEQ_DELAY128 [3:0]
WSEQ_DATA_WIDTH129 [2:0]
WSEQ_DELAY129 [3:0]
WSEQ_DATA_WIDTH130 [2:0]
WSEQ_DELAY130 [3:0]
WSEQ_DATA_WIDTH131 [2:0]
WSEQ_DELAY131 [3:0]
WSEQ_DATA_WIDTH132 [2:0]
WSEQ_DELAY132 [3:0]
WSEQ_DATA_WIDTH133 [2:0]
WSEQ_DELAY133 [3:0]
WSEQ_DATA_WIDTH134 [2:0]
WSEQ_DELAY134 [3:0]
WSEQ_DATA_WIDTH135 [2:0]
WSEQ_DELAY135 [3:0]
WSEQ_DATA_WIDTH136 [2:0]
WSEQ_DELAY136 [3:0]
WSEQ_DATA_WIDTH137 [2:0]
WSEQ_DELAY137 [3:0]
WSEQ_DATA_WIDTH138 [2:0]
WSEQ_DELAY138 [3:0]
WSEQ_DATA_WIDTH139 [2:0]
WSEQ_DELAY139 [3:0]
WSEQ_DATA_WIDTH140 [2:0]
WSEQ_DELAY140 [3:0]
WSEQ_DATA_WIDTH141 [2:0]
WSEQ_DELAY141 [3:0]
WSEQ_DATA_WIDTH142 [2:0]
WSEQ_DELAY142 [3:0]
WSEQ_DATA_WIDTH143 [2:0]
WSEQ_DELAY143 [3:0]
WSEQ_DATA_WIDTH144 [2:0]
WSEQ_DELAY144 [3:0]
WSEQ_DATA_WIDTH145 [2:0]
WSEQ_DELAY145 [3:0]
WSEQ_DATA_WIDTH146 [2:0]
WSEQ_DELAY146 [3:0]
WSEQ_DATA_WIDTH147 [2:0]
WSEQ_DELAY147 [3:0]
WSEQ_DATA_WIDTH148 [2:0]
WSEQ_DELAY148 [3:0]
WSEQ_DATA_WIDTH149 [2:0]
WSEQ_DELAY149 [3:0]
WSEQ_DATA_WIDTH150 [2:0]
WSEQ_DELAY150 [3:0]
WSEQ_DATA_WIDTH151 [2:0]
WSEQ_DELAY151 [3:0]
WSEQ_DATA_WIDTH152 [2:0]
WSEQ_DELAY152 [3:0]
WSEQ_DATA_WIDTH153 [2:0]
WSEQ_DELAY153 [3:0]
WSEQ_DATA_WIDTH154 [2:0]
WSEQ_DELAY154 [3:0]
WSEQ_DATA_WIDTH155 [2:0]
WSEQ_DELAY155 [3:0]
WSEQ_DATA_WIDTH156 [2:0]
WSEQ_DELAY156 [3:0]
WSEQ_DATA_WIDTH157 [2:0]
WSEQ_DELAY157 [3:0]
WSEQ_DATA_WIDTH158 [2:0]
WSEQ_DELAY158 [3:0]
WSEQ_DATA_WIDTH159 [2:0]
WSEQ_DELAY159 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA124 [7:0]
C2400001h
WSEQ_ADDR125 [12:0]
WSEQ_DATA_START125 [3:0]
WSEQ_DATA125 [7:0]
02281301h
WSEQ_ADDR126 [12:0]
WSEQ_DATA_START126 [3:0]
WSEQ_DATA126 [7:0]
8228191Fh
WSEQ_ADDR127 [12:0]
WSEQ_DATA_START127 [3:0]
WSEQ_DATA127 [7:0]
82410B02h
WSEQ_ADDR128 [12:0]
WSEQ_DATA_START128 [3:0]
WSEQ_DATA128 [7:0]
E241023Bh
WSEQ_ADDR129 [12:0]
WSEQ_DATA_START129 [3:0]
WSEQ_DATA129 [7:0]
02413B01h
WSEQ_ADDR130 [12:0]
WSEQ_DATA_START130 [3:0]
WSEQ_DATA130 [7:0]
62400000h
WSEQ_ADDR131 [12:0]
WSEQ_DATA_START131 [3:0]
WSEQ_DATA131 [7:0]
E2414288h
WSEQ_ADDR132 [12:0]
WSEQ_DATA_START132 [3:0]
WSEQ_DATA132 [7:0]
02410B00h
WSEQ_ADDR133 [12:0]
WSEQ_DATA_START133 [3:0]
WSEQ_DATA133 [7:0]
02410B00h
WSEQ_ADDR134 [12:0]
WSEQ_DATA_START134 [3:0]
WSEQ_DATA134 [7:0]
02280E01h
WSEQ_ADDR135 [12:0]
WSEQ_DATA_START135 [3:0]
WSEQ_DATA135 [7:0]
42410C03h
WSEQ_ADDR136 [12:0]
WSEQ_DATA_START136 [3:0]
WSEQ_DATA136 [7:0]
E2410227h
WSEQ_ADDR137 [12:0]
WSEQ_DATA_START137 [3:0]
WSEQ_DATA137 [7:0]
02413B01h
WSEQ_ADDR138 [12:0]
WSEQ_DATA_START138 [3:0]
WSEQ_DATA138 [7:0]
E2414266h
WSEQ_ADDR139 [12:0]
WSEQ_DATA_START139 [3:0]
WSEQ_DATA139 [7:0]
E2415294h
WSEQ_ADDR140 [12:0]
WSEQ_DATA_START140 [3:0]
WSEQ_DATA140 [7:0]
02410B00h
WSEQ_ADDR141 [12:0]
WSEQ_DATA_START141 [3:0]
WSEQ_DATA141 [7:0]
02410B00h
WSEQ_ADDR142 [12:0]
WSEQ_DATA_START142 [3:0]
WSEQ_DATA142 [7:0]
E2281734h
WSEQ_ADDR143 [12:0]
WSEQ_DATA_START143 [3:0]
WSEQ_DATA143 [7:0]
0228F501h
WSEQ_ADDR144 [12:0]
WSEQ_DATA_START144 [3:0]
WSEQ_DATA144 [7:0]
0000F000h
WSEQ_ADDR145 [12:0]
WSEQ_DATA_START145 [3:0]
WSEQ_DATA145 [7:0]
0000F000h
WSEQ_ADDR146 [12:0]
WSEQ_DATA_START146 [3:0]
WSEQ_DATA146 [7:0]
0000F000h
WSEQ_ADDR147 [12:0]
WSEQ_DATA_START147 [3:0]
WSEQ_DATA147 [7:0]
0000F000h
WSEQ_ADDR148 [12:0]
WSEQ_DATA_START148 [3:0]
WSEQ_DATA148 [7:0]
0000F000h
WSEQ_ADDR149 [12:0]
WSEQ_DATA_START149 [3:0]
WSEQ_DATA149 [7:0]
0000F000h
WSEQ_ADDR150 [12:0]
WSEQ_DATA_START150 [3:0]
WSEQ_DATA150 [7:0]
02283A01h
WSEQ_ADDR151 [12:0]
WSEQ_DATA_START151 [3:0]
WSEQ_DATA151 [7:0]
C2281300h
WSEQ_ADDR152 [12:0]
WSEQ_DATA_START152 [3:0]
WSEQ_DATA152 [7:0]
02280B00h
WSEQ_ADDR153 [12:0]
WSEQ_DATA_START153 [3:0]
WSEQ_DATA153 [7:0]
0228FF01h
WSEQ_ADDR154 [12:0]
WSEQ_DATA_START154 [3:0]
WSEQ_DATA154 [7:0]
0000F000h
WSEQ_ADDR155 [12:0]
WSEQ_DATA_START155 [3:0]
WSEQ_DATA155 [7:0]
0000F000h
WSEQ_ADDR156 [12:0]
WSEQ_DATA_START156 [3:0]
WSEQ_DATA156 [7:0]
0000F000h
WSEQ_ADDR157 [12:0]
WSEQ_DATA_START157 [3:0]
WSEQ_DATA157 [7:0]
0000F000h
WSEQ_ADDR158 [12:0]
WSEQ_DATA_START158 [3:0]
WSEQ_DATA158 [7:0]
0000F000h
WSEQ_ADDR159 [12:0]
WSEQ_DATA_START159 [3:0]
17
1
82283719h
WSEQ_ADDR124 [12:0]
WSEQ_DATA_START124 [3:0]
18
2
WSEQ_DATA159 [7:0]
315
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12608 WSEQ_Sequence_161
(3140h)
R12610 WSEQ_Sequence_162
(3142h)
R12612 WSEQ_Sequence_163
(3144h)
R12614 WSEQ_Sequence_164
(3146h)
R12616 WSEQ_Sequence_165
(3148h)
R12618 WSEQ_Sequence_166
(314Ah)
R12620 WSEQ_Sequence_167
(314Ch)
R12622 WSEQ_Sequence_168
(314Eh)
R12624 WSEQ_Sequence_169
(3150h)
R12626 WSEQ_Sequence_170
(3152h)
R12628 WSEQ_Sequence_171
(3154h)
R12630 WSEQ_Sequence_172
(3156h)
R12632 WSEQ_Sequence_173
(3158h)
R12634 WSEQ_Sequence_174
(315Ah)
R12636 WSEQ_Sequence_175
(315Ch)
R12638 WSEQ_Sequence_176
(315Eh)
R12640 WSEQ_Sequence_177
(3160h)
R12642 WSEQ_Sequence_178
(3162h)
R12644 WSEQ_Sequence_179
(3164h)
R12646 WSEQ_Sequence_180
(3166h)
R12648 WSEQ_Sequence_181
(3168h)
R12650 WSEQ_Sequence_182
(316Ah)
R12652 WSEQ_Sequence_183
(316Ch)
R12654 WSEQ_Sequence_184
(316Eh)
R12656 WSEQ_Sequence_185
(3170h)
R12658 WSEQ_Sequence_186
(3172h)
R12660 WSEQ_Sequence_187
(3174h)
R12662 WSEQ_Sequence_188
(3176h)
R12664 WSEQ_Sequence_189
(3178h)
R12666 WSEQ_Sequence_190
(317Ah)
R12668 WSEQ_Sequence_191
(317Ch)
R12670 WSEQ_Sequence_192
(317Eh)
R12672 WSEQ_Sequence_193
(3180h)
R12674 WSEQ_Sequence_194
(3182h)
R12676 WSEQ_Sequence_195
(3184h)
R12678 WSEQ_Sequence_196
(3186h)
316
31
15
30
14
29
13
WSEQ_DATA_WIDTH160 [2:0]
WSEQ_DELAY160 [3:0]
WSEQ_DATA_WIDTH161 [2:0]
WSEQ_DELAY161 [3:0]
WSEQ_DATA_WIDTH162 [2:0]
WSEQ_DELAY162 [3:0]
WSEQ_DATA_WIDTH163 [2:0]
WSEQ_DELAY163 [3:0]
WSEQ_DATA_WIDTH164 [2:0]
WSEQ_DELAY164 [3:0]
WSEQ_DATA_WIDTH165 [2:0]
WSEQ_DELAY165 [3:0]
WSEQ_DATA_WIDTH166 [2:0]
WSEQ_DELAY166 [3:0]
WSEQ_DATA_WIDTH167 [2:0]
WSEQ_DELAY167 [3:0]
WSEQ_DATA_WIDTH168 [2:0]
WSEQ_DELAY168 [3:0]
WSEQ_DATA_WIDTH169 [2:0]
WSEQ_DELAY169 [3:0]
WSEQ_DATA_WIDTH170 [2:0]
WSEQ_DELAY170 [3:0]
WSEQ_DATA_WIDTH171 [2:0]
WSEQ_DELAY171 [3:0]
WSEQ_DATA_WIDTH172 [2:0]
WSEQ_DELAY172 [3:0]
WSEQ_DATA_WIDTH173 [2:0]
WSEQ_DELAY173 [3:0]
WSEQ_DATA_WIDTH174 [2:0]
WSEQ_DELAY174 [3:0]
WSEQ_DATA_WIDTH175 [2:0]
WSEQ_DELAY175 [3:0]
WSEQ_DATA_WIDTH176 [2:0]
WSEQ_DELAY176 [3:0]
WSEQ_DATA_WIDTH177 [2:0]
WSEQ_DELAY177 [3:0]
WSEQ_DATA_WIDTH178 [2:0]
WSEQ_DELAY178 [3:0]
WSEQ_DATA_WIDTH179 [2:0]
WSEQ_DELAY179 [3:0]
WSEQ_DATA_WIDTH180 [2:0]
WSEQ_DELAY180 [3:0]
WSEQ_DATA_WIDTH181 [2:0]
WSEQ_DELAY181 [3:0]
WSEQ_DATA_WIDTH182 [2:0]
WSEQ_DELAY182 [3:0]
WSEQ_DATA_WIDTH183 [2:0]
WSEQ_DELAY183 [3:0]
WSEQ_DATA_WIDTH184 [2:0]
WSEQ_DELAY184 [3:0]
WSEQ_DATA_WIDTH185 [2:0]
WSEQ_DELAY185 [3:0]
WSEQ_DATA_WIDTH186 [2:0]
WSEQ_DELAY186 [3:0]
WSEQ_DATA_WIDTH187 [2:0]
WSEQ_DELAY187 [3:0]
WSEQ_DATA_WIDTH188 [2:0]
WSEQ_DELAY188 [3:0]
WSEQ_DATA_WIDTH189 [2:0]
WSEQ_DELAY189 [3:0]
WSEQ_DATA_WIDTH190 [2:0]
WSEQ_DELAY190 [3:0]
WSEQ_DATA_WIDTH191 [2:0]
WSEQ_DELAY191 [3:0]
WSEQ_DATA_WIDTH192 [2:0]
WSEQ_DELAY192 [3:0]
WSEQ_DATA_WIDTH193 [2:0]
WSEQ_DELAY193 [3:0]
WSEQ_DATA_WIDTH194 [2:0]
WSEQ_DELAY194 [3:0]
WSEQ_DATA_WIDTH195 [2:0]
WSEQ_DELAY195 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA160 [7:0]
0000F000h
WSEQ_ADDR161 [12:0]
WSEQ_DATA_START161 [3:0]
WSEQ_DATA161 [7:0]
0000F000h
WSEQ_ADDR162 [12:0]
WSEQ_DATA_START162 [3:0]
WSEQ_DATA162 [7:0]
0000F000h
WSEQ_ADDR163 [12:0]
WSEQ_DATA_START163 [3:0]
WSEQ_DATA163 [7:0]
82293719h
WSEQ_ADDR164 [12:0]
WSEQ_DATA_START164 [3:0]
WSEQ_DATA164 [7:0]
C2500001h
WSEQ_ADDR165 [12:0]
WSEQ_DATA_START165 [3:0]
WSEQ_DATA165 [7:0]
02291301h
WSEQ_ADDR166 [12:0]
WSEQ_DATA_START166 [3:0]
WSEQ_DATA166 [7:0]
8229191Fh
WSEQ_ADDR167 [12:0]
WSEQ_DATA_START167 [3:0]
WSEQ_DATA167 [7:0]
82510B00h
WSEQ_ADDR168 [12:0]
WSEQ_DATA_START168 [3:0]
WSEQ_DATA168 [7:0]
E251023Bh
WSEQ_ADDR169 [12:0]
WSEQ_DATA_START169 [3:0]
WSEQ_DATA169 [7:0]
02513B01h
WSEQ_ADDR170 [12:0]
WSEQ_DATA_START170 [3:0]
WSEQ_DATA170 [7:0]
62500000h
WSEQ_ADDR171 [12:0]
WSEQ_DATA_START171 [3:0]
WSEQ_DATA171 [7:0]
E2514288h
WSEQ_ADDR172 [12:0]
WSEQ_DATA_START172 [3:0]
WSEQ_DATA172 [7:0]
02510B00h
WSEQ_ADDR173 [12:0]
WSEQ_DATA_START173 [3:0]
WSEQ_DATA173 [7:0]
02510B00h
WSEQ_ADDR174 [12:0]
WSEQ_DATA_START174 [3:0]
WSEQ_DATA174 [7:0]
02290E01h
WSEQ_ADDR175 [12:0]
WSEQ_DATA_START175 [3:0]
WSEQ_DATA175 [7:0]
42510C02h
WSEQ_ADDR176 [12:0]
WSEQ_DATA_START176 [3:0]
WSEQ_DATA176 [7:0]
E2510227h
WSEQ_ADDR177 [12:0]
WSEQ_DATA_START177 [3:0]
WSEQ_DATA177 [7:0]
02513B01h
WSEQ_ADDR178 [12:0]
WSEQ_DATA_START178 [3:0]
WSEQ_DATA178 [7:0]
E2514266h
WSEQ_ADDR179 [12:0]
WSEQ_DATA_START179 [3:0]
WSEQ_DATA179 [7:0]
E2515294h
WSEQ_ADDR180 [12:0]
WSEQ_DATA_START180 [3:0]
WSEQ_DATA180 [7:0]
02510B00h
WSEQ_ADDR181 [12:0]
WSEQ_DATA_START181 [3:0]
WSEQ_DATA181 [7:0]
02510B00h
WSEQ_ADDR182 [12:0]
WSEQ_DATA_START182 [3:0]
WSEQ_DATA182 [7:0]
E2291734h
WSEQ_ADDR183 [12:0]
WSEQ_DATA_START183 [3:0]
WSEQ_DATA183 [7:0]
0229F501h
WSEQ_ADDR184 [12:0]
WSEQ_DATA_START184 [3:0]
WSEQ_DATA184 [7:0]
0000F000h
WSEQ_ADDR185 [12:0]
WSEQ_DATA_START185 [3:0]
WSEQ_DATA185 [7:0]
0000F000h
WSEQ_ADDR186 [12:0]
WSEQ_DATA_START186 [3:0]
WSEQ_DATA186 [7:0]
0000F000h
WSEQ_ADDR187 [12:0]
WSEQ_DATA_START187 [3:0]
WSEQ_DATA187 [7:0]
0000F000h
WSEQ_ADDR188 [12:0]
WSEQ_DATA_START188 [3:0]
WSEQ_DATA188 [7:0]
0000F000h
WSEQ_ADDR189 [12:0]
WSEQ_DATA_START189 [3:0]
WSEQ_DATA189 [7:0]
0000F000h
WSEQ_ADDR190 [12:0]
WSEQ_DATA_START190 [3:0]
WSEQ_DATA190 [7:0]
02293A01h
WSEQ_ADDR191 [12:0]
WSEQ_DATA_START191 [3:0]
WSEQ_DATA191 [7:0]
C2291300h
WSEQ_ADDR192 [12:0]
WSEQ_DATA_START192 [3:0]
WSEQ_DATA192 [7:0]
02290B00h
WSEQ_ADDR193 [12:0]
WSEQ_DATA_START193 [3:0]
WSEQ_DATA193 [7:0]
0229FF01h
WSEQ_ADDR194 [12:0]
WSEQ_DATA_START194 [3:0]
WSEQ_DATA194 [7:0]
0000F000h
WSEQ_ADDR195 [12:0]
WSEQ_DATA_START195 [3:0]
17
1
0000F000h
WSEQ_ADDR160 [12:0]
WSEQ_DATA_START160 [3:0]
18
2
WSEQ_DATA195 [7:0]
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12680 WSEQ_Sequence_197
(3188h)
R12682 WSEQ_Sequence_198
(318Ah)
R12684 WSEQ_Sequence_199
(318Ch)
R12686 WSEQ_Sequence_200
(318Eh)
R12688 WSEQ_Sequence_201
(3190h)
R12690 WSEQ_Sequence_202
(3192h)
R12692 WSEQ_Sequence_203
(3194h)
R12694 WSEQ_Sequence_204
(3196h)
R12696 WSEQ_Sequence_205
(3198h)
R12698 WSEQ_Sequence_206
(319Ah)
R12700 WSEQ_Sequence_207
(319Ch)
R12702 WSEQ_Sequence_208
(319Eh)
R12704 WSEQ_Sequence_209
(31A0h)
R12706 WSEQ_Sequence_210
(31A2h)
R12708 WSEQ_Sequence_211
(31A4h)
R12710 WSEQ_Sequence_212
(31A6h)
R12712 WSEQ_Sequence_213
(31A8h)
R12714 WSEQ_Sequence_214
(31AAh)
R12716 WSEQ_Sequence_215
(31ACh)
R12718 WSEQ_Sequence_216
(31AEh)
R12720 WSEQ_Sequence_217
(31B0h)
R12722 WSEQ_Sequence_218
(31B2h)
R12724 WSEQ_Sequence_219
(31B4h)
R12726 WSEQ_Sequence_220
(31B6h)
R12728 WSEQ_Sequence_221
(31B8h)
R12730 WSEQ_Sequence_222
(31BAh)
R12732 WSEQ_Sequence_223
(31BCh)
R12734 WSEQ_Sequence_224
(31BEh)
R12736 WSEQ_Sequence_225
(31C0h)
R12738 WSEQ_Sequence_226
(31C2h)
R12740 WSEQ_Sequence_227
(31C4h)
R12742 WSEQ_Sequence_228
(31C6h)
R12744 WSEQ_Sequence_229
(31C8h)
R12746 WSEQ_Sequence_230
(31CAh)
R12748 WSEQ_Sequence_231
(31CCh)
R12750 WSEQ_Sequence_232
(31CEh)
DS1162F1
31
15
30
14
29
13
WSEQ_DATA_WIDTH196 [2:0]
WSEQ_DELAY196 [3:0]
WSEQ_DATA_WIDTH197 [2:0]
WSEQ_DELAY197 [3:0]
WSEQ_DATA_WIDTH198 [2:0]
WSEQ_DELAY198 [3:0]
WSEQ_DATA_WIDTH199 [2:0]
WSEQ_DELAY199 [3:0]
WSEQ_DATA_WIDTH200 [2:0]
WSEQ_DELAY200 [3:0]
WSEQ_DATA_WIDTH201 [2:0]
WSEQ_DELAY201 [3:0]
WSEQ_DATA_WIDTH202 [2:0]
WSEQ_DELAY202 [3:0]
WSEQ_DATA_WIDTH203 [2:0]
WSEQ_DELAY203 [3:0]
WSEQ_DATA_WIDTH204 [2:0]
WSEQ_DELAY204 [3:0]
WSEQ_DATA_WIDTH205 [2:0]
WSEQ_DELAY205 [3:0]
WSEQ_DATA_WIDTH206 [2:0]
WSEQ_DELAY206 [3:0]
WSEQ_DATA_WIDTH207 [2:0]
WSEQ_DELAY207 [3:0]
WSEQ_DATA_WIDTH208 [2:0]
WSEQ_DELAY208 [3:0]
WSEQ_DATA_WIDTH209 [2:0]
WSEQ_DELAY209 [3:0]
WSEQ_DATA_WIDTH210 [2:0]
WSEQ_DELAY210 [3:0]
WSEQ_DATA_WIDTH211 [2:0]
WSEQ_DELAY211 [3:0]
WSEQ_DATA_WIDTH212 [2:0]
WSEQ_DELAY212 [3:0]
WSEQ_DATA_WIDTH213 [2:0]
WSEQ_DELAY213 [3:0]
WSEQ_DATA_WIDTH214 [2:0]
WSEQ_DELAY214 [3:0]
WSEQ_DATA_WIDTH215 [2:0]
WSEQ_DELAY215 [3:0]
WSEQ_DATA_WIDTH216 [2:0]
WSEQ_DELAY216 [3:0]
WSEQ_DATA_WIDTH217 [2:0]
WSEQ_DELAY217 [3:0]
WSEQ_DATA_WIDTH218 [2:0]
WSEQ_DELAY218 [3:0]
WSEQ_DATA_WIDTH219 [2:0]
WSEQ_DELAY219 [3:0]
WSEQ_DATA_WIDTH220 [2:0]
WSEQ_DELAY220 [3:0]
WSEQ_DATA_WIDTH221 [2:0]
WSEQ_DELAY221 [3:0]
WSEQ_DATA_WIDTH222 [2:0]
WSEQ_DELAY222 [3:0]
WSEQ_DATA_WIDTH223 [2:0]
WSEQ_DELAY223 [3:0]
WSEQ_DATA_WIDTH224 [2:0]
WSEQ_DELAY224 [3:0]
WSEQ_DATA_WIDTH225 [2:0]
WSEQ_DELAY225 [3:0]
WSEQ_DATA_WIDTH226 [2:0]
WSEQ_DELAY226 [3:0]
WSEQ_DATA_WIDTH227 [2:0]
WSEQ_DELAY227 [3:0]
WSEQ_DATA_WIDTH228 [2:0]
WSEQ_DELAY228 [3:0]
WSEQ_DATA_WIDTH229 [2:0]
WSEQ_DELAY229 [3:0]
WSEQ_DATA_WIDTH230 [2:0]
WSEQ_DELAY230 [3:0]
WSEQ_DATA_WIDTH231 [2:0]
WSEQ_DELAY231 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA196 [7:0]
0000F000h
WSEQ_ADDR197 [12:0]
WSEQ_DATA_START197 [3:0]
WSEQ_DATA197 [7:0]
0000F000h
WSEQ_ADDR198 [12:0]
WSEQ_DATA_START198 [3:0]
WSEQ_DATA198 [7:0]
0000F000h
WSEQ_ADDR199 [12:0]
WSEQ_DATA_START199 [3:0]
WSEQ_DATA199 [7:0]
0000F000h
WSEQ_ADDR200 [12:0]
WSEQ_DATA_START200 [3:0]
WSEQ_DATA200 [7:0]
0000F000h
WSEQ_ADDR201 [12:0]
WSEQ_DATA_START201 [3:0]
WSEQ_DATA201 [7:0]
0000F000h
WSEQ_ADDR202 [12:0]
WSEQ_DATA_START202 [3:0]
WSEQ_DATA202 [7:0]
0000F000h
WSEQ_ADDR203 [12:0]
WSEQ_DATA_START203 [3:0]
WSEQ_DATA203 [7:0]
822A3719h
WSEQ_ADDR204 [12:0]
WSEQ_DATA_START204 [3:0]
WSEQ_DATA204 [7:0]
C2500001h
WSEQ_ADDR205 [12:0]
WSEQ_DATA_START205 [3:0]
WSEQ_DATA205 [7:0]
022A1301h
WSEQ_ADDR206 [12:0]
WSEQ_DATA_START206 [3:0]
WSEQ_DATA206 [7:0]
822A191Fh
WSEQ_ADDR207 [12:0]
WSEQ_DATA_START207 [3:0]
WSEQ_DATA207 [7:0]
82510B02h
WSEQ_ADDR208 [12:0]
WSEQ_DATA_START208 [3:0]
WSEQ_DATA208 [7:0]
E251023Bh
WSEQ_ADDR209 [12:0]
WSEQ_DATA_START209 [3:0]
WSEQ_DATA209 [7:0]
02513B01h
WSEQ_ADDR210 [12:0]
WSEQ_DATA_START210 [3:0]
WSEQ_DATA210 [7:0]
62500000h
WSEQ_ADDR211 [12:0]
WSEQ_DATA_START211 [3:0]
WSEQ_DATA211 [7:0]
E2514288h
WSEQ_ADDR212 [12:0]
WSEQ_DATA_START212 [3:0]
WSEQ_DATA212 [7:0]
02510B00h
WSEQ_ADDR213 [12:0]
WSEQ_DATA_START213 [3:0]
WSEQ_DATA213 [7:0]
02510B00h
WSEQ_ADDR214 [12:0]
WSEQ_DATA_START214 [3:0]
WSEQ_DATA214 [7:0]
022A0E01h
WSEQ_ADDR215 [12:0]
WSEQ_DATA_START215 [3:0]
WSEQ_DATA215 [7:0]
42510C03h
WSEQ_ADDR216 [12:0]
WSEQ_DATA_START216 [3:0]
WSEQ_DATA216 [7:0]
E2510227h
WSEQ_ADDR217 [12:0]
WSEQ_DATA_START217 [3:0]
WSEQ_DATA217 [7:0]
02513B01h
WSEQ_ADDR218 [12:0]
WSEQ_DATA_START218 [3:0]
WSEQ_DATA218 [7:0]
E2514266h
WSEQ_ADDR219 [12:0]
WSEQ_DATA_START219 [3:0]
WSEQ_DATA219 [7:0]
E2515294h
WSEQ_ADDR220 [12:0]
WSEQ_DATA_START220 [3:0]
WSEQ_DATA220 [7:0]
02510B00h
WSEQ_ADDR221 [12:0]
WSEQ_DATA_START221 [3:0]
WSEQ_DATA221 [7:0]
02510B00h
WSEQ_ADDR222 [12:0]
WSEQ_DATA_START222 [3:0]
WSEQ_DATA222 [7:0]
E22A1734h
WSEQ_ADDR223 [12:0]
WSEQ_DATA_START223 [3:0]
WSEQ_DATA223 [7:0]
022AF501h
WSEQ_ADDR224 [12:0]
WSEQ_DATA_START224 [3:0]
WSEQ_DATA224 [7:0]
0000F000h
WSEQ_ADDR225 [12:0]
WSEQ_DATA_START225 [3:0]
WSEQ_DATA225 [7:0]
0000F000h
WSEQ_ADDR226 [12:0]
WSEQ_DATA_START226 [3:0]
WSEQ_DATA226 [7:0]
0000F000h
WSEQ_ADDR227 [12:0]
WSEQ_DATA_START227 [3:0]
WSEQ_DATA227 [7:0]
0000F000h
WSEQ_ADDR228 [12:0]
WSEQ_DATA_START228 [3:0]
WSEQ_DATA228 [7:0]
0000F000h
WSEQ_ADDR229 [12:0]
WSEQ_DATA_START229 [3:0]
WSEQ_DATA229 [7:0]
0000F000h
WSEQ_ADDR230 [12:0]
WSEQ_DATA_START230 [3:0]
WSEQ_DATA230 [7:0]
022A3A01h
WSEQ_ADDR231 [12:0]
WSEQ_DATA_START231 [3:0]
17
1
0000F000h
WSEQ_ADDR196 [12:0]
WSEQ_DATA_START196 [3:0]
18
2
WSEQ_DATA231 [7:0]
317
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12752 WSEQ_Sequence_233
(31D0h)
R12754 WSEQ_Sequence_234
(31D2h)
R12756 WSEQ_Sequence_235
(31D4h)
R12758 WSEQ_Sequence_236
(31D6h)
R12760 WSEQ_Sequence_237
(31D8h)
R12762 WSEQ_Sequence_238
(31DAh)
R12764 WSEQ_Sequence_239
(31DCh)
R12766 WSEQ_Sequence_240
(31DEh)
R12768 WSEQ_Sequence_241
(31E0h)
R12770 WSEQ_Sequence_242
(31E2h)
R12772 WSEQ_Sequence_243
(31E4h)
R12774 WSEQ_Sequence_244
(31E6h)
R12776 WSEQ_Sequence_245
(31E8h)
R12778 WSEQ_Sequence_246
(31EAh)
R12780 WSEQ_Sequence_247
(31ECh)
R12782 WSEQ_Sequence_248
(31EEh)
R12784 WSEQ_Sequence_249
(31F0h)
R12786 WSEQ_Sequence_250
(31F2h)
R12788 WSEQ_Sequence_251
(31F4h)
R12790 WSEQ_Sequence_252
(31F6h)
R12792 WSEQ_Sequence_253
(31F8h)
R12794 WSEQ_Sequence_254
(31FAh)
R12796 WSEQ_Sequence_255
(31FCh)
R12798 WSEQ_Sequence_256
(31FEh)
R12800 WSEQ_Sequence_257
(3200h)
R12802 WSEQ_Sequence_258
(3202h)
R12804 WSEQ_Sequence_259
(3204h)
R12806 WSEQ_Sequence_260
(3206h)
R12808 WSEQ_Sequence_261
(3208h)
R12810 WSEQ_Sequence_262
(320Ah)
R12812 WSEQ_Sequence_263
(320Ch)
R12814 WSEQ_Sequence_264
(320Eh)
R12816 WSEQ_Sequence_265
(3210h)
R12818 WSEQ_Sequence_266
(3212h)
R12820 WSEQ_Sequence_267
(3214h)
R12822 WSEQ_Sequence_268
(3216h)
318
31
15
30
14
29
13
WSEQ_DATA_WIDTH232 [2:0]
WSEQ_DELAY232 [3:0]
WSEQ_DATA_WIDTH233 [2:0]
WSEQ_DELAY233 [3:0]
WSEQ_DATA_WIDTH234 [2:0]
WSEQ_DELAY234 [3:0]
WSEQ_DATA_WIDTH235 [2:0]
WSEQ_DELAY235 [3:0]
WSEQ_DATA_WIDTH236 [2:0]
WSEQ_DELAY236 [3:0]
WSEQ_DATA_WIDTH237 [2:0]
WSEQ_DELAY237 [3:0]
WSEQ_DATA_WIDTH238 [2:0]
WSEQ_DELAY238 [3:0]
WSEQ_DATA_WIDTH239 [2:0]
WSEQ_DELAY239 [3:0]
WSEQ_DATA_WIDTH240 [2:0]
WSEQ_DELAY240 [3:0]
WSEQ_DATA_WIDTH241 [2:0]
WSEQ_DELAY241 [3:0]
WSEQ_DATA_WIDTH242 [2:0]
WSEQ_DELAY242 [3:0]
WSEQ_DATA_WIDTH243 [2:0]
WSEQ_DELAY243 [3:0]
WSEQ_DATA_WIDTH244 [2:0]
WSEQ_DELAY244 [3:0]
WSEQ_DATA_WIDTH245 [2:0]
WSEQ_DELAY245 [3:0]
WSEQ_DATA_WIDTH246 [2:0]
WSEQ_DELAY246 [3:0]
WSEQ_DATA_WIDTH247 [2:0]
WSEQ_DELAY247 [3:0]
WSEQ_DATA_WIDTH248 [2:0]
WSEQ_DELAY248 [3:0]
WSEQ_DATA_WIDTH249 [2:0]
WSEQ_DELAY249 [3:0]
WSEQ_DATA_WIDTH250 [2:0]
WSEQ_DELAY250 [3:0]
WSEQ_DATA_WIDTH251 [2:0]
WSEQ_DELAY251 [3:0]
WSEQ_DATA_WIDTH252 [2:0]
WSEQ_DELAY252 [3:0]
WSEQ_DATA_WIDTH253 [2:0]
WSEQ_DELAY253 [3:0]
WSEQ_DATA_WIDTH254 [2:0]
WSEQ_DELAY254 [3:0]
WSEQ_DATA_WIDTH255 [2:0]
WSEQ_DELAY255 [3:0]
WSEQ_DATA_WIDTH256 [2:0]
WSEQ_DELAY256 [3:0]
WSEQ_DATA_WIDTH257 [2:0]
WSEQ_DELAY257 [3:0]
WSEQ_DATA_WIDTH258 [2:0]
WSEQ_DELAY258 [3:0]
WSEQ_DATA_WIDTH259 [2:0]
WSEQ_DELAY259 [3:0]
WSEQ_DATA_WIDTH260 [2:0]
WSEQ_DELAY260 [3:0]
WSEQ_DATA_WIDTH261 [2:0]
WSEQ_DELAY261 [3:0]
WSEQ_DATA_WIDTH262 [2:0]
WSEQ_DELAY262 [3:0]
WSEQ_DATA_WIDTH263 [2:0]
WSEQ_DELAY263 [3:0]
WSEQ_DATA_WIDTH264 [2:0]
WSEQ_DELAY264 [3:0]
WSEQ_DATA_WIDTH265 [2:0]
WSEQ_DELAY265 [3:0]
WSEQ_DATA_WIDTH266 [2:0]
WSEQ_DELAY266 [3:0]
WSEQ_DATA_WIDTH267 [2:0]
WSEQ_DELAY267 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA232 [7:0]
022A0B00h
WSEQ_ADDR233 [12:0]
WSEQ_DATA_START233 [3:0]
WSEQ_DATA233 [7:0]
022AFF01h
WSEQ_ADDR234 [12:0]
WSEQ_DATA_START234 [3:0]
WSEQ_DATA234 [7:0]
0000F000h
WSEQ_ADDR235 [12:0]
WSEQ_DATA_START235 [3:0]
WSEQ_DATA235 [7:0]
0000F000h
WSEQ_ADDR236 [12:0]
WSEQ_DATA_START236 [3:0]
WSEQ_DATA236 [7:0]
0000F000h
WSEQ_ADDR237 [12:0]
WSEQ_DATA_START237 [3:0]
WSEQ_DATA237 [7:0]
0000F000h
WSEQ_ADDR238 [12:0]
WSEQ_DATA_START238 [3:0]
WSEQ_DATA238 [7:0]
0000F000h
WSEQ_ADDR239 [12:0]
WSEQ_DATA_START239 [3:0]
WSEQ_DATA239 [7:0]
0000F000h
WSEQ_ADDR240 [12:0]
WSEQ_DATA_START240 [3:0]
WSEQ_DATA240 [7:0]
0000F000h
WSEQ_ADDR241 [12:0]
WSEQ_DATA_START241 [3:0]
WSEQ_DATA241 [7:0]
0000F000h
WSEQ_ADDR242 [12:0]
WSEQ_DATA_START242 [3:0]
WSEQ_DATA242 [7:0]
0000F000h
WSEQ_ADDR243 [12:0]
WSEQ_DATA_START243 [3:0]
WSEQ_DATA243 [7:0]
0000F000h
WSEQ_ADDR244 [12:0]
WSEQ_DATA_START244 [3:0]
WSEQ_DATA244 [7:0]
0000F000h
WSEQ_ADDR245 [12:0]
WSEQ_DATA_START245 [3:0]
WSEQ_DATA245 [7:0]
0000F000h
WSEQ_ADDR246 [12:0]
WSEQ_DATA_START246 [3:0]
WSEQ_DATA246 [7:0]
0000F000h
WSEQ_ADDR247 [12:0]
WSEQ_DATA_START247 [3:0]
WSEQ_DATA247 [7:0]
0000F000h
WSEQ_ADDR248 [12:0]
WSEQ_DATA_START248 [3:0]
WSEQ_DATA248 [7:0]
0000F000h
WSEQ_ADDR249 [12:0]
WSEQ_DATA_START249 [3:0]
WSEQ_DATA249 [7:0]
0000F000h
WSEQ_ADDR250 [12:0]
WSEQ_DATA_START250 [3:0]
WSEQ_DATA250 [7:0]
0000F000h
WSEQ_ADDR251 [12:0]
WSEQ_DATA_START251 [3:0]
WSEQ_DATA251 [7:0]
0000F000h
WSEQ_ADDR252 [12:0]
WSEQ_DATA_START252 [3:0]
WSEQ_DATA252 [7:0]
0000F000h
WSEQ_ADDR253 [12:0]
WSEQ_DATA_START253 [3:0]
WSEQ_DATA253 [7:0]
0000F000h
WSEQ_ADDR254 [12:0]
WSEQ_DATA_START254 [3:0]
WSEQ_DATA254 [7:0]
0000F000h
WSEQ_ADDR255 [12:0]
WSEQ_DATA_START255 [3:0]
WSEQ_DATA255 [7:0]
0000F000h
WSEQ_ADDR256 [12:0]
WSEQ_DATA_START256 [3:0]
WSEQ_DATA256 [7:0]
0000F000h
WSEQ_ADDR257 [12:0]
WSEQ_DATA_START257 [3:0]
WSEQ_DATA257 [7:0]
0000F000h
WSEQ_ADDR258 [12:0]
WSEQ_DATA_START258 [3:0]
WSEQ_DATA258 [7:0]
0000F000h
WSEQ_ADDR259 [12:0]
WSEQ_DATA_START259 [3:0]
WSEQ_DATA259 [7:0]
0000F000h
WSEQ_ADDR260 [12:0]
WSEQ_DATA_START260 [3:0]
WSEQ_DATA260 [7:0]
0000F000h
WSEQ_ADDR261 [12:0]
WSEQ_DATA_START261 [3:0]
WSEQ_DATA261 [7:0]
0000F000h
WSEQ_ADDR262 [12:0]
WSEQ_DATA_START262 [3:0]
WSEQ_DATA262 [7:0]
0000F000h
WSEQ_ADDR263 [12:0]
WSEQ_DATA_START263 [3:0]
WSEQ_DATA263 [7:0]
0000F000h
WSEQ_ADDR264 [12:0]
WSEQ_DATA_START264 [3:0]
WSEQ_DATA264 [7:0]
0000F000h
WSEQ_ADDR265 [12:0]
WSEQ_DATA_START265 [3:0]
WSEQ_DATA265 [7:0]
0000F000h
WSEQ_ADDR266 [12:0]
WSEQ_DATA_START266 [3:0]
WSEQ_DATA266 [7:0]
0000F000h
WSEQ_ADDR267 [12:0]
WSEQ_DATA_START267 [3:0]
17
1
C22A1300h
WSEQ_ADDR232 [12:0]
WSEQ_DATA_START232 [3:0]
18
2
WSEQ_DATA267 [7:0]
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12824 WSEQ_Sequence_269
(3218h)
R12826 WSEQ_Sequence_270
(321Ah)
R12828 WSEQ_Sequence_271
(321Ch)
R12830 WSEQ_Sequence_272
(321Eh)
R12832 WSEQ_Sequence_273
(3220h)
R12834 WSEQ_Sequence_274
(3222h)
R12836 WSEQ_Sequence_275
(3224h)
R12838 WSEQ_Sequence_276
(3226h)
R12840 WSEQ_Sequence_277
(3228h)
R12842 WSEQ_Sequence_278
(322Ah)
R12844 WSEQ_Sequence_279
(322Ch)
R12846 WSEQ_Sequence_280
(322Eh)
R12848 WSEQ_Sequence_281
(3230h)
R12850 WSEQ_Sequence_282
(3232h)
R12852 WSEQ_Sequence_283
(3234h)
R12854 WSEQ_Sequence_284
(3236h)
R12856 WSEQ_Sequence_285
(3238h)
R12858 WSEQ_Sequence_286
(323Ah)
R12860 WSEQ_Sequence_287
(323Ch)
R12862 WSEQ_Sequence_288
(323Eh)
R12864 WSEQ_Sequence_289
(3240h)
R12866 WSEQ_Sequence_290
(3242h)
R12868 WSEQ_Sequence_291
(3244h)
R12870 WSEQ_Sequence_292
(3246h)
R12872 WSEQ_Sequence_293
(3248h)
R12874 WSEQ_Sequence_294
(324Ah)
R12876 WSEQ_Sequence_295
(324Ch)
R12878 WSEQ_Sequence_296
(324Eh)
R12880 WSEQ_Sequence_297
(3250h)
R12882 WSEQ_Sequence_298
(3252h)
R12884 WSEQ_Sequence_299
(3254h)
R12886 WSEQ_Sequence_300
(3256h)
R12888 WSEQ_Sequence_301
(3258h)
R12890 WSEQ_Sequence_302
(325Ah)
R12892 WSEQ_Sequence_303
(325Ch)
R12894 WSEQ_Sequence_304
(325Eh)
DS1162F1
31
15
30
14
29
13
WSEQ_DATA_WIDTH268 [2:0]
WSEQ_DELAY268 [3:0]
WSEQ_DATA_WIDTH269 [2:0]
WSEQ_DELAY269 [3:0]
WSEQ_DATA_WIDTH270 [2:0]
WSEQ_DELAY270 [3:0]
WSEQ_DATA_WIDTH271 [2:0]
WSEQ_DELAY271 [3:0]
WSEQ_DATA_WIDTH272 [2:0]
WSEQ_DELAY272 [3:0]
WSEQ_DATA_WIDTH273 [2:0]
WSEQ_DELAY273 [3:0]
WSEQ_DATA_WIDTH274 [2:0]
WSEQ_DELAY274 [3:0]
WSEQ_DATA_WIDTH275 [2:0]
WSEQ_DELAY275 [3:0]
WSEQ_DATA_WIDTH276 [2:0]
WSEQ_DELAY276 [3:0]
WSEQ_DATA_WIDTH277 [2:0]
WSEQ_DELAY277 [3:0]
WSEQ_DATA_WIDTH278 [2:0]
WSEQ_DELAY278 [3:0]
WSEQ_DATA_WIDTH279 [2:0]
WSEQ_DELAY279 [3:0]
WSEQ_DATA_WIDTH280 [2:0]
WSEQ_DELAY280 [3:0]
WSEQ_DATA_WIDTH281 [2:0]
WSEQ_DELAY281 [3:0]
WSEQ_DATA_WIDTH282 [2:0]
WSEQ_DELAY282 [3:0]
WSEQ_DATA_WIDTH283 [2:0]
WSEQ_DELAY283 [3:0]
WSEQ_DATA_WIDTH284 [2:0]
WSEQ_DELAY284 [3:0]
WSEQ_DATA_WIDTH285 [2:0]
WSEQ_DELAY285 [3:0]
WSEQ_DATA_WIDTH286 [2:0]
WSEQ_DELAY286 [3:0]
WSEQ_DATA_WIDTH287 [2:0]
WSEQ_DELAY287 [3:0]
WSEQ_DATA_WIDTH288 [2:0]
WSEQ_DELAY288 [3:0]
WSEQ_DATA_WIDTH289 [2:0]
WSEQ_DELAY289 [3:0]
WSEQ_DATA_WIDTH290 [2:0]
WSEQ_DELAY290 [3:0]
WSEQ_DATA_WIDTH291 [2:0]
WSEQ_DELAY291 [3:0]
WSEQ_DATA_WIDTH292 [2:0]
WSEQ_DELAY292 [3:0]
WSEQ_DATA_WIDTH293 [2:0]
WSEQ_DELAY293 [3:0]
WSEQ_DATA_WIDTH294 [2:0]
WSEQ_DELAY294 [3:0]
WSEQ_DATA_WIDTH295 [2:0]
WSEQ_DELAY295 [3:0]
WSEQ_DATA_WIDTH296 [2:0]
WSEQ_DELAY296 [3:0]
WSEQ_DATA_WIDTH297 [2:0]
WSEQ_DELAY297 [3:0]
WSEQ_DATA_WIDTH298 [2:0]
WSEQ_DELAY298 [3:0]
WSEQ_DATA_WIDTH299 [2:0]
WSEQ_DELAY299 [3:0]
WSEQ_DATA_WIDTH300 [2:0]
WSEQ_DELAY300 [3:0]
WSEQ_DATA_WIDTH301 [2:0]
WSEQ_DELAY301 [3:0]
WSEQ_DATA_WIDTH302 [2:0]
WSEQ_DELAY302 [3:0]
WSEQ_DATA_WIDTH303 [2:0]
WSEQ_DELAY303 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA268 [7:0]
0000F000h
WSEQ_ADDR269 [12:0]
WSEQ_DATA_START269 [3:0]
WSEQ_DATA269 [7:0]
0000F000h
WSEQ_ADDR270 [12:0]
WSEQ_DATA_START270 [3:0]
WSEQ_DATA270 [7:0]
0000F000h
WSEQ_ADDR271 [12:0]
WSEQ_DATA_START271 [3:0]
WSEQ_DATA271 [7:0]
0000F000h
WSEQ_ADDR272 [12:0]
WSEQ_DATA_START272 [3:0]
WSEQ_DATA272 [7:0]
0000F000h
WSEQ_ADDR273 [12:0]
WSEQ_DATA_START273 [3:0]
WSEQ_DATA273 [7:0]
0000F000h
WSEQ_ADDR274 [12:0]
WSEQ_DATA_START274 [3:0]
WSEQ_DATA274 [7:0]
0000F000h
WSEQ_ADDR275 [12:0]
WSEQ_DATA_START275 [3:0]
WSEQ_DATA275 [7:0]
0000F000h
WSEQ_ADDR276 [12:0]
WSEQ_DATA_START276 [3:0]
WSEQ_DATA276 [7:0]
0000F000h
WSEQ_ADDR277 [12:0]
WSEQ_DATA_START277 [3:0]
WSEQ_DATA277 [7:0]
0000F000h
WSEQ_ADDR278 [12:0]
WSEQ_DATA_START278 [3:0]
WSEQ_DATA278 [7:0]
0000F000h
WSEQ_ADDR279 [12:0]
WSEQ_DATA_START279 [3:0]
WSEQ_DATA279 [7:0]
0000F000h
WSEQ_ADDR280 [12:0]
WSEQ_DATA_START280 [3:0]
WSEQ_DATA280 [7:0]
0000F000h
WSEQ_ADDR281 [12:0]
WSEQ_DATA_START281 [3:0]
WSEQ_DATA281 [7:0]
0000F000h
WSEQ_ADDR282 [12:0]
WSEQ_DATA_START282 [3:0]
WSEQ_DATA282 [7:0]
0000F000h
WSEQ_ADDR283 [12:0]
WSEQ_DATA_START283 [3:0]
WSEQ_DATA283 [7:0]
0000F000h
WSEQ_ADDR284 [12:0]
WSEQ_DATA_START284 [3:0]
WSEQ_DATA284 [7:0]
0000F000h
WSEQ_ADDR285 [12:0]
WSEQ_DATA_START285 [3:0]
WSEQ_DATA285 [7:0]
0000F000h
WSEQ_ADDR286 [12:0]
WSEQ_DATA_START286 [3:0]
WSEQ_DATA286 [7:0]
0000F000h
WSEQ_ADDR287 [12:0]
WSEQ_DATA_START287 [3:0]
WSEQ_DATA287 [7:0]
0000F000h
WSEQ_ADDR288 [12:0]
WSEQ_DATA_START288 [3:0]
WSEQ_DATA288 [7:0]
0000F000h
WSEQ_ADDR289 [12:0]
WSEQ_DATA_START289 [3:0]
WSEQ_DATA289 [7:0]
0000F000h
WSEQ_ADDR290 [12:0]
WSEQ_DATA_START290 [3:0]
WSEQ_DATA290 [7:0]
0000F000h
WSEQ_ADDR291 [12:0]
WSEQ_DATA_START291 [3:0]
WSEQ_DATA291 [7:0]
0000F000h
WSEQ_ADDR292 [12:0]
WSEQ_DATA_START292 [3:0]
WSEQ_DATA292 [7:0]
0000F000h
WSEQ_ADDR293 [12:0]
WSEQ_DATA_START293 [3:0]
WSEQ_DATA293 [7:0]
0000F000h
WSEQ_ADDR294 [12:0]
WSEQ_DATA_START294 [3:0]
WSEQ_DATA294 [7:0]
0000F000h
WSEQ_ADDR295 [12:0]
WSEQ_DATA_START295 [3:0]
WSEQ_DATA295 [7:0]
0000F000h
WSEQ_ADDR296 [12:0]
WSEQ_DATA_START296 [3:0]
WSEQ_DATA296 [7:0]
0000F000h
WSEQ_ADDR297 [12:0]
WSEQ_DATA_START297 [3:0]
WSEQ_DATA297 [7:0]
0000F000h
WSEQ_ADDR298 [12:0]
WSEQ_DATA_START298 [3:0]
WSEQ_DATA298 [7:0]
0000F000h
WSEQ_ADDR299 [12:0]
WSEQ_DATA_START299 [3:0]
WSEQ_DATA299 [7:0]
0000F000h
WSEQ_ADDR300 [12:0]
WSEQ_DATA_START300 [3:0]
WSEQ_DATA300 [7:0]
0000F000h
WSEQ_ADDR301 [12:0]
WSEQ_DATA_START301 [3:0]
WSEQ_DATA301 [7:0]
0000F000h
WSEQ_ADDR302 [12:0]
WSEQ_DATA_START302 [3:0]
WSEQ_DATA302 [7:0]
0000F000h
WSEQ_ADDR303 [12:0]
WSEQ_DATA_START303 [3:0]
17
1
0000F000h
WSEQ_ADDR268 [12:0]
WSEQ_DATA_START268 [3:0]
18
2
WSEQ_DATA303 [7:0]
319
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12896 WSEQ_Sequence_305
(3260h)
R12898 WSEQ_Sequence_306
(3262h)
R12900 WSEQ_Sequence_307
(3264h)
R12902 WSEQ_Sequence_308
(3266h)
R12904 WSEQ_Sequence_309
(3268h)
R12906 WSEQ_Sequence_310
(326Ah)
R12908 WSEQ_Sequence_311
(326Ch)
R12910 WSEQ_Sequence_312
(326Eh)
R12912 WSEQ_Sequence_313
(3270h)
R12914 WSEQ_Sequence_314
(3272h)
R12916 WSEQ_Sequence_315
(3274h)
R12918 WSEQ_Sequence_316
(3276h)
R12920 WSEQ_Sequence_317
(3278h)
R12922 WSEQ_Sequence_318
(327Ah)
R12924 WSEQ_Sequence_319
(327Ch)
R12926 WSEQ_Sequence_320
(327Eh)
R12928 WSEQ_Sequence_321
(3280h)
R12930 WSEQ_Sequence_322
(3282h)
R12932 WSEQ_Sequence_323
(3284h)
R12934 WSEQ_Sequence_324
(3286h)
R12936 WSEQ_Sequence_325
(3288h)
R12938 WSEQ_Sequence_326
(328Ah)
R12940 WSEQ_Sequence_327
(328Ch)
R12942 WSEQ_Sequence_328
(328Eh)
R12944 WSEQ_Sequence_329
(3290h)
R12946 WSEQ_Sequence_330
(3292h)
R12948 WSEQ_Sequence_331
(3294h)
R12950 WSEQ_Sequence_332
(3296h)
R12952 WSEQ_Sequence_333
(3298h)
R12954 WSEQ_Sequence_334
(329Ah)
R12956 WSEQ_Sequence_335
(329Ch)
R12958 WSEQ_Sequence_336
(329Eh)
R12960 WSEQ_Sequence_337
(32A0h)
R12962 WSEQ_Sequence_338
(32A2h)
R12964 WSEQ_Sequence_339
(32A4h)
R12966 WSEQ_Sequence_340
(32A6h)
320
31
15
30
14
29
13
WSEQ_DATA_WIDTH304 [2:0]
WSEQ_DELAY304 [3:0]
WSEQ_DATA_WIDTH305 [2:0]
WSEQ_DELAY305 [3:0]
WSEQ_DATA_WIDTH306 [2:0]
WSEQ_DELAY306 [3:0]
WSEQ_DATA_WIDTH307 [2:0]
WSEQ_DELAY307 [3:0]
WSEQ_DATA_WIDTH308 [2:0]
WSEQ_DELAY308 [3:0]
WSEQ_DATA_WIDTH309 [2:0]
WSEQ_DELAY309 [3:0]
WSEQ_DATA_WIDTH310 [2:0]
WSEQ_DELAY310 [3:0]
WSEQ_DATA_WIDTH311 [2:0]
WSEQ_DELAY311 [3:0]
WSEQ_DATA_WIDTH312 [2:0]
WSEQ_DELAY312 [3:0]
WSEQ_DATA_WIDTH313 [2:0]
WSEQ_DELAY313 [3:0]
WSEQ_DATA_WIDTH314 [2:0]
WSEQ_DELAY314 [3:0]
WSEQ_DATA_WIDTH315 [2:0]
WSEQ_DELAY315 [3:0]
WSEQ_DATA_WIDTH316 [2:0]
WSEQ_DELAY316 [3:0]
WSEQ_DATA_WIDTH317 [2:0]
WSEQ_DELAY317 [3:0]
WSEQ_DATA_WIDTH318 [2:0]
WSEQ_DELAY318 [3:0]
WSEQ_DATA_WIDTH319 [2:0]
WSEQ_DELAY319 [3:0]
WSEQ_DATA_WIDTH320 [2:0]
WSEQ_DELAY320 [3:0]
WSEQ_DATA_WIDTH321 [2:0]
WSEQ_DELAY321 [3:0]
WSEQ_DATA_WIDTH322 [2:0]
WSEQ_DELAY322 [3:0]
WSEQ_DATA_WIDTH323 [2:0]
WSEQ_DELAY323 [3:0]
WSEQ_DATA_WIDTH324 [2:0]
WSEQ_DELAY324 [3:0]
WSEQ_DATA_WIDTH325 [2:0]
WSEQ_DELAY325 [3:0]
WSEQ_DATA_WIDTH326 [2:0]
WSEQ_DELAY326 [3:0]
WSEQ_DATA_WIDTH327 [2:0]
WSEQ_DELAY327 [3:0]
WSEQ_DATA_WIDTH328 [2:0]
WSEQ_DELAY328 [3:0]
WSEQ_DATA_WIDTH329 [2:0]
WSEQ_DELAY329 [3:0]
WSEQ_DATA_WIDTH330 [2:0]
WSEQ_DELAY330 [3:0]
WSEQ_DATA_WIDTH331 [2:0]
WSEQ_DELAY331 [3:0]
WSEQ_DATA_WIDTH332 [2:0]
WSEQ_DELAY332 [3:0]
WSEQ_DATA_WIDTH333 [2:0]
WSEQ_DELAY333 [3:0]
WSEQ_DATA_WIDTH334 [2:0]
WSEQ_DELAY334 [3:0]
WSEQ_DATA_WIDTH335 [2:0]
WSEQ_DELAY335 [3:0]
WSEQ_DATA_WIDTH336 [2:0]
WSEQ_DELAY336 [3:0]
WSEQ_DATA_WIDTH337 [2:0]
WSEQ_DELAY337 [3:0]
WSEQ_DATA_WIDTH338 [2:0]
WSEQ_DELAY338 [3:0]
WSEQ_DATA_WIDTH339 [2:0]
WSEQ_DELAY339 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA304 [7:0]
0000F000h
WSEQ_ADDR305 [12:0]
WSEQ_DATA_START305 [3:0]
WSEQ_DATA305 [7:0]
0000F000h
WSEQ_ADDR306 [12:0]
WSEQ_DATA_START306 [3:0]
WSEQ_DATA306 [7:0]
0000F000h
WSEQ_ADDR307 [12:0]
WSEQ_DATA_START307 [3:0]
WSEQ_DATA307 [7:0]
0000F000h
WSEQ_ADDR308 [12:0]
WSEQ_DATA_START308 [3:0]
WSEQ_DATA308 [7:0]
0000F000h
WSEQ_ADDR309 [12:0]
WSEQ_DATA_START309 [3:0]
WSEQ_DATA309 [7:0]
0000F000h
WSEQ_ADDR310 [12:0]
WSEQ_DATA_START310 [3:0]
WSEQ_DATA310 [7:0]
0000F000h
WSEQ_ADDR311 [12:0]
WSEQ_DATA_START311 [3:0]
WSEQ_DATA311 [7:0]
0000F000h
WSEQ_ADDR312 [12:0]
WSEQ_DATA_START312 [3:0]
WSEQ_DATA312 [7:0]
0000F000h
WSEQ_ADDR313 [12:0]
WSEQ_DATA_START313 [3:0]
WSEQ_DATA313 [7:0]
0000F000h
WSEQ_ADDR314 [12:0]
WSEQ_DATA_START314 [3:0]
WSEQ_DATA314 [7:0]
0000F000h
WSEQ_ADDR315 [12:0]
WSEQ_DATA_START315 [3:0]
WSEQ_DATA315 [7:0]
0000F000h
WSEQ_ADDR316 [12:0]
WSEQ_DATA_START316 [3:0]
WSEQ_DATA316 [7:0]
0000F000h
WSEQ_ADDR317 [12:0]
WSEQ_DATA_START317 [3:0]
WSEQ_DATA317 [7:0]
0000F000h
WSEQ_ADDR318 [12:0]
WSEQ_DATA_START318 [3:0]
WSEQ_DATA318 [7:0]
0000F000h
WSEQ_ADDR319 [12:0]
WSEQ_DATA_START319 [3:0]
WSEQ_DATA319 [7:0]
0000F000h
WSEQ_ADDR320 [12:0]
WSEQ_DATA_START320 [3:0]
WSEQ_DATA320 [7:0]
0000F000h
WSEQ_ADDR321 [12:0]
WSEQ_DATA_START321 [3:0]
WSEQ_DATA321 [7:0]
0000F000h
WSEQ_ADDR322 [12:0]
WSEQ_DATA_START322 [3:0]
WSEQ_DATA322 [7:0]
0000F000h
WSEQ_ADDR323 [12:0]
WSEQ_DATA_START323 [3:0]
WSEQ_DATA323 [7:0]
0000F000h
WSEQ_ADDR324 [12:0]
WSEQ_DATA_START324 [3:0]
WSEQ_DATA324 [7:0]
0000F000h
WSEQ_ADDR325 [12:0]
WSEQ_DATA_START325 [3:0]
WSEQ_DATA325 [7:0]
0000F000h
WSEQ_ADDR326 [12:0]
WSEQ_DATA_START326 [3:0]
WSEQ_DATA326 [7:0]
0000F000h
WSEQ_ADDR327 [12:0]
WSEQ_DATA_START327 [3:0]
WSEQ_DATA327 [7:0]
0000F000h
WSEQ_ADDR328 [12:0]
WSEQ_DATA_START328 [3:0]
WSEQ_DATA328 [7:0]
0000F000h
WSEQ_ADDR329 [12:0]
WSEQ_DATA_START329 [3:0]
WSEQ_DATA329 [7:0]
0000F000h
WSEQ_ADDR330 [12:0]
WSEQ_DATA_START330 [3:0]
WSEQ_DATA330 [7:0]
0000F000h
WSEQ_ADDR331 [12:0]
WSEQ_DATA_START331 [3:0]
WSEQ_DATA331 [7:0]
0000F000h
WSEQ_ADDR332 [12:0]
WSEQ_DATA_START332 [3:0]
WSEQ_DATA332 [7:0]
0000F000h
WSEQ_ADDR333 [12:0]
WSEQ_DATA_START333 [3:0]
WSEQ_DATA333 [7:0]
0000F000h
WSEQ_ADDR334 [12:0]
WSEQ_DATA_START334 [3:0]
WSEQ_DATA334 [7:0]
0000F000h
WSEQ_ADDR335 [12:0]
WSEQ_DATA_START335 [3:0]
WSEQ_DATA335 [7:0]
0000F000h
WSEQ_ADDR336 [12:0]
WSEQ_DATA_START336 [3:0]
WSEQ_DATA336 [7:0]
0000F000h
WSEQ_ADDR337 [12:0]
WSEQ_DATA_START337 [3:0]
WSEQ_DATA337 [7:0]
0000F000h
WSEQ_ADDR338 [12:0]
WSEQ_DATA_START338 [3:0]
WSEQ_DATA338 [7:0]
0000F000h
WSEQ_ADDR339 [12:0]
WSEQ_DATA_START339 [3:0]
17
1
0000F000h
WSEQ_ADDR304 [12:0]
WSEQ_DATA_START304 [3:0]
18
2
WSEQ_DATA339 [7:0]
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R12968 WSEQ_Sequence_341
(32A8h)
R12970 WSEQ_Sequence_342
(32AAh)
R12972 WSEQ_Sequence_343
(32ACh)
R12974 WSEQ_Sequence_344
(32AEh)
R12976 WSEQ_Sequence_345
(32B0h)
R12978 WSEQ_Sequence_346
(32B2h)
R12980 WSEQ_Sequence_347
(32B4h)
R12982 WSEQ_Sequence_348
(32B6h)
R12984 WSEQ_Sequence_349
(32B8h)
R12986 WSEQ_Sequence_350
(32BAh)
R12988 WSEQ_Sequence_351
(32BCh)
R12990 WSEQ_Sequence_352
(32BEh)
R12992 WSEQ_Sequence_353
(32C0h)
R12994 WSEQ_Sequence_354
(32C2h)
R12996 WSEQ_Sequence_355
(32C4h)
R12998 WSEQ_Sequence_356
(32C6h)
R13000 WSEQ_Sequence_357
(32C8h)
R13002 WSEQ_Sequence_358
(32CAh)
R13004 WSEQ_Sequence_359
(32CCh)
R13006 WSEQ_Sequence_360
(32CEh)
R13008 WSEQ_Sequence_361
(32D0h)
R13010 WSEQ_Sequence_362
(32D2h)
R13012 WSEQ_Sequence_363
(32D4h)
R13014 WSEQ_Sequence_364
(32D6h)
R13016 WSEQ_Sequence_365
(32D8h)
R13018 WSEQ_Sequence_366
(32DAh)
R13020 WSEQ_Sequence_367
(32DCh)
R13022 WSEQ_Sequence_368
(32DEh)
R13024 WSEQ_Sequence_369
(32E0h)
R13026 WSEQ_Sequence_370
(32E2h)
R13028 WSEQ_Sequence_371
(32E4h)
R13030 WSEQ_Sequence_372
(32E6h)
R13032 WSEQ_Sequence_373
(32E8h)
R13034 WSEQ_Sequence_374
(32EAh)
R13036 WSEQ_Sequence_375
(32ECh)
R13038 WSEQ_Sequence_376
(32EEh)
DS1162F1
31
15
30
14
29
13
WSEQ_DATA_WIDTH340 [2:0]
WSEQ_DELAY340 [3:0]
WSEQ_DATA_WIDTH341 [2:0]
WSEQ_DELAY341 [3:0]
WSEQ_DATA_WIDTH342 [2:0]
WSEQ_DELAY342 [3:0]
WSEQ_DATA_WIDTH343 [2:0]
WSEQ_DELAY343 [3:0]
WSEQ_DATA_WIDTH344 [2:0]
WSEQ_DELAY344 [3:0]
WSEQ_DATA_WIDTH345 [2:0]
WSEQ_DELAY345 [3:0]
WSEQ_DATA_WIDTH346 [2:0]
WSEQ_DELAY346 [3:0]
WSEQ_DATA_WIDTH347 [2:0]
WSEQ_DELAY347 [3:0]
WSEQ_DATA_WIDTH348 [2:0]
WSEQ_DELAY348 [3:0]
WSEQ_DATA_WIDTH349 [2:0]
WSEQ_DELAY349 [3:0]
WSEQ_DATA_WIDTH350 [2:0]
WSEQ_DELAY350 [3:0]
WSEQ_DATA_WIDTH351 [2:0]
WSEQ_DELAY351 [3:0]
WSEQ_DATA_WIDTH352 [2:0]
WSEQ_DELAY352 [3:0]
WSEQ_DATA_WIDTH353 [2:0]
WSEQ_DELAY353 [3:0]
WSEQ_DATA_WIDTH354 [2:0]
WSEQ_DELAY354 [3:0]
WSEQ_DATA_WIDTH355 [2:0]
WSEQ_DELAY355 [3:0]
WSEQ_DATA_WIDTH356 [2:0]
WSEQ_DELAY356 [3:0]
WSEQ_DATA_WIDTH357 [2:0]
WSEQ_DELAY357 [3:0]
WSEQ_DATA_WIDTH358 [2:0]
WSEQ_DELAY358 [3:0]
WSEQ_DATA_WIDTH359 [2:0]
WSEQ_DELAY359 [3:0]
WSEQ_DATA_WIDTH360 [2:0]
WSEQ_DELAY360 [3:0]
WSEQ_DATA_WIDTH361 [2:0]
WSEQ_DELAY361 [3:0]
WSEQ_DATA_WIDTH362 [2:0]
WSEQ_DELAY362 [3:0]
WSEQ_DATA_WIDTH363 [2:0]
WSEQ_DELAY363 [3:0]
WSEQ_DATA_WIDTH364 [2:0]
WSEQ_DELAY364 [3:0]
WSEQ_DATA_WIDTH365 [2:0]
WSEQ_DELAY365 [3:0]
WSEQ_DATA_WIDTH366 [2:0]
WSEQ_DELAY366 [3:0]
WSEQ_DATA_WIDTH367 [2:0]
WSEQ_DELAY367 [3:0]
WSEQ_DATA_WIDTH368 [2:0]
WSEQ_DELAY368 [3:0]
WSEQ_DATA_WIDTH369 [2:0]
WSEQ_DELAY369 [3:0]
WSEQ_DATA_WIDTH370 [2:0]
WSEQ_DELAY370 [3:0]
WSEQ_DATA_WIDTH371 [2:0]
WSEQ_DELAY371 [3:0]
WSEQ_DATA_WIDTH372 [2:0]
WSEQ_DELAY372 [3:0]
WSEQ_DATA_WIDTH373 [2:0]
WSEQ_DELAY373 [3:0]
WSEQ_DATA_WIDTH374 [2:0]
WSEQ_DELAY374 [3:0]
WSEQ_DATA_WIDTH375 [2:0]
WSEQ_DELAY375 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA340 [7:0]
0000F000h
WSEQ_ADDR341 [12:0]
WSEQ_DATA_START341 [3:0]
WSEQ_DATA341 [7:0]
0000F000h
WSEQ_ADDR342 [12:0]
WSEQ_DATA_START342 [3:0]
WSEQ_DATA342 [7:0]
0000F000h
WSEQ_ADDR343 [12:0]
WSEQ_DATA_START343 [3:0]
WSEQ_DATA343 [7:0]
0000F000h
WSEQ_ADDR344 [12:0]
WSEQ_DATA_START344 [3:0]
WSEQ_DATA344 [7:0]
0000F000h
WSEQ_ADDR345 [12:0]
WSEQ_DATA_START345 [3:0]
WSEQ_DATA345 [7:0]
0000F000h
WSEQ_ADDR346 [12:0]
WSEQ_DATA_START346 [3:0]
WSEQ_DATA346 [7:0]
0000F000h
WSEQ_ADDR347 [12:0]
WSEQ_DATA_START347 [3:0]
WSEQ_DATA347 [7:0]
0000F000h
WSEQ_ADDR348 [12:0]
WSEQ_DATA_START348 [3:0]
WSEQ_DATA348 [7:0]
0000F000h
WSEQ_ADDR349 [12:0]
WSEQ_DATA_START349 [3:0]
WSEQ_DATA349 [7:0]
0000F000h
WSEQ_ADDR350 [12:0]
WSEQ_DATA_START350 [3:0]
WSEQ_DATA350 [7:0]
0000F000h
WSEQ_ADDR351 [12:0]
WSEQ_DATA_START351 [3:0]
WSEQ_DATA351 [7:0]
0000F000h
WSEQ_ADDR352 [12:0]
WSEQ_DATA_START352 [3:0]
WSEQ_DATA352 [7:0]
0000F000h
WSEQ_ADDR353 [12:0]
WSEQ_DATA_START353 [3:0]
WSEQ_DATA353 [7:0]
0000F000h
WSEQ_ADDR354 [12:0]
WSEQ_DATA_START354 [3:0]
WSEQ_DATA354 [7:0]
0000F000h
WSEQ_ADDR355 [12:0]
WSEQ_DATA_START355 [3:0]
WSEQ_DATA355 [7:0]
0000F000h
WSEQ_ADDR356 [12:0]
WSEQ_DATA_START356 [3:0]
WSEQ_DATA356 [7:0]
0000F000h
WSEQ_ADDR357 [12:0]
WSEQ_DATA_START357 [3:0]
WSEQ_DATA357 [7:0]
0000F000h
WSEQ_ADDR358 [12:0]
WSEQ_DATA_START358 [3:0]
WSEQ_DATA358 [7:0]
0000F000h
WSEQ_ADDR359 [12:0]
WSEQ_DATA_START359 [3:0]
WSEQ_DATA359 [7:0]
0000F000h
WSEQ_ADDR360 [12:0]
WSEQ_DATA_START360 [3:0]
WSEQ_DATA360 [7:0]
0000F000h
WSEQ_ADDR361 [12:0]
WSEQ_DATA_START361 [3:0]
WSEQ_DATA361 [7:0]
0000F000h
WSEQ_ADDR362 [12:0]
WSEQ_DATA_START362 [3:0]
WSEQ_DATA362 [7:0]
0000F000h
WSEQ_ADDR363 [12:0]
WSEQ_DATA_START363 [3:0]
WSEQ_DATA363 [7:0]
0000F000h
WSEQ_ADDR364 [12:0]
WSEQ_DATA_START364 [3:0]
WSEQ_DATA364 [7:0]
0000F000h
WSEQ_ADDR365 [12:0]
WSEQ_DATA_START365 [3:0]
WSEQ_DATA365 [7:0]
0000F000h
WSEQ_ADDR366 [12:0]
WSEQ_DATA_START366 [3:0]
WSEQ_DATA366 [7:0]
0000F000h
WSEQ_ADDR367 [12:0]
WSEQ_DATA_START367 [3:0]
WSEQ_DATA367 [7:0]
0000F000h
WSEQ_ADDR368 [12:0]
WSEQ_DATA_START368 [3:0]
WSEQ_DATA368 [7:0]
0000F000h
WSEQ_ADDR369 [12:0]
WSEQ_DATA_START369 [3:0]
WSEQ_DATA369 [7:0]
0000F000h
WSEQ_ADDR370 [12:0]
WSEQ_DATA_START370 [3:0]
WSEQ_DATA370 [7:0]
0000F000h
WSEQ_ADDR371 [12:0]
WSEQ_DATA_START371 [3:0]
WSEQ_DATA371 [7:0]
0000F000h
WSEQ_ADDR372 [12:0]
WSEQ_DATA_START372 [3:0]
WSEQ_DATA372 [7:0]
0000F000h
WSEQ_ADDR373 [12:0]
WSEQ_DATA_START373 [3:0]
WSEQ_DATA373 [7:0]
0000F000h
WSEQ_ADDR374 [12:0]
WSEQ_DATA_START374 [3:0]
WSEQ_DATA374 [7:0]
0000F000h
WSEQ_ADDR375 [12:0]
WSEQ_DATA_START375 [3:0]
17
1
0000F000h
WSEQ_ADDR340 [12:0]
WSEQ_DATA_START340 [3:0]
18
2
WSEQ_DATA375 [7:0]
321
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R13040 WSEQ_Sequence_377
(32F0h)
R13042 WSEQ_Sequence_378
(32F2h)
R13044 WSEQ_Sequence_379
(32F4h)
R13046 WSEQ_Sequence_380
(32F6h)
R13048 WSEQ_Sequence_381
(32F8h)
R13050 WSEQ_Sequence_382
(32FAh)
R13052 WSEQ_Sequence_383
(32FCh)
R13054 WSEQ_Sequence_384
(32FEh)
R13056 WSEQ_Sequence_385
(3300h)
R13058 WSEQ_Sequence_386
(3302h)
R13060 WSEQ_Sequence_387
(3304h)
R13062 WSEQ_Sequence_388
(3306h)
R13064 WSEQ_Sequence_389
(3308h)
R13066 WSEQ_Sequence_390
(330Ah)
R13068 WSEQ_Sequence_391
(330Ch)
R13070 WSEQ_Sequence_392
(330Eh)
R13072 WSEQ_Sequence_393
(3310h)
R13074 WSEQ_Sequence_394
(3312h)
R13076 WSEQ_Sequence_395
(3314h)
R13078 WSEQ_Sequence_396
(3316h)
R13080 WSEQ_Sequence_397
(3318h)
R13082 WSEQ_Sequence_398
(331Ah)
R13084 WSEQ_Sequence_399
(331Ch)
R13086 WSEQ_Sequence_400
(331Eh)
R13088 WSEQ_Sequence_401
(3320h)
R13090 WSEQ_Sequence_402
(3322h)
R13092 WSEQ_Sequence_403
(3324h)
R13094 WSEQ_Sequence_404
(3326h)
R13096 WSEQ_Sequence_405
(3328h)
R13098 WSEQ_Sequence_406
(332Ah)
R13100 WSEQ_Sequence_407
(332Ch)
R13102 WSEQ_Sequence_408
(332Eh)
R13104 WSEQ_Sequence_409
(3330h)
R13106 WSEQ_Sequence_410
(3332h)
R13108 WSEQ_Sequence_411
(3334h)
R13110 WSEQ_Sequence_412
(3336h)
322
31
15
30
14
29
13
WSEQ_DATA_WIDTH376 [2:0]
WSEQ_DELAY376 [3:0]
WSEQ_DATA_WIDTH377 [2:0]
WSEQ_DELAY377 [3:0]
WSEQ_DATA_WIDTH378 [2:0]
WSEQ_DELAY378 [3:0]
WSEQ_DATA_WIDTH379 [2:0]
WSEQ_DELAY379 [3:0]
WSEQ_DATA_WIDTH380 [2:0]
WSEQ_DELAY380 [3:0]
WSEQ_DATA_WIDTH381 [2:0]
WSEQ_DELAY381 [3:0]
WSEQ_DATA_WIDTH382 [2:0]
WSEQ_DELAY382 [3:0]
WSEQ_DATA_WIDTH383 [2:0]
WSEQ_DELAY383 [3:0]
WSEQ_DATA_WIDTH384 [2:0]
WSEQ_DELAY384 [3:0]
WSEQ_DATA_WIDTH385 [2:0]
WSEQ_DELAY385 [3:0]
WSEQ_DATA_WIDTH386 [2:0]
WSEQ_DELAY386 [3:0]
WSEQ_DATA_WIDTH387 [2:0]
WSEQ_DELAY387 [3:0]
WSEQ_DATA_WIDTH388 [2:0]
WSEQ_DELAY388 [3:0]
WSEQ_DATA_WIDTH389 [2:0]
WSEQ_DELAY389 [3:0]
WSEQ_DATA_WIDTH390 [2:0]
WSEQ_DELAY390 [3:0]
WSEQ_DATA_WIDTH391 [2:0]
WSEQ_DELAY391 [3:0]
WSEQ_DATA_WIDTH392 [2:0]
WSEQ_DELAY392 [3:0]
WSEQ_DATA_WIDTH393 [2:0]
WSEQ_DELAY393 [3:0]
WSEQ_DATA_WIDTH394 [2:0]
WSEQ_DELAY394 [3:0]
WSEQ_DATA_WIDTH395 [2:0]
WSEQ_DELAY395 [3:0]
WSEQ_DATA_WIDTH396 [2:0]
WSEQ_DELAY396 [3:0]
WSEQ_DATA_WIDTH397 [2:0]
WSEQ_DELAY397 [3:0]
WSEQ_DATA_WIDTH398 [2:0]
WSEQ_DELAY398 [3:0]
WSEQ_DATA_WIDTH399 [2:0]
WSEQ_DELAY399 [3:0]
WSEQ_DATA_WIDTH400 [2:0]
WSEQ_DELAY400 [3:0]
WSEQ_DATA_WIDTH401 [2:0]
WSEQ_DELAY401 [3:0]
WSEQ_DATA_WIDTH402 [2:0]
WSEQ_DELAY402 [3:0]
WSEQ_DATA_WIDTH403 [2:0]
WSEQ_DELAY403 [3:0]
WSEQ_DATA_WIDTH404 [2:0]
WSEQ_DELAY404 [3:0]
WSEQ_DATA_WIDTH405 [2:0]
WSEQ_DELAY405 [3:0]
WSEQ_DATA_WIDTH406 [2:0]
WSEQ_DELAY406 [3:0]
WSEQ_DATA_WIDTH407 [2:0]
WSEQ_DELAY407 [3:0]
WSEQ_DATA_WIDTH408 [2:0]
WSEQ_DELAY408 [3:0]
WSEQ_DATA_WIDTH409 [2:0]
WSEQ_DELAY409 [3:0]
WSEQ_DATA_WIDTH410 [2:0]
WSEQ_DELAY410 [3:0]
WSEQ_DATA_WIDTH411 [2:0]
WSEQ_DELAY411 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA376 [7:0]
0000F000h
WSEQ_ADDR377 [12:0]
WSEQ_DATA_START377 [3:0]
WSEQ_DATA377 [7:0]
0000F000h
WSEQ_ADDR378 [12:0]
WSEQ_DATA_START378 [3:0]
WSEQ_DATA378 [7:0]
0000F000h
WSEQ_ADDR379 [12:0]
WSEQ_DATA_START379 [3:0]
WSEQ_DATA379 [7:0]
0000F000h
WSEQ_ADDR380 [12:0]
WSEQ_DATA_START380 [3:0]
WSEQ_DATA380 [7:0]
0000F000h
WSEQ_ADDR381 [12:0]
WSEQ_DATA_START381 [3:0]
WSEQ_DATA381 [7:0]
0000F000h
WSEQ_ADDR382 [12:0]
WSEQ_DATA_START382 [3:0]
WSEQ_DATA382 [7:0]
0000F000h
WSEQ_ADDR383 [12:0]
WSEQ_DATA_START383 [3:0]
WSEQ_DATA383 [7:0]
FFFFFFFFh
WSEQ_ADDR384 [12:0]
WSEQ_DATA_START384 [3:0]
WSEQ_DATA384 [7:0]
FFFFFFFFh
WSEQ_ADDR385 [12:0]
WSEQ_DATA_START385 [3:0]
WSEQ_DATA385 [7:0]
FFFFFFFFh
WSEQ_ADDR386 [12:0]
WSEQ_DATA_START386 [3:0]
WSEQ_DATA386 [7:0]
FFFFFFFFh
WSEQ_ADDR387 [12:0]
WSEQ_DATA_START387 [3:0]
WSEQ_DATA387 [7:0]
FFFFFFFFh
WSEQ_ADDR388 [12:0]
WSEQ_DATA_START388 [3:0]
WSEQ_DATA388 [7:0]
FFFFFFFFh
WSEQ_ADDR389 [12:0]
WSEQ_DATA_START389 [3:0]
WSEQ_DATA389 [7:0]
FFFFFFFFh
WSEQ_ADDR390 [12:0]
WSEQ_DATA_START390 [3:0]
WSEQ_DATA390 [7:0]
FFFFFFFFh
WSEQ_ADDR391 [12:0]
WSEQ_DATA_START391 [3:0]
WSEQ_DATA391 [7:0]
FFFFFFFFh
WSEQ_ADDR392 [12:0]
WSEQ_DATA_START392 [3:0]
WSEQ_DATA392 [7:0]
FFFFFFFFh
WSEQ_ADDR393 [12:0]
WSEQ_DATA_START393 [3:0]
WSEQ_DATA393 [7:0]
FFFFFFFFh
WSEQ_ADDR394 [12:0]
WSEQ_DATA_START394 [3:0]
WSEQ_DATA394 [7:0]
FFFFFFFFh
WSEQ_ADDR395 [12:0]
WSEQ_DATA_START395 [3:0]
WSEQ_DATA395 [7:0]
FFFFFFFFh
WSEQ_ADDR396 [12:0]
WSEQ_DATA_START396 [3:0]
WSEQ_DATA396 [7:0]
FFFFFFFFh
WSEQ_ADDR397 [12:0]
WSEQ_DATA_START397 [3:0]
WSEQ_DATA397 [7:0]
FFFFFFFFh
WSEQ_ADDR398 [12:0]
WSEQ_DATA_START398 [3:0]
WSEQ_DATA398 [7:0]
FFFFFFFFh
WSEQ_ADDR399 [12:0]
WSEQ_DATA_START399 [3:0]
WSEQ_DATA399 [7:0]
FFFFFFFFh
WSEQ_ADDR400 [12:0]
WSEQ_DATA_START400 [3:0]
WSEQ_DATA400 [7:0]
FFFFFFFFh
WSEQ_ADDR401 [12:0]
WSEQ_DATA_START401 [3:0]
WSEQ_DATA401 [7:0]
FFFFFFFFh
WSEQ_ADDR402 [12:0]
WSEQ_DATA_START402 [3:0]
WSEQ_DATA402 [7:0]
FFFFFFFFh
WSEQ_ADDR403 [12:0]
WSEQ_DATA_START403 [3:0]
WSEQ_DATA403 [7:0]
FFFFFFFFh
WSEQ_ADDR404 [12:0]
WSEQ_DATA_START404 [3:0]
WSEQ_DATA404 [7:0]
FFFFFFFFh
WSEQ_ADDR405 [12:0]
WSEQ_DATA_START405 [3:0]
WSEQ_DATA405 [7:0]
FFFFFFFFh
WSEQ_ADDR406 [12:0]
WSEQ_DATA_START406 [3:0]
WSEQ_DATA406 [7:0]
FFFFFFFFh
WSEQ_ADDR407 [12:0]
WSEQ_DATA_START407 [3:0]
WSEQ_DATA407 [7:0]
FFFFFFFFh
WSEQ_ADDR408 [12:0]
WSEQ_DATA_START408 [3:0]
WSEQ_DATA408 [7:0]
FFFFFFFFh
WSEQ_ADDR409 [12:0]
WSEQ_DATA_START409 [3:0]
WSEQ_DATA409 [7:0]
FFFFFFFFh
WSEQ_ADDR410 [12:0]
WSEQ_DATA_START410 [3:0]
WSEQ_DATA410 [7:0]
FFFFFFFFh
WSEQ_ADDR411 [12:0]
WSEQ_DATA_START411 [3:0]
17
1
0000F000h
WSEQ_ADDR376 [12:0]
WSEQ_DATA_START376 [3:0]
18
2
WSEQ_DATA411 [7:0]
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R13112 WSEQ_Sequence_413
(3338h)
R13114 WSEQ_Sequence_414
(333Ah)
R13116 WSEQ_Sequence_415
(333Ch)
R13118 WSEQ_Sequence_416
(333Eh)
R13120 WSEQ_Sequence_417
(3340h)
R13122 WSEQ_Sequence_418
(3342h)
R13124 WSEQ_Sequence_419
(3344h)
R13126 WSEQ_Sequence_420
(3346h)
R13128 WSEQ_Sequence_421
(3348h)
R13130 WSEQ_Sequence_422
(334Ah)
R13132 WSEQ_Sequence_423
(334Ch)
R13134 WSEQ_Sequence_424
(334Eh)
R13136 WSEQ_Sequence_425
(3350h)
R13138 WSEQ_Sequence_426
(3352h)
R13140 WSEQ_Sequence_427
(3354h)
R13142 WSEQ_Sequence_428
(3356h)
R13144 WSEQ_Sequence_429
(3358h)
R13146 WSEQ_Sequence_430
(335Ah)
R13148 WSEQ_Sequence_431
(335Ch)
R13150 WSEQ_Sequence_432
(335Eh)
R13152 WSEQ_Sequence_433
(3360h)
R13154 WSEQ_Sequence_434
(3362h)
R13156 WSEQ_Sequence_435
(3364h)
R13158 WSEQ_Sequence_436
(3366h)
R13160 WSEQ_Sequence_437
(3368h)
R13162 WSEQ_Sequence_438
(336Ah)
R13164 WSEQ_Sequence_439
(336Ch)
R13166 WSEQ_Sequence_440
(336Eh)
R13168 WSEQ_Sequence_441
(3370h)
R13170 WSEQ_Sequence_442
(3372h)
R13172 WSEQ_Sequence_443
(3374h)
R13174 WSEQ_Sequence_444
(3376h)
R13176 WSEQ_Sequence_445
(3378h)
R13178 WSEQ_Sequence_446
(337Ah)
R13180 WSEQ_Sequence_447
(337Ch)
R13182 WSEQ_Sequence_448
(337Eh)
DS1162F1
31
15
30
14
29
13
WSEQ_DATA_WIDTH412 [2:0]
WSEQ_DELAY412 [3:0]
WSEQ_DATA_WIDTH413 [2:0]
WSEQ_DELAY413 [3:0]
WSEQ_DATA_WIDTH414 [2:0]
WSEQ_DELAY414 [3:0]
WSEQ_DATA_WIDTH415 [2:0]
WSEQ_DELAY415 [3:0]
WSEQ_DATA_WIDTH416 [2:0]
WSEQ_DELAY416 [3:0]
WSEQ_DATA_WIDTH417 [2:0]
WSEQ_DELAY417 [3:0]
WSEQ_DATA_WIDTH418 [2:0]
WSEQ_DELAY418 [3:0]
WSEQ_DATA_WIDTH419 [2:0]
WSEQ_DELAY419 [3:0]
WSEQ_DATA_WIDTH420 [2:0]
WSEQ_DELAY420 [3:0]
WSEQ_DATA_WIDTH421 [2:0]
WSEQ_DELAY421 [3:0]
WSEQ_DATA_WIDTH422 [2:0]
WSEQ_DELAY422 [3:0]
WSEQ_DATA_WIDTH423 [2:0]
WSEQ_DELAY423 [3:0]
WSEQ_DATA_WIDTH424 [2:0]
WSEQ_DELAY424 [3:0]
WSEQ_DATA_WIDTH425 [2:0]
WSEQ_DELAY425 [3:0]
WSEQ_DATA_WIDTH426 [2:0]
WSEQ_DELAY426 [3:0]
WSEQ_DATA_WIDTH427 [2:0]
WSEQ_DELAY427 [3:0]
WSEQ_DATA_WIDTH428 [2:0]
WSEQ_DELAY428 [3:0]
WSEQ_DATA_WIDTH429 [2:0]
WSEQ_DELAY429 [3:0]
WSEQ_DATA_WIDTH430 [2:0]
WSEQ_DELAY430 [3:0]
WSEQ_DATA_WIDTH431 [2:0]
WSEQ_DELAY431 [3:0]
WSEQ_DATA_WIDTH432 [2:0]
WSEQ_DELAY432 [3:0]
WSEQ_DATA_WIDTH433 [2:0]
WSEQ_DELAY433 [3:0]
WSEQ_DATA_WIDTH434 [2:0]
WSEQ_DELAY434 [3:0]
WSEQ_DATA_WIDTH435 [2:0]
WSEQ_DELAY435 [3:0]
WSEQ_DATA_WIDTH436 [2:0]
WSEQ_DELAY436 [3:0]
WSEQ_DATA_WIDTH437 [2:0]
WSEQ_DELAY437 [3:0]
WSEQ_DATA_WIDTH438 [2:0]
WSEQ_DELAY438 [3:0]
WSEQ_DATA_WIDTH439 [2:0]
WSEQ_DELAY439 [3:0]
WSEQ_DATA_WIDTH440 [2:0]
WSEQ_DELAY440 [3:0]
WSEQ_DATA_WIDTH441 [2:0]
WSEQ_DELAY441 [3:0]
WSEQ_DATA_WIDTH442 [2:0]
WSEQ_DELAY442 [3:0]
WSEQ_DATA_WIDTH443 [2:0]
WSEQ_DELAY443 [3:0]
WSEQ_DATA_WIDTH444 [2:0]
WSEQ_DELAY444 [3:0]
WSEQ_DATA_WIDTH445 [2:0]
WSEQ_DELAY445 [3:0]
WSEQ_DATA_WIDTH446 [2:0]
WSEQ_DELAY446 [3:0]
WSEQ_DATA_WIDTH447 [2:0]
WSEQ_DELAY447 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA412 [7:0]
FFFFFFFFh
WSEQ_ADDR413 [12:0]
WSEQ_DATA_START413 [3:0]
WSEQ_DATA413 [7:0]
FFFFFFFFh
WSEQ_ADDR414 [12:0]
WSEQ_DATA_START414 [3:0]
WSEQ_DATA414 [7:0]
FFFFFFFFh
WSEQ_ADDR415 [12:0]
WSEQ_DATA_START415 [3:0]
WSEQ_DATA415 [7:0]
FFFFFFFFh
WSEQ_ADDR416 [12:0]
WSEQ_DATA_START416 [3:0]
WSEQ_DATA416 [7:0]
FFFFFFFFh
WSEQ_ADDR417 [12:0]
WSEQ_DATA_START417 [3:0]
WSEQ_DATA417 [7:0]
FFFFFFFFh
WSEQ_ADDR418 [12:0]
WSEQ_DATA_START418 [3:0]
WSEQ_DATA418 [7:0]
FFFFFFFFh
WSEQ_ADDR419 [12:0]
WSEQ_DATA_START419 [3:0]
WSEQ_DATA419 [7:0]
FFFFFFFFh
WSEQ_ADDR420 [12:0]
WSEQ_DATA_START420 [3:0]
WSEQ_DATA420 [7:0]
FFFFFFFFh
WSEQ_ADDR421 [12:0]
WSEQ_DATA_START421 [3:0]
WSEQ_DATA421 [7:0]
FFFFFFFFh
WSEQ_ADDR422 [12:0]
WSEQ_DATA_START422 [3:0]
WSEQ_DATA422 [7:0]
FFFFFFFFh
WSEQ_ADDR423 [12:0]
WSEQ_DATA_START423 [3:0]
WSEQ_DATA423 [7:0]
FFFFFFFFh
WSEQ_ADDR424 [12:0]
WSEQ_DATA_START424 [3:0]
WSEQ_DATA424 [7:0]
FFFFFFFFh
WSEQ_ADDR425 [12:0]
WSEQ_DATA_START425 [3:0]
WSEQ_DATA425 [7:0]
FFFFFFFFh
WSEQ_ADDR426 [12:0]
WSEQ_DATA_START426 [3:0]
WSEQ_DATA426 [7:0]
FFFFFFFFh
WSEQ_ADDR427 [12:0]
WSEQ_DATA_START427 [3:0]
WSEQ_DATA427 [7:0]
FFFFFFFFh
WSEQ_ADDR428 [12:0]
WSEQ_DATA_START428 [3:0]
WSEQ_DATA428 [7:0]
FFFFFFFFh
WSEQ_ADDR429 [12:0]
WSEQ_DATA_START429 [3:0]
WSEQ_DATA429 [7:0]
FFFFFFFFh
WSEQ_ADDR430 [12:0]
WSEQ_DATA_START430 [3:0]
WSEQ_DATA430 [7:0]
FFFFFFFFh
WSEQ_ADDR431 [12:0]
WSEQ_DATA_START431 [3:0]
WSEQ_DATA431 [7:0]
FFFFFFFFh
WSEQ_ADDR432 [12:0]
WSEQ_DATA_START432 [3:0]
WSEQ_DATA432 [7:0]
FFFFFFFFh
WSEQ_ADDR433 [12:0]
WSEQ_DATA_START433 [3:0]
WSEQ_DATA433 [7:0]
FFFFFFFFh
WSEQ_ADDR434 [12:0]
WSEQ_DATA_START434 [3:0]
WSEQ_DATA434 [7:0]
FFFFFFFFh
WSEQ_ADDR435 [12:0]
WSEQ_DATA_START435 [3:0]
WSEQ_DATA435 [7:0]
FFFFFFFFh
WSEQ_ADDR436 [12:0]
WSEQ_DATA_START436 [3:0]
WSEQ_DATA436 [7:0]
FFFFFFFFh
WSEQ_ADDR437 [12:0]
WSEQ_DATA_START437 [3:0]
WSEQ_DATA437 [7:0]
FFFFFFFFh
WSEQ_ADDR438 [12:0]
WSEQ_DATA_START438 [3:0]
WSEQ_DATA438 [7:0]
FFFFFFFFh
WSEQ_ADDR439 [12:0]
WSEQ_DATA_START439 [3:0]
WSEQ_DATA439 [7:0]
FFFFFFFFh
WSEQ_ADDR440 [12:0]
WSEQ_DATA_START440 [3:0]
WSEQ_DATA440 [7:0]
FFFFFFFFh
WSEQ_ADDR441 [12:0]
WSEQ_DATA_START441 [3:0]
WSEQ_DATA441 [7:0]
FFFFFFFFh
WSEQ_ADDR442 [12:0]
WSEQ_DATA_START442 [3:0]
WSEQ_DATA442 [7:0]
FFFFFFFFh
WSEQ_ADDR443 [12:0]
WSEQ_DATA_START443 [3:0]
WSEQ_DATA443 [7:0]
FFFFFFFFh
WSEQ_ADDR444 [12:0]
WSEQ_DATA_START444 [3:0]
WSEQ_DATA444 [7:0]
FFFFFFFFh
WSEQ_ADDR445 [12:0]
WSEQ_DATA_START445 [3:0]
WSEQ_DATA445 [7:0]
FFFFFFFFh
WSEQ_ADDR446 [12:0]
WSEQ_DATA_START446 [3:0]
WSEQ_DATA446 [7:0]
FFFFFFFFh
WSEQ_ADDR447 [12:0]
WSEQ_DATA_START447 [3:0]
17
1
FFFFFFFFh
WSEQ_ADDR412 [12:0]
WSEQ_DATA_START412 [3:0]
18
2
WSEQ_DATA447 [7:0]
323
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R13184 WSEQ_Sequence_449
(3380h)
R13186 WSEQ_Sequence_450
(3382h)
R13188 WSEQ_Sequence_451
(3384h)
R13190 WSEQ_Sequence_452
(3386h)
R13192 WSEQ_Sequence_453
(3388h)
R13194 WSEQ_Sequence_454
(338Ah)
R13196 WSEQ_Sequence_455
(338Ch)
R13198 WSEQ_Sequence_456
(338Eh)
R13200 WSEQ_Sequence_457
(3390h)
R13202 WSEQ_Sequence_458
(3392h)
R13204 WSEQ_Sequence_459
(3394h)
R13206 WSEQ_Sequence_460
(3396h)
R13208 WSEQ_Sequence_461
(3398h)
R13210 WSEQ_Sequence_462
(339Ah)
R13212 WSEQ_Sequence_463
(339Ch)
R13214 WSEQ_Sequence_464
(339Eh)
R13216 WSEQ_Sequence_465
(33A0h)
R13218 WSEQ_Sequence_466
(33A2h)
R13220 WSEQ_Sequence_467
(33A4h)
R13222 WSEQ_Sequence_468
(33A6h)
R13224 WSEQ_Sequence_469
(33A8h)
R13226 WSEQ_Sequence_470
(33AAh)
R13228 WSEQ_Sequence_471
(33ACh)
R13230 WSEQ_Sequence_472
(33AEh)
R13232 WSEQ_Sequence_473
(33B0h)
R13234 WSEQ_Sequence_474
(33B2h)
R13236 WSEQ_Sequence_475
(33B4h)
R13238 WSEQ_Sequence_476
(33B6h)
R13240 WSEQ_Sequence_477
(33B8h)
R13242 WSEQ_Sequence_478
(33BAh)
R13244 WSEQ_Sequence_479
(33BCh)
R13246 WSEQ_Sequence_480
(33BEh)
R13248 WSEQ_Sequence_481
(33C0h)
R13250 WSEQ_Sequence_482
(33C2h)
R13252 WSEQ_Sequence_483
(33C4h)
R13254 WSEQ_Sequence_484
(33C6h)
324
31
15
30
14
29
13
WSEQ_DATA_WIDTH448 [2:0]
WSEQ_DELAY448 [3:0]
WSEQ_DATA_WIDTH449 [2:0]
WSEQ_DELAY449 [3:0]
WSEQ_DATA_WIDTH450 [2:0]
WSEQ_DELAY450 [3:0]
WSEQ_DATA_WIDTH451 [2:0]
WSEQ_DELAY451 [3:0]
WSEQ_DATA_WIDTH452 [2:0]
WSEQ_DELAY452 [3:0]
WSEQ_DATA_WIDTH453 [2:0]
WSEQ_DELAY453 [3:0]
WSEQ_DATA_WIDTH454 [2:0]
WSEQ_DELAY454 [3:0]
WSEQ_DATA_WIDTH455 [2:0]
WSEQ_DELAY455 [3:0]
WSEQ_DATA_WIDTH456 [2:0]
WSEQ_DELAY456 [3:0]
WSEQ_DATA_WIDTH457 [2:0]
WSEQ_DELAY457 [3:0]
WSEQ_DATA_WIDTH458 [2:0]
WSEQ_DELAY458 [3:0]
WSEQ_DATA_WIDTH459 [2:0]
WSEQ_DELAY459 [3:0]
WSEQ_DATA_WIDTH460 [2:0]
WSEQ_DELAY460 [3:0]
WSEQ_DATA_WIDTH461 [2:0]
WSEQ_DELAY461 [3:0]
WSEQ_DATA_WIDTH462 [2:0]
WSEQ_DELAY462 [3:0]
WSEQ_DATA_WIDTH463 [2:0]
WSEQ_DELAY463 [3:0]
WSEQ_DATA_WIDTH464 [2:0]
WSEQ_DELAY464 [3:0]
WSEQ_DATA_WIDTH465 [2:0]
WSEQ_DELAY465 [3:0]
WSEQ_DATA_WIDTH466 [2:0]
WSEQ_DELAY466 [3:0]
WSEQ_DATA_WIDTH467 [2:0]
WSEQ_DELAY467 [3:0]
WSEQ_DATA_WIDTH468 [2:0]
WSEQ_DELAY468 [3:0]
WSEQ_DATA_WIDTH469 [2:0]
WSEQ_DELAY469 [3:0]
WSEQ_DATA_WIDTH470 [2:0]
WSEQ_DELAY470 [3:0]
WSEQ_DATA_WIDTH471 [2:0]
WSEQ_DELAY471 [3:0]
WSEQ_DATA_WIDTH472 [2:0]
WSEQ_DELAY472 [3:0]
WSEQ_DATA_WIDTH473 [2:0]
WSEQ_DELAY473 [3:0]
WSEQ_DATA_WIDTH474 [2:0]
WSEQ_DELAY474 [3:0]
WSEQ_DATA_WIDTH475 [2:0]
WSEQ_DELAY475 [3:0]
WSEQ_DATA_WIDTH476 [2:0]
WSEQ_DELAY476 [3:0]
WSEQ_DATA_WIDTH477 [2:0]
WSEQ_DELAY477 [3:0]
WSEQ_DATA_WIDTH478 [2:0]
WSEQ_DELAY478 [3:0]
WSEQ_DATA_WIDTH479 [2:0]
WSEQ_DELAY479 [3:0]
WSEQ_DATA_WIDTH480 [2:0]
WSEQ_DELAY480 [3:0]
WSEQ_DATA_WIDTH481 [2:0]
WSEQ_DELAY481 [3:0]
WSEQ_DATA_WIDTH482 [2:0]
WSEQ_DELAY482 [3:0]
WSEQ_DATA_WIDTH483 [2:0]
WSEQ_DELAY483 [3:0]
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
16
0
Default
WSEQ_DATA448 [7:0]
FFFFFFFFh
WSEQ_ADDR449 [12:0]
WSEQ_DATA_START449 [3:0]
WSEQ_DATA449 [7:0]
FFFFFFFFh
WSEQ_ADDR450 [12:0]
WSEQ_DATA_START450 [3:0]
WSEQ_DATA450 [7:0]
FFFFFFFFh
WSEQ_ADDR451 [12:0]
WSEQ_DATA_START451 [3:0]
WSEQ_DATA451 [7:0]
FFFFFFFFh
WSEQ_ADDR452 [12:0]
WSEQ_DATA_START452 [3:0]
WSEQ_DATA452 [7:0]
FFFFFFFFh
WSEQ_ADDR453 [12:0]
WSEQ_DATA_START453 [3:0]
WSEQ_DATA453 [7:0]
FFFFFFFFh
WSEQ_ADDR454 [12:0]
WSEQ_DATA_START454 [3:0]
WSEQ_DATA454 [7:0]
FFFFFFFFh
WSEQ_ADDR455 [12:0]
WSEQ_DATA_START455 [3:0]
WSEQ_DATA455 [7:0]
FFFFFFFFh
WSEQ_ADDR456 [12:0]
WSEQ_DATA_START456 [3:0]
WSEQ_DATA456 [7:0]
FFFFFFFFh
WSEQ_ADDR457 [12:0]
WSEQ_DATA_START457 [3:0]
WSEQ_DATA457 [7:0]
FFFFFFFFh
WSEQ_ADDR458 [12:0]
WSEQ_DATA_START458 [3:0]
WSEQ_DATA458 [7:0]
FFFFFFFFh
WSEQ_ADDR459 [12:0]
WSEQ_DATA_START459 [3:0]
WSEQ_DATA459 [7:0]
FFFFFFFFh
WSEQ_ADDR460 [12:0]
WSEQ_DATA_START460 [3:0]
WSEQ_DATA460 [7:0]
FFFFFFFFh
WSEQ_ADDR461 [12:0]
WSEQ_DATA_START461 [3:0]
WSEQ_DATA461 [7:0]
FFFFFFFFh
WSEQ_ADDR462 [12:0]
WSEQ_DATA_START462 [3:0]
WSEQ_DATA462 [7:0]
FFFFFFFFh
WSEQ_ADDR463 [12:0]
WSEQ_DATA_START463 [3:0]
WSEQ_DATA463 [7:0]
FFFFFFFFh
WSEQ_ADDR464 [12:0]
WSEQ_DATA_START464 [3:0]
WSEQ_DATA464 [7:0]
FFFFFFFFh
WSEQ_ADDR465 [12:0]
WSEQ_DATA_START465 [3:0]
WSEQ_DATA465 [7:0]
FFFFFFFFh
WSEQ_ADDR466 [12:0]
WSEQ_DATA_START466 [3:0]
WSEQ_DATA466 [7:0]
FFFFFFFFh
WSEQ_ADDR467 [12:0]
WSEQ_DATA_START467 [3:0]
WSEQ_DATA467 [7:0]
FFFFFFFFh
WSEQ_ADDR468 [12:0]
WSEQ_DATA_START468 [3:0]
WSEQ_DATA468 [7:0]
FFFFFFFFh
WSEQ_ADDR469 [12:0]
WSEQ_DATA_START469 [3:0]
WSEQ_DATA469 [7:0]
FFFFFFFFh
WSEQ_ADDR470 [12:0]
WSEQ_DATA_START470 [3:0]
WSEQ_DATA470 [7:0]
FFFFFFFFh
WSEQ_ADDR471 [12:0]
WSEQ_DATA_START471 [3:0]
WSEQ_DATA471 [7:0]
FFFFFFFFh
WSEQ_ADDR472 [12:0]
WSEQ_DATA_START472 [3:0]
WSEQ_DATA472 [7:0]
FFFFFFFFh
WSEQ_ADDR473 [12:0]
WSEQ_DATA_START473 [3:0]
WSEQ_DATA473 [7:0]
FFFFFFFFh
WSEQ_ADDR474 [12:0]
WSEQ_DATA_START474 [3:0]
WSEQ_DATA474 [7:0]
FFFFFFFFh
WSEQ_ADDR475 [12:0]
WSEQ_DATA_START475 [3:0]
WSEQ_DATA475 [7:0]
FFFFFFFFh
WSEQ_ADDR476 [12:0]
WSEQ_DATA_START476 [3:0]
WSEQ_DATA476 [7:0]
FFFFFFFFh
WSEQ_ADDR477 [12:0]
WSEQ_DATA_START477 [3:0]
WSEQ_DATA477 [7:0]
FFFFFFFFh
WSEQ_ADDR478 [12:0]
WSEQ_DATA_START478 [3:0]
WSEQ_DATA478 [7:0]
FFFFFFFFh
WSEQ_ADDR479 [12:0]
WSEQ_DATA_START479 [3:0]
WSEQ_DATA479 [7:0]
FFFFFFFFh
WSEQ_ADDR480 [12:0]
WSEQ_DATA_START480 [3:0]
WSEQ_DATA480 [7:0]
FFFFFFFFh
WSEQ_ADDR481 [12:0]
WSEQ_DATA_START481 [3:0]
WSEQ_DATA481 [7:0]
FFFFFFFFh
WSEQ_ADDR482 [12:0]
WSEQ_DATA_START482 [3:0]
WSEQ_DATA482 [7:0]
FFFFFFFFh
WSEQ_ADDR483 [12:0]
WSEQ_DATA_START483 [3:0]
17
1
FFFFFFFFh
WSEQ_ADDR448 [12:0]
WSEQ_DATA_START448 [3:0]
18
2
WSEQ_DATA483 [7:0]
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R13256 WSEQ_Sequence_485
(33C8h)
R13258 WSEQ_Sequence_486
(33CAh)
R13260 WSEQ_Sequence_487
(33CCh)
R13262 WSEQ_Sequence_488
(33CEh)
R13264 WSEQ_Sequence_489
(33D0h)
R13266 WSEQ_Sequence_490
(33D2h)
R13268 WSEQ_Sequence_491
(33D4h)
R13270 WSEQ_Sequence_492
(33D6h)
R13272 WSEQ_Sequence_493
(33D8h)
R13274 WSEQ_Sequence_494
(33DAh)
R13276 WSEQ_Sequence_495
(33DCh)
R13278 WSEQ_Sequence_496
(33DEh)
R13280 WSEQ_Sequence_497
(33E0h)
R13282 WSEQ_Sequence_498
(33E2h)
R13284 WSEQ_Sequence_499
(33E4h)
R13286 WSEQ_Sequence_500
(33E6h)
R13288 WSEQ_Sequence_501
(33E8h)
R13290 WSEQ_Sequence_502
(33EAh)
R13292 WSEQ_Sequence_503
(33ECh)
R13294 WSEQ_Sequence_504
(33EEh)
R13296 WSEQ_Sequence_505
(33F0h)
R13298 WSEQ_Sequence_506
(33F2h)
R13300 WSEQ_Sequence_507
(33F4h)
R13302 WSEQ_Sequence_508
(33F6h)
R131076 OTP_HPDET_Cal_1
(20004h)
R131078 OTP_HPDET_Cal_2
(20006h)
R294912 EVENTLOG1_
(48000h) CONTROL
31
15
30
14
29
13
28
12
27
11
26
10
25
9
24
8
WSEQ_DATA_WIDTH484 [2:0]
WSEQ_DELAY484 [3:0]
WSEQ_DATA_START484 [3:0]
WSEQ_DATA_WIDTH485 [2:0]
WSEQ_DELAY485 [3:0]
WSEQ_DATA_START485 [3:0]
WSEQ_DATA_WIDTH486 [2:0]
WSEQ_DELAY486 [3:0]
WSEQ_DATA_START486 [3:0]
WSEQ_DATA_WIDTH487 [2:0]
WSEQ_DELAY487 [3:0]
WSEQ_DATA_START487 [3:0]
WSEQ_DATA_WIDTH488 [2:0]
WSEQ_DELAY488 [3:0]
WSEQ_DATA_START488 [3:0]
WSEQ_DATA_WIDTH489 [2:0]
WSEQ_DELAY489 [3:0]
WSEQ_DATA_START489 [3:0]
WSEQ_DATA_WIDTH490 [2:0]
WSEQ_DELAY490 [3:0]
WSEQ_DATA_START490 [3:0]
WSEQ_DATA_WIDTH491 [2:0]
WSEQ_DELAY491 [3:0]
WSEQ_DATA_START491 [3:0]
WSEQ_DATA_WIDTH492 [2:0]
WSEQ_DELAY492 [3:0]
WSEQ_DATA_START492 [3:0]
WSEQ_DATA_WIDTH493 [2:0]
WSEQ_DELAY493 [3:0]
WSEQ_DATA_START493 [3:0]
WSEQ_DATA_WIDTH494 [2:0]
WSEQ_DELAY494 [3:0]
WSEQ_DATA_START494 [3:0]
WSEQ_DATA_WIDTH495 [2:0]
WSEQ_DELAY495 [3:0]
WSEQ_DATA_START495 [3:0]
WSEQ_DATA_WIDTH496 [2:0]
WSEQ_DELAY496 [3:0]
WSEQ_DATA_START496 [3:0]
WSEQ_DATA_WIDTH497 [2:0]
WSEQ_DELAY497 [3:0]
WSEQ_DATA_START497 [3:0]
WSEQ_DATA_WIDTH498 [2:0]
WSEQ_DELAY498 [3:0]
WSEQ_DATA_START498 [3:0]
WSEQ_DATA_WIDTH499 [2:0]
WSEQ_DELAY499 [3:0]
WSEQ_DATA_START499 [3:0]
WSEQ_DATA_WIDTH500 [2:0]
WSEQ_DELAY500 [3:0]
WSEQ_DATA_START500 [3:0]
WSEQ_DATA_WIDTH501 [2:0]
WSEQ_DELAY501 [3:0]
WSEQ_DATA_START501 [3:0]
WSEQ_DATA_WIDTH502 [2:0]
WSEQ_DELAY502 [3:0]
WSEQ_DATA_START502 [3:0]
WSEQ_DATA_WIDTH503 [2:0]
WSEQ_DELAY503 [3:0]
WSEQ_DATA_START503 [3:0]
WSEQ_DATA_WIDTH504 [2:0]
WSEQ_DELAY504 [3:0]
WSEQ_DATA_START504 [3:0]
WSEQ_DATA_WIDTH505 [2:0]
WSEQ_DELAY505 [3:0]
WSEQ_DATA_START505 [3:0]
WSEQ_DATA_WIDTH506 [2:0]
WSEQ_DELAY506 [3:0]
WSEQ_DATA_START506 [3:0]
WSEQ_DATA_WIDTH507 [2:0]
WSEQ_DELAY507 [3:0]
WSEQ_DATA_START507 [3:0]
HP_OFFSET_11 [7:0]
HP_OFFSET_01 [7:0]
SPARE2 [7:0]
HP_GRADIENT_1X [7:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
23
7
22
6
21
5
20
4
Default
FFFFFFFFh
WSEQ_ADDR485 [12:0]
WSEQ_DATA485 [7:0]
FFFFFFFFh
WSEQ_ADDR486 [12:0]
WSEQ_DATA486 [7:0]
FFFFFFFFh
WSEQ_ADDR487 [12:0]
WSEQ_DATA487 [7:0]
FFFFFFFFh
WSEQ_ADDR488 [12:0]
WSEQ_DATA488 [7:0]
FFFFFFFFh
WSEQ_ADDR489 [12:0]
WSEQ_DATA489 [7:0]
FFFFFFFFh
WSEQ_ADDR490 [12:0]
WSEQ_DATA490 [7:0]
FFFFFFFFh
WSEQ_ADDR491 [12:0]
WSEQ_DATA491 [7:0]
FFFFFFFFh
WSEQ_ADDR492 [12:0]
WSEQ_DATA492 [7:0]
FFFFFFFFh
WSEQ_ADDR493 [12:0]
WSEQ_DATA493 [7:0]
FFFFFFFFh
WSEQ_ADDR494 [12:0]
WSEQ_DATA494 [7:0]
FFFFFFFFh
WSEQ_ADDR495 [12:0]
WSEQ_DATA495 [7:0]
FFFFFFFFh
WSEQ_ADDR496 [12:0]
WSEQ_DATA496 [7:0]
FFFFFFFFh
WSEQ_ADDR497 [12:0]
WSEQ_DATA497 [7:0]
FFFFFFFFh
WSEQ_ADDR498 [12:0]
WSEQ_DATA498 [7:0]
FFFFFFFFh
WSEQ_ADDR499 [12:0]
WSEQ_DATA499 [7:0]
FFFFFFFFh
WSEQ_ADDR500 [12:0]
WSEQ_DATA500 [7:0]
FFFFFFFFh
WSEQ_ADDR501 [12:0]
WSEQ_DATA501 [7:0]
FFFFFFFFh
WSEQ_ADDR502 [12:0]
WSEQ_DATA502 [7:0]
FFFFFFFFh
WSEQ_ADDR503 [12:0]
WSEQ_DATA503 [7:0]
FFFFFFFFh
WSEQ_ADDR504 [12:0]
WSEQ_DATA504 [7:0]
FFFFFFFFh
WSEQ_ADDR505 [12:0]
WSEQ_DATA505 [7:0]
FFFFFFFFh
WSEQ_ADDR506 [12:0]
WSEQ_DATA506 [7:0]
FFFFFFFFh
WSEQ_ADDR507 [12:0]
0
0
0
0
0
0
WSEQ_DATA507 [7:0]
HP_OFFSET_10 [7:0]
HP_OFFSET_00 [7:0]
SPARE1 [7:0]
HP_GRADIENT_0X [7:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R294924 EVENTLOG1_FIFO_
(4800Ch) CONTROL1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
EVENTLO
G1_CH8_
ENA
0
EVENTLO
G1_CH8_
STS
0
0
EVENTLO
G1_CH7_
ENA
0
EVENTLO
G1_CH7_
STS
0
0
EVENTLO
G1_CH6_
ENA
0
EVENTLO
G1_CH6_
STS
0
0
EVENTLO
G1_CH5_
ENA
0
EVENTLO
G1_CH5_
STS
DS1162F1
16
0
FFFFFFFFh
0
0
0
0
0
0
EVENTLOG1_FIFO_WPTR [3:0]
0
0
0
0
0
0
0
0
EVENTLO EVENTLO EVENTLO EVENTLO EVENTLO EVENTLO EVENTLO EVENTLO
G1_CH16_ G1_CH15_ G1_CH14_ G1_CH13_ G1_CH12_ G1_CH11_ G1_CH10_ G1_CH9_
ENA
ENA
ENA
ENA
ENA
ENA
ENA
ENA
0
0
0
0
0
0
0
0
R294948 EVENTLOG1_EVENT_
(48024h) STATUS
EVENTLO EVENTLO EVENTLO EVENTLO EVENTLO EVENTLO EVENTLO EVENTLO
G1_CH16_ G1_CH15_ G1_CH14_ G1_CH13_ G1_CH12_ G1_CH11_ G1_CH10_ G1_CH9_
STS
STS
STS
STS
STS
STS
STS
STS
17
1
WSEQ_DATA484 [7:0]
0
0
R294944 EVENTLOG1_CH_
(48020h) ENABLE1
18
2
WSEQ_ADDR484 [12:0]
R294916 EVENTLOG1_TIMER_
(48004h) SEL
R294926 EVENTLOG1_FIFO_
(4800Eh) POINTER1
19
3
00000000h
00000000h
0
0
0
0
EVENTLO EVENTLO
G1_RST G1_ENA
0
0
0
0
0
0
EVENTLOG1_
TIMER_SEL [1:0]
0
0
0
0
EVENTLOG1_FIFO_WMARK [3:0]
0
EVENTLO EVENTLO EVENTLO
G1_FULL
G1_ G1_NOT_
WMARK_ EMPTY
STS
EVENTLOG1_FIFO_RPTR [3:0]
0
0
0
0
EVENTLO EVENTLO EVENTLO EVENTLO
G1_CH4_ G1_CH3_ G1_CH2_ G1_CH1_
ENA
ENA
ENA
ENA
0
0
0
0
EVENTLO EVENTLO EVENTLO EVENTLO
G1_CH4_ G1_CH3_ G1_CH2_ G1_CH1_
STS
STS
STS
STS
00000000h
00000000h
00000001h
00000000h
00000000h
00000000h
325
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R294976 EVENTLOG1_CH1_
(48040h) DEFINE
R294978 EVENTLOG1_CH2_
(48042h) DEFINE
R294980 EVENTLOG1_CH3_
(48044h) DEFINE
R294982 EVENTLOG1_CH4_
(48046h) DEFINE
R294984 EVENTLOG1_CH5_
(48048h) DEFINE
R294986 EVENTLOG1_CH6_
(4804Ah) DEFINE
R294988 EVENTLOG1_CH7_
(4804Ch) DEFINE
R294990 EVENTLOG1_CH8_
(4804Eh) DEFINE
R294992 EVENTLOG1_CH9_
(48050h) DEFINE
R294994 EVENTLOG1_CH10_
(48052h) DEFINE
R294996 EVENTLOG1_CH11_
(48054h) DEFINE
R294998 EVENTLOG1_CH12_
(48056h) DEFINE
R295000 EVENTLOG1_CH13_
(48058h) DEFINE
R295002 EVENTLOG1_CH14_
(4805Ah) DEFINE
R295004 EVENTLOG1_CH15_
(4805Ch) DEFINE
R295006 EVENTLOG1_CH16_
(4805Eh) DEFINE
R295040 EVENTLOG1_FIFO0_
(48080h) READ
31
15
30
14
29
13
28
12
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH1_ G1_CH1_ G1_CH1_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH2_ G1_CH2_ G1_CH2_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH3_ G1_CH3_ G1_CH3_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH4_ G1_CH4_ G1_CH4_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH5_ G1_CH5_ G1_CH5_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH6_ G1_CH6_ G1_CH6_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH7_ G1_CH7_ G1_CH7_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH8_ G1_CH8_ G1_CH8_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH9_ G1_CH9_ G1_CH9_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH10_ G1_CH10_ G1_CH10_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH11_ G1_CH11_ G1_CH11_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH12_ G1_CH12_ G1_CH12_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH13_ G1_CH13_ G1_CH13_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH14_ G1_CH14_ G1_CH14_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH15_ G1_CH15_ G1_CH15_
DB
POL
FILT
0
0
0
0
EVENTLO EVENTLO EVENTLO
0
G1_CH16_ G1_CH16_ G1_CH16_
DB
POL
FILT
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO0_
POL
27
11
26
10
25
9
24
8
23
7
22
6
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
18
2
17
1
16
0
Default
0
0
0
EVENTLOG1_CH1_SEL [9:0]
0
0
0
00000000h
0
0
0
0
EVENTLOG1_CH2_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
EVENTLOG1_CH3_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
EVENTLOG1_CH4_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
EVENTLOG1_CH5_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH6_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH7_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH8_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH9_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH10_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH11_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH12_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH13_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH14_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH15_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_CH16_SEL [9:0]
0
0
0
00000000h
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_FIFO0_ID [9:0]
0
0
0
00000000h
R295042 EVENTLOG1_FIFO0_
(48082h) TIME
R295044 EVENTLOG1_FIFO1_
(48084h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO1_
POL
0
0
0
0
R295046 EVENTLOG1_FIFO1_
(48086h) TIME
R295048 EVENTLOG1_FIFO2_
(48088h) READ
R295050 EVENTLOG1_FIFO2_
(4808Ah) TIME
326
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO2_
POL
0
0
0
0
EVENTLOG1_FIFO0_TIME [31:16]
EVENTLOG1_FIFO0_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO1_TIME [31:16]
EVENTLOG1_FIFO1_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO2_TIME [31:16]
EVENTLOG1_FIFO2_TIME [15:0]
21
5
20
4
19
3
00000000h
0
0
0
EVENTLOG1_FIFO1_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO2_ID [9:0]
0
0
0
00000000h
00000000h
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R295052 EVENTLOG1_FIFO3_
(4808Ch) READ
31
15
30
14
29
13
28
12
27
11
26
10
25
9
24
8
23
7
22
6
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO3_
POL
0
0
0
0
0
0
0
0
R295054 EVENTLOG1_FIFO3_
(4808Eh) TIME
R295056 EVENTLOG1_FIFO4_
(48090h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO4_
POL
0
0
0
0
R295058 EVENTLOG1_FIFO4_
(48092h) TIME
R295060 EVENTLOG1_FIFO5_
(48094h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO5_
POL
0
0
0
0
R295062 EVENTLOG1_FIFO5_
(48096h) TIME
R295064 EVENTLOG1_FIFO6_
(48098h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO6_
POL
0
0
0
0
R295066 EVENTLOG1_FIFO6_
(4809Ah) TIME
R295068 EVENTLOG1_FIFO7_
(4809Ch) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO7_
POL
0
0
0
0
R295070 EVENTLOG1_FIFO7_
(4809Eh) TIME
R295072 EVENTLOG1_FIFO8_
(480A0h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO8_
POL
0
0
0
0
R295074 EVENTLOG1_FIFO8_
(480A2h) TIME
R295076 EVENTLOG1_FIFO9_
(480A4h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO9_
POL
0
0
0
0
R295078 EVENTLOG1_FIFO9_
(480A6h) TIME
R295080 EVENTLOG1_FIFO10_
(480A8h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO10_
POL
0
0
0
0
R295082 EVENTLOG1_FIFO10_
(480AAh) TIME
R295084 EVENTLOG1_FIFO11_
(480ACh) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO11_
POL
0
0
0
0
R295086 EVENTLOG1_FIFO11_
(480AEh) TIME
R295088 EVENTLOG1_FIFO12_
(480B0h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO12_
POL
0
0
0
0
R295090 EVENTLOG1_FIFO12_
(480B2h) TIME
R295092 EVENTLOG1_FIFO13_
(480B4h) READ
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO13_
POL
0
0
0
0
R295094 EVENTLOG1_FIFO13_
(480B6h) TIME
R295096 EVENTLOG1_FIFO14_
(480B8h) READ
R295098 EVENTLOG1_FIFO14_
(480BAh) TIME
DS1162F1
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO14_
POL
0
0
0
0
EVENTLOG1_FIFO3_TIME [31:16]
EVENTLOG1_FIFO3_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO4_TIME [31:16]
EVENTLOG1_FIFO4_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO5_TIME [31:16]
EVENTLOG1_FIFO5_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO6_TIME [31:16]
EVENTLOG1_FIFO6_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO7_TIME [31:16]
EVENTLOG1_FIFO7_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO8_TIME [31:16]
EVENTLOG1_FIFO8_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO9_TIME [31:16]
EVENTLOG1_FIFO9_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO10_TIME [31:16]
EVENTLOG1_FIFO10_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO11_TIME [31:16]
EVENTLOG1_FIFO11_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO12_TIME [31:16]
EVENTLOG1_FIFO12_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO13_TIME [31:16]
EVENTLOG1_FIFO13_TIME [15:0]
0
0
0
0
EVENTLOG1_FIFO14_TIME [31:16]
EVENTLOG1_FIFO14_TIME [15:0]
21
5
20
4
19
3
0
0
0
EVENTLOG1_FIFO3_ID [9:0]
18
2
17
1
16
0
Default
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO4_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO5_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO6_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO7_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO8_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO9_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO10_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO11_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO12_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO13_ID [9:0]
0
0
0
00000000h
00000000h
0
0
0
EVENTLOG1_FIFO14_ID [9:0]
0
0
0
00000000h
00000000h
327
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R295100 EVENTLOG1_FIFO15_
(480BCh) READ
31
15
30
14
29
13
28
12
27
11
26
10
25
9
24
8
23
7
22
6
0
0
0
0
0
0
0
EVENTLO
G1_
FIFO15_
POL
0
0
0
0
0
0
0
0
R295102 EVENTLOG1_FIFO15_
(480BEh) TIME
21
5
20
4
19
3
0
0
0
EVENTLOG1_FIFO15_ID [9:0]
18
2
17
1
16
0
Default
0
0
0
00000000h
00000000h
R303104 ALM1_CFG
(4A000h)
0
0
0
0
0
0
0
0
0
0
0
0
EVENTLOG1_FIFO15_TIME [31:16]
EVENTLOG1_FIFO15_TIME [15:0]
0
0
0
0
0
0
0
0
R303120 ALM1_CONFIG1
(4A010h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
ALM1_
CH1_UPD
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
ALM1_
CH2_
CONT
0
ALM1_
CH2_
STOP
0
0
0
0
0
0
0
0
R303122 ALM1_CTRL1
(4A012h)
R303124 ALM1_TRIG_VAL1
(4A0124h)
0
0
0
0
0
0
0
0
0
ALM1_
CH1_
CONT
0
ALM1_
CH1_
STOP
0
0
0
0
0
0
0
0
R303128 ALM1_STATUS1
(4A018h)
0
0
0
0
0
0
0
0
0
0
0
0
R303136 ALM1_CONFIG2
(4A020h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
ALM1_
CH2_UPD
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
ALM1_
CH3_
CONT
0
ALM1_
CH3_
STOP
0
0
0
0
0
0
0
0
R303138 ALM1_CTRL2
(4A022h)
R303140 ALM1_TRIG_VAL2
(4A024h)
0
0
0
0
0
0
0
0
0
0
0
0
R303152 ALM1_CONFIG3
(4A030h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
ALM1_
CH3_UPD
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
ALM1_
CH4_
CONT
0
ALM1_
CH4_
STOP
0
0
0
0
0
0
0
0
R303156 ALM1_TRIG_VAL3
(4A034h)
0
0
0
0
0
0
0
0
0
0
0
0
R303168 ALM1_CONFIG4
(4A040h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
ALM1_
CH4_UPD
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R303172 ALM1_TRIG_VAL4
(4A044h)
R303176 ALM1_STATUS4
(4A048h)
0
0
0
0
0
0
0
0
0
0
0
0
ALM1_CH4_TRIG_VAL[31:16]
ALM1_CH4_TRIG_VAL[15:0]
ALM1_CH4_PULSE_DUR[31:16]
ALM1_CH4_PULSE_DUR[15:0]
0
0
0
0
0
0
0
0
R311296 Timer1_Control
(4C000h)
0
0
0
0
0
0
0
R303174 ALM1_PULSE_DUR4
(4A046h)
0
TIMER1_REFCLK_DIV [2:0]
0
R311298 Timer1_Count_Preset
(4C002h)
R311302 Timer1_Start_and_Stop
(4C006h)
328
0
0
0
0
0
0
0
0
0
0
0
0
0
TIMER1_REFCLK_FREQ_SEL
0
0
[2:0]
TIMER1_MAX_COUNT [31:16]
TIMER1_MAX_COUNT [15:0]
0
0
0
0
0
0
0
0
0
0
0
00000000h
ALM1_
CH1_STS
0
0
00000000h
ALM1_CH2_TRIG_
MODE[1:0]
0
0
0
0
0
ALM1_
CH2_
START
00000000h
0
00000000h
ALM1_
CH2_STS
0
0
00000000h
ALM1_CH3_TRIG_
MODE[1:0]
0
0
0
0
0
ALM1_
CH3_
START
00000000h
00000000h
R303160 ALM1_STATUS3
(4A038h)
R303170 ALM1_CTRL4
(4A042h)
00000000h
00000000h
ALM1_CH3_TRIG_VAL[31:16]
ALM1_CH3_TRIG_VAL[15:0]
ALM1_CH3_PULSE_DUR[31:16]
ALM1_CH3_PULSE_DUR[15:0]
0
0
0
0
0
0
0
0
R303158 ALM1_PULSE_DUR3
(4A036h)
0
ALM1_
CH1_
START
00000000h
00000000h
R303144 ALM1_STATUS2
(4A028h)
R303154 ALM1_CTRL3
(4A032h)
0
0
00000000h
00000000h
ALM1_CH2_TRIG_VAL[31:16]
ALM1_CH2_TRIG_VAL[15:0]
ALM1_CH2_PULSE_DUR[31:16]
ALM1_CH2_PULSE_DUR[15:0]
0
0
0
0
0
0
0
0
R303142 ALM1_PULSE_DUR2
(4A026h)
0
ALM1_
TIMER_
SEL
0
0
ALM1_CH1_TRIG_
MODE[1:0]
00000000h
ALM1_CH1_TRIG_VAL[31:16]
ALM1_CH1_TRIG_VAL[15:0]
ALM1_CH1_PULSE_DUR[31:16]
ALM1_CH1_PULSE_DUR[15:0]
0
0
0
0
0
0
0
0
R303126 ALM1_PULSE_DUR1
(4A016h)
0
0
00000000h
0
00000000h
ALM1_
CH3_STS
0
0
00000000h
ALM1_CH4_TRIG_
MODE[1:0]
0
0
0
0
0
ALM1_
CH4_
START
00000000h
00000000h
00000000h
0
0
0
0
TIMER1_ TIMER1_
CONTINU
DIR
OUS
0
0
0
0
0
0
00000000h
ALM1_
CH4_STS
TIMER1_PRESCALE [2:0]
00000000h
0
0
0
0
TIMER1_REFCLK_SRC [3:0]
00000000h
0
0
0
TIMER1_
STOP
0
0
0
0
0
0
0
00000000h
TIMER1_
START
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
R311304 Timer1_Status
(4C008h)
31
15
30
14
29
13
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
18
2
17
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R311306 Timer1_Count_
(4C00Ah) Readback
R311308 Timer1_DSP_Clock_
(4C00Ch) Config
0
0
0
0
0
0
R311310 Timer1_DSP_Clock_
(4C00Eh) Status
0
0
0
0
0
0
0
DSPGP16
_STS
0
DSPGP16
_SET1_
MASK
0
DSPGP16
_SET1_
DIR
0
DSPGP16
_SET1_
LVL
0
DSPGP16
_SET2_
MASK
0
DSPGP16
_SET2_
DIR
0
DSPGP16
_SET2_
LVL
0
DSPGP16
_SET3_
MASK
0
DSPGP16
_SET3_
DIR
0
DSPGP16
_SET3_
LVL
0
DSPGP16
_SET4_
MASK
0
DSPGP16
_SET4_
DIR
0
DSPGP16
_SET4_
LVL
0
DSPGP16
_SET5_
MASK
0
DSPGP16
_SET5_
DIR
0
DSPGP16
_SET5_
LVL
0
DSPGP16
_SET6_
MASK
0
DSPGP16
_SET6_
DIR
0
DSPGP16
_SET6_
LVL
0
DSPGP15
_STS
0
DSPGP15
_SET1_
MASK
0
DSPGP15
_SET1_
DIR
0
DSPGP15
_SET1_
LVL
0
DSPGP15
_SET2_
MASK
0
DSPGP15
_SET2_
DIR
0
DSPGP15
_SET2_
LVL
0
DSPGP15
_SET3_
MASK
0
DSPGP15
_SET3_
DIR
0
DSPGP15
_SET3_
LVL
0
DSPGP15
_SET4_
MASK
0
DSPGP15
_SET4_
DIR
0
DSPGP15
_SET4_
LVL
0
DSPGP15
_SET5_
MASK
0
DSPGP15
_SET5_
DIR
0
DSPGP15
_SET5_
LVL
0
DSPGP15
_SET6_
MASK
0
DSPGP15
_SET6_
DIR
0
DSPGP15
_SET6_
LVL
0
DSPGP14
_STS
0
DSPGP14
_SET1_
MASK
0
DSPGP14
_SET1_
DIR
0
DSPGP14
_SET1_
LVL
0
DSPGP14
_SET2_
MASK
0
DSPGP14
_SET2_
DIR
0
DSPGP14
_SET2_
LVL
0
DSPGP14
_SET3_
MASK
0
DSPGP14
_SET3_
DIR
0
DSPGP14
_SET3_
LVL
0
DSPGP14
_SET4_
MASK
0
DSPGP14
_SET4_
DIR
0
DSPGP14
_SET4_
LVL
0
DSPGP14
_SET5_
MASK
0
DSPGP14
_SET5_
DIR
0
DSPGP14
_SET5_
LVL
0
DSPGP14
_SET6_
MASK
0
DSPGP14
_SET6_
DIR
0
DSPGP14
_SET6_
LVL
0
DSPGP13
_STS
0
DSPGP13
_SET1_
MASK
0
DSPGP13
_SET1_
DIR
0
DSPGP13
_SET1_
LVL
0
DSPGP13
_SET2_
MASK
0
DSPGP13
_SET2_
DIR
0
DSPGP13
_SET2_
LVL
0
DSPGP13
_SET3_
MASK
0
DSPGP13
_SET3_
DIR
0
DSPGP13
_SET3_
LVL
0
DSPGP13
_SET4_
MASK
0
DSPGP13
_SET4_
DIR
0
DSPGP13
_SET4_
LVL
0
DSPGP13
_SET5_
MASK
0
DSPGP13
_SET5_
DIR
0
DSPGP13
_SET5_
LVL
0
DSPGP13
_SET6_
MASK
0
DSPGP13
_SET6_
DIR
0
DSPGP13
_SET6_
LVL
0
DSPGP12
_STS
0
DSPGP12
_SET1_
MASK
0
DSPGP12
_SET1_
DIR
0
DSPGP12
_SET1_
LVL
0
DSPGP12
_SET2_
MASK
0
DSPGP12
_SET2_
DIR
0
DSPGP12
_SET2_
LVL
0
DSPGP12
_SET3_
MASK
0
DSPGP12
_SET3_
DIR
0
DSPGP12
_SET3_
LVL
0
DSPGP12
_SET4_
MASK
0
DSPGP12
_SET4_
DIR
0
DSPGP12
_SET4_
LVL
0
DSPGP12
_SET5_
MASK
0
DSPGP12
_SET5_
DIR
0
DSPGP12
_SET5_
LVL
0
DSPGP12
_SET6_
MASK
0
DSPGP12
_SET6_
DIR
0
DSPGP12
_SET6_
LVL
0
DSPGP11
_STS
0
DSPGP11
_SET1_
MASK
0
DSPGP11
_SET1_
DIR
0
DSPGP11
_SET1_
LVL
0
DSPGP11
_SET2_
MASK
0
DSPGP11
_SET2_
DIR
0
DSPGP11
_SET2_
LVL
0
DSPGP11
_SET3_
MASK
0
DSPGP11
_SET3_
DIR
0
DSPGP11
_SET3_
LVL
0
DSPGP11
_SET4_
MASK
0
DSPGP11
_SET4_
DIR
0
DSPGP11
_SET4_
LVL
0
DSPGP11
_SET5_
MASK
0
DSPGP11
_SET5_
DIR
0
DSPGP11
_SET5_
LVL
0
DSPGP11
_SET6_
MASK
0
DSPGP11
_SET6_
DIR
0
DSPGP11
_SET6_
LVL
R315392 DSPGP_Status_1
(4D000h)
R315424 DSPGP_SET1_Mask_1
(4D020h)
R315432 DSPGP_SET1_
(4D028h) Direction_1
R315440 DSPGP_SET1_Level_1
(4D030h)
R315456 DSPGP_SET2_Mask_1
(4D040h)
R315464 DSPGP_SET2_
(4D048h) Direction_1
R315472 DSPGP_SET2_Level_1
(4D050h)
R315488 DSPGP_SET3_Mask_1
(4D060h)
R315496 DSPGP_SET3_
(4D068h) Direction_1
R315504 DSPGP_SET3_Level_1
(4D070h)
R315520 DSPGP_SET4_Mask_1
(4D080h)
R315528 DSPGP_SET4_
(4D088h) Direction_1
R315536 DSPGP_SET4_Level_1
(4D090h)
R315552 DSPGP_SET5_Mask_1
(4D0A0h)
R315560 DSPGP_SET5_
(4D0A8h) Direction_1
R315568 DSPGP_SET5_Level_1
(4D0B0h)
R315584 DSPGP_SET6_Mask_1
(4D0C0h)
R315592 DSPGP_SET6_
(4D0C8h) Direction_1
R315600 DSPGP_SET6_Level_1
(4D0D0h)
DS1162F1
16
0
Default
0
00000000h
TIMER1_
RUNNING
_STS
TIMER1_CUR_COUNT [31:16]
TIMER1_CUR_COUNT [15:0]
0
0
0
0
0
0
0
0
0
0
TIMER1_DSPCLK_FREQ_SEL [15:0]
0
0
0
0
0
0
0
0
0
0
TIMER1_DSPCLK_FREQ_STS [15:0]
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_STS
STS
STS
STS
STS
STS
STS
STS
STS
STS
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET1_ SET1_
SET1_
SET1_
SET1_
SET1_
SET1_
SET1_
SET1_
SET1_
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET1_ SET1_DIR SET1_DIR SET1_DIR SET1_DIR SET1_DIR SET1_DIR SET1_DIR SET1_DIR SET1_DIR
DIR
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET1_ SET1_LVL SET1_LVL SET1_LVL SET1_LVL SET1_LVL SET1_LVL SET1_LVL SET1_LVL SET1_LVL
LVL
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET2_ SET2_
SET2_
SET2_
SET2_
SET2_
SET2_
SET2_
SET2_
SET2_
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET2_ SET2_DIR SET2_DIR SET2_DIR SET2_DIR SET2_DIR SET2_DIR SET2_DIR SET2_DIR SET2_DIR
DIR
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET2_ SET2_LVL SET2_LVL SET2_LVL SET2_LVL SET2_LVL SET2_LVL SET2_LVL SET2_LVL SET2_LVL
LVL
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET3_ SET3_
SET3_
SET3_
SET3_
SET3_
SET3_
SET3_
SET3_
SET3_
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET3_ SET3_DIR SET3_DIR SET3_DIR SET3_DIR SET3_DIR SET3_DIR SET3_DIR SET3_DIR SET3_DIR
DIR
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET3_ SET3_LVL SET3_LVL SET3_LVL SET3_LVL SET3_LVL SET3_LVL SET3_LVL SET3_LVL SET3_LVL
LVL
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET4_ SET4_
SET4_
SET4_
SET4_
SET4_
SET4_
SET4_
SET4_
SET4_
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET4_ SET4_DIR SET4_DIR SET4_DIR SET4_DIR SET4_DIR SET4_DIR SET4_DIR SET4_DIR SET4_DIR
DIR
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET4_ SET4_LVL SET4_LVL SET4_LVL SET4_LVL SET4_LVL SET4_LVL SET4_LVL SET4_LVL SET4_LVL
LVL
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET5_ SET5_
SET5_
SET5_
SET5_
SET5_
SET5_
SET5_
SET5_
SET5_
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET5_ SET5_DIR SET5_DIR SET5_DIR SET5_DIR SET5_DIR SET5_DIR SET5_DIR SET5_DIR SET5_DIR
DIR
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET5_ SET5_LVL SET5_LVL SET5_LVL SET5_LVL SET5_LVL SET5_LVL SET5_LVL SET5_LVL SET5_LVL
LVL
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET6_ SET6_
SET6_
SET6_
SET6_
SET6_
SET6_
SET6_
SET6_
SET6_
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET6_ SET6_DIR SET6_DIR SET6_DIR SET6_DIR SET6_DIR SET6_DIR SET6_DIR SET6_DIR SET6_DIR
DIR
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET6_ SET6_LVL SET6_LVL SET6_LVL SET6_LVL SET6_LVL SET6_LVL SET6_LVL SET6_LVL SET6_LVL
LVL
00000000h
00000000h
00000000h
00000000h
0000FFFFh
0000FFFFh
00000000h
0000FFFFh
0000FFFFh
00000000h
0000FFFFh
0000FFFFh
00000000h
0000FFFFh
0000FFFFh
00000000h
0000FFFFh
0000FFFFh
00000000h
0000FFFFh
0000FFFFh
00000000h
329
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
31
15
30
14
29
13
28
12
27
11
26
10
25
9
24
8
23
7
22
6
21
5
20
4
19
3
18
2
17
1
16
0
Default
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R315616 DSPGP_SET7_Mask_1
0000FFFFh
(4D0E0h)
DSPGP16 DSPGP15 DSPGP14 DSPGP13 DSPGP12 DSPGP11 DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET7_
MASK
0
R315624 DSPGP_SET7_
(4D0E8h) Direction_1
DSPGP16
_SET7_
DIR
0
R315632 DSPGP_SET7_Level_1
(4D0F0h)
DSPGP16
_SET7_
LVL
0
R315648 DSPGP_SET8_Mask_1
(4D100h)
DSPGP16
_SET8_
MASK
0
R315656 DSPGP_SET8_
(4D108h) Direction_1
DSPGP16
_SET8_
DIR
0
R315664 DSPGP_SET8_Level_1
(4D110h)
DSPGP16
_SET8_
LVL
0
R524288 DSP1_PMEM_0
_SET7_
MASK
0
DSPGP15
_SET7_
DIR
0
DSPGP15
_SET7_
LVL
0
DSPGP15
_SET8_
MASK
0
DSPGP15
_SET8_
DIR
0
DSPGP15
_SET8_
LVL
0
_SET7_
MASK
0
DSPGP14
_SET7_
DIR
0
DSPGP14
_SET7_
LVL
0
DSPGP14
_SET8_
MASK
0
DSPGP14
_SET8_
DIR
0
DSPGP14
_SET8_
LVL
0
_SET7_
MASK
0
DSPGP13
_SET7_
DIR
0
DSPGP13
_SET7_
LVL
0
DSPGP13
_SET8_
MASK
0
DSPGP13
_SET8_
DIR
0
DSPGP13
_SET8_
LVL
0
_SET7_
MASK
0
DSPGP12
_SET7_
DIR
0
DSPGP12
_SET7_
LVL
0
DSPGP12
_SET8_
MASK
0
DSPGP12
_SET8_
DIR
0
DSPGP12
_SET8_
LVL
0
_SET7_
MASK
0
DSPGP11
_SET7_
DIR
0
DSPGP11
_SET7_
LVL
0
DSPGP11
_SET8_
MASK
0
DSPGP11
_SET8_
DIR
0
DSPGP11
_SET8_
LVL
0
0
0
0
0
0
(80000h)
R524290 DSP1_PMEM_1
(80002h)
0
R524292 DSP1_PMEM_2
(80004h)
R561146 DSP1_PMEM_18429
(88FFAh)
R561148 DSP1_PMEM_18430
(88FFCh)
0
0
0
0
0
0
0
0
0
0
0
0
R561150 DSP1_PMEM_18431
(88FFEh)
R655360 DSP1_XMEM_0
(A0000h)
0
0
0
0
0
0
R655362 DSP1_XMEM_1
(A0002h)
0
0
0
0
0
0
R696316 DSP1_XMEM_20478
(A9FFCh)
0
0
0
0
0
0
R696318 DSP1_XMEM_20479
(A9FFEh)
0
0
0
0
0
0
R786432 DSP1_YMEM_0
(C0000h)
0
0
0
0
0
0
R786434 DSP1_YMEM_1
(C0002h)
0
0
0
0
0
0
R802812 DSP1_YMEM_8190
(C3FFCh)
0
0
0
0
0
0
R802814 DSP1_YMEM_8191
(C3FFEh)
0
0
0
0
0
0
R917504 DSP1_ZMEM_0
(E0000h)
0
0
0
0
0
0
R917506 DSP1_ZMEM_1
(E0002h)
0
0
0
0
0
0
R925692 DSP1_ZMEM_4094
(E1FFCh)
0
0
0
0
0
0
R925694 DSP1_ZMEM_4095
(E1FFEh)
0
0
0
0
0
0
R1048064 DSP1_Config_1
(FFE00h)
0
0
0
0
0
0
R1048066 DSP1_Config_2
(FFE02h)
0
0
0
0
0
0
R1048068 DSP1_Status_1
(FFE04h)
DSP1_
PING_
FULL
0
DSP1_
PONG_
FULL
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R1048072 DSP1_Status_3
(FFE08h)
0
0
0
0
0
0
R1048074 DSP1_Watchdog_1
(FFE0Ah)
0
0
0
0
0
0
0
0
0
0
0
0
R1048070 DSP1_Status_2
(FFE06h)
330
0
0
DSP1_RATE [3:0]
_SET7_ SET7_
SET7_
SET7_
SET7_
SET7_
SET7_
SET7_
SET7_
SET7_
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET7_ SET7_DIR SET7_DIR SET7_DIR SET7_DIR SET7_DIR SET7_DIR SET7_DIR SET7_DIR SET7_DIR
DIR
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET7_ SET7_LVL SET7_LVL SET7_LVL SET7_LVL SET7_LVL SET7_LVL SET7_LVL SET7_LVL SET7_LVL
LVL
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET8_ SET8_
SET8_
SET8_
SET8_
SET8_
SET8_
SET8_
SET8_
SET8_
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
MASK
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET8_ SET8_DIR SET8_DIR SET8_DIR SET8_DIR SET8_DIR SET8_DIR SET8_DIR SET8_DIR SET8_DIR
DIR
0
0
0
0
0
0
0
0
0
0
DSPGP10 DSPGP9_ DSPGP8_ DSPGP7_ DSPGP6_ DSPGP5_ DSPGP4_ DSPGP3_ DSPGP2_ DSPGP1_
_SET8_ SET8_LVL SET8_LVL SET8_LVL SET8_LVL SET8_LVL SET8_LVL SET8_LVL SET8_LVL SET8_LVL
LVL
0
0
DSP1_PM_START [39:32]
DSP1_PM_START [31:16]
DSP1_PM_START [15:0]
0
0
DSP1_PM_1 [39:32]
DSP1_PM_1 [31:16]
DSP1_PM_1 [15:0]
0
0
DSP1_PM_12286 [39:32]
DSP1_PM_12286 [31:16]
DSP1_PM_12286 [15:0]
0
0
DSP1_PM_END [39:32]
DSP1_PM_END [31:16]
DSP1_PM_END [15:0]
0
0
DSP1_XM_START [23:16]
DSP1_XM_START [15:0]
0
0
DSP1_XM_1 [23:16]
DSP1_XM_1 [15:0]
0
0
DSP1_XM_20478 [23:16]
DSP1_XM_20478 [15:0]
0
0
DSP1_XM_END [23:16]
DSP1_XM_END [15:0]
0
0
DSP1_YM_START [23:16]
DSP1_YM_START [15:0]
0
0
DSP1_YM_1 [23:16]
DSP1_YM_1 [15:0]
0
0
DSP1_YM_8190 [23:16]
DSP1_YM_8190 [15:0]
0
0
DSP1_YM_END [23:16]
DSP1_YM_END [15:0]
0
0
DSP1_ZM_START [23:16]
DSP1_ZM_START [15:0]
0
0
DSP1_ZM_1 [23:16]
DSP1_ZM_1 [15:0]
0
0
DSP1_ZM_4094 [23:16]
DSP1_ZM_4094 [15:0]
0
0
DSP1_ZM_END [23:16]
DSP1_ZM_END [15:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1_
DSP1_
0
DSP1_
DSP1_
MEM_ENA DBG_
CORE_ START
CLK_ENA
ENA
0
0
0
0
0
0
0
0
0
0
DSP1_CLK_FREQ_SEL [15:0]
0
0
DSP1_WDMA_ACTIVE_CHANNELS [7:0]
0
0
0
0
DSP1_DUALMEM_COLLISION_ADDR [15:0]
0
0
0
0
0
0
0
0
DSP1_CLK_FREQ_STS [15:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1_
CLK_
AVAIL
0
0
0
0
0000FFFFh
00000000h
0000FFFFh
0000FFFFh
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
0
0
0
DSP1_WDT_MAX_COUNT [3:0]
00000000h
0
00000000h
DSP1_
WDT_ENA
DS1162F1
CS42L92
6 Register Map
Table 6-2. Register Map Definition—32-bit region (Cont.)
Register
Name
31
15
30
14
29
13
28
12
27
11
26
10
R1048080 DSP1_WDMA_Buffer_1
(FFE10h)
R1048082 DSP1_WDMA_Buffer_2
(FFE12h)
R1048084 DSP1_WDMA_Buffer_3
(FFE14h)
R1048086 DSP1_WDMA_Buffer_4
(FFE16h)
R1048096 DSP1_RDMA_Buffer_1
(FFE20h)
R1048098 DSP1_RDMA_Buffer_2
(FFE22h)
R1048100 DSP1_RDMA_Buffer_3
(FFE24h)
R1048112 DSP1_DMA_Config_1
(FFE30h)
0
0
0
0
0
0
0
0
0
0
0
0
R1048118 DSP1_DMA_Config_4
(FFE36h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R1048120 DSP1_External_Start
(FFE38h)
0
0
0
0
0
0
0
0
0
0
0
0
R1048114 DSP1_DMA_Config_2
(FFE32h)
R1048116 DSP1_DMA_Config_3
(FFE34h)
25
9
24
8
23
7
22
6
0
0
0
0
0
0
R1048148 DSP1_Ext_window_A
(FFE54h)
DSP1_
EXT_A_
PSIZE16
0
0
0
0
0
R1048150 DSP1_Ext_window_B
(FFE56h)
DSP1_
EXT_B_
PSIZE16
0
0
0
0
0
0
R1048152 DSP1_Ext_window_C
(FFE58h)
DSP1_
EXT_C_
PSIZE16
0
0
0
0
0
R1048154 DSP1_Ext_window_D
(FFE5Ah)
DSP1_
EXT_D_
PSIZE16
0
0
0
0
0
R1048158 DSP1_Watchdog_2
(FFE5Eh)
0
0
0
0
0
0
R1048160 DSP1_Identity
(FFE60h)
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
R1048130 DSP1_Scratch_2
(FFE42h)
R1048146 DSP1_Bus_Error_Addr
(FFE52h)
R1048164 DSP1_Region_lock_sts_
(FFE64h) 0
R1048166 DSP1_Region_lock_1__
(FFE66h) _DSP1_Region_lock_0
R1048168 DSP1_Region_lock_3__
(FFE68h) _DSP1_Region_lock_2
R1048170 DSP1_Region_lock_5__
(FFE6Ah) _DSP1_Region_lock_4
R1048172 DSP1_Region_lock_7__
(FFE6Ch) _DSP1_Region_lock_6
R1048174 DSP1_Region_lock_9__
(FFE6Eh) _DSP1_Region_lock_8
0
R1048186 DSP1_Region_lock_ctrl_
(FFE7Ah) 0
DSP1_
R1048188 DSP1_PMEM_Err_
(FFE7Ch) Addr___XMEM_Err_
Addr
DS1162F1
0
0
DSP1_
DSP1_
LOCK_ ADDR_
WDT_
ERR_STS ERR_STS TIMEOUT_
STS
0
0
0
0
0
0
0
20
4
19
3
18
2
17
1
DSP1_START_ADDRESS_WDMA_BUFFER_1 [15:0]
DSP1_START_ADDRESS_WDMA_BUFFER_0 [15:0]
DSP1_START_ADDRESS_WDMA_BUFFER_3 [15:0]
DSP1_START_ADDRESS_WDMA_BUFFER_2 [15:0]
DSP1_START_ADDRESS_WDMA_BUFFER_5 [15:0]
DSP1_START_ADDRESS_WDMA_BUFFER_4 [15:0]
DSP1_START_ADDRESS_WDMA_BUFFER_7 [15:0]
DSP1_START_ADDRESS_WDMA_BUFFER_6 [15:0]
DSP1_START_ADDRESS_RDMA_BUFFER_1 [15:0]
DSP1_START_ADDRESS_RDMA_BUFFER_0 [15:0]
DSP1_START_ADDRESS_RDMA_BUFFER_3 [15:0]
DSP1_START_ADDRESS_RDMA_BUFFER_2 [15:0]
DSP1_START_ADDRESS_RDMA_BUFFER_5 [15:0]
DSP1_START_ADDRESS_RDMA_BUFFER_4 [15:0]
0
0
DSP1_WDMA_CHANNEL_ENABLE [7:0]
DSP1_DMA_BUFFER_LENGTH [13:0]
0
0
0
0
0
0
0
0
0
0
0
DSP1_WDMA_CHANNEL_OFFSET [7:0]
0
0
0
0
DSP1_RDMA_CHANNEL_OFFSET [5:0]
0
0
0
0
DSP1_RDMA_CHANNEL_ENABLE [5:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1_SCRATCH_1 [15:0]
DSP1_SCRATCH_0 [15:0]
DSP1_SCRATCH_3 [15:0]
DSP1_SCRATCH_2 [15:0]
0
0
DSP1_BUS_ERR_ADDR [15:0]
0
0
0
0
R1048128 DSP1_Scratch_1
(FFE40h)
21
5
0
0
0
0
0
0
0
0
DSP1_START_IN_SEL [4:0]
16
0
Default
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
0
00000000h
00000000h
0
DSP1_
DMA_
WORD_
SEL
0
00000000h
00000000h
00000000h
00000000h
00000000h
DSP1_BUS_ERR_ADDR [23:16]
0
0
0
0
0
0
00000000h
DSP1_EXT_A_PAGE [15:0]
0
0
0
0
0
0
0
0
0
00000000h
0
DSP1_EXT_B_PAGE [15:0]
0
0
0
0
0
0
0
0
0
00000000h
0
DSP1_EXT_C_PAGE [15:0]
0
0
0
0
0
0
0
0
0
00000000h
DSP1_EXT_D_PAGE [15:0]
0
0
0
0
0
0
0
0
0
DSP1_WDT_RESET [15:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1_CORE_NUMBER [4:0]
0
0
0
0
0
0
0
0
0
0
DSP1_
DSP1_
DSP1_
DSP1_
DSP1_
DSP1_
DSP1_
DSP1_
DSP1_
DSP1_
CTRL_
CTRL_
CTRL_
CTRL_
CTRL_
CTRL_
CTRL_
CTRL_
CTRL_
CTRL_
REGION9_REGION8_REGION7_REGION6_REGION5_REGION4_REGION3_REGION2_REGION1_REGION0_
LOCK_ LOCK_ LOCK_ LOCK_ LOCK_ LOCK_ LOCK_ LOCK_ LOCK_ LOCK_
STS
STS
STS
STS
STS
STS
STS
STS
STS
STS
DSP1_CTRL_REGION1_LOCK [15:0]
DSP1_CTRL_REGION0_LOCK [15:0]
DSP1_CTRL_REGION3_LOCK [15:0]
DSP1_CTRL_REGION2_LOCK [15:0]
DSP1_CTRL_REGION5_LOCK [15:0]
DSP1_CTRL_REGION4_LOCK [15:0]
DSP1_CTRL_REGION7_LOCK [15:0]
DSP1_CTRL_REGION6_LOCK [15:0]
DSP1_CTRL_REGION9_LOCK [15:0]
DSP1_CTRL_REGION8_LOCK [15:0]
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
DSP1_
DSP1_
ERR_
ERR_
PAUSE CLEAR
0
DSP1_PMEM_ERR_ADDR [14:0]
DSP1_XMEM_ERR_ADDR [15:0]
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
00000000h
331
CS42L92
7 Thermal Characteristics
7 Thermal Characteristics
Table 7-1. Typical JEDEC Four-Layer, 2s2p Board Thermal Characteristics
Symbol
WLCSP
Units
Junction-to-ambient thermal resistance
Parameter
JA
38.5
°C/W
Junction-to-board thermal resistance
JB
9.3
°C/W
Junction-to-case thermal resistance
JC
2.11
°C/W
Junction-to-board thermal-characterization parameter
JB
9.3
°C/W
Junction-to-package-top thermal-characterization parameter
JT
0.10
°C/W
Notes:
• Natural convection at the maximum recommended operating temperature TA (see Table 3-3)
• Four-layer, 2s2p PCB as specified by JESD51-9 and JESD51-11; dimensions: 101.5 x 114.5 x 1.6 mm
• Thermal parameters as defined by JESD51-12
332
DS1162F1
CS42L92
8 Package Dimensions
8 Package Dimensions
Ball A1 Location Indicator
(seen through package)
A2
g
X
X
A
Ball A1
Location
Indicator
c2
A1
d2
Z
Z
Y
Seating
plane
e
d1
Y
WAFER BACK SIDE
b
c1
104 x Øb
Øddd Z X Y
Øccc Z
SIDE VIEW
e
e
f
BUMP SIDE
Notes:
• Dimensioning and tolerances per ASME Y 14.5M–2009.
• The Ball A1 position indicator is for illustration purposes only and may not be to scale.
• Dimension “b” applies to the solder sphere diameter and is measured at the midpoint
between the package body and the seating plane Datum Z.
Table 8-1. WLCSP Package Dimensions
Dimension
Millimeters
Nominal
0.494
0.19
0.304
0.27
0.3579
0.2362
0.2607
0.236
0.4
0.3464
0.3464
4.7754
3.4722
Minimum
0.464
0.161
0.289
0.24
0.3279
0.2062
0.2307
0.206
BSC
BSC
REF
4.7504
3.4472
A
A1
A2
b
c1
d1
c2
d2
e
f
g
X
Y
ccc = 0.05
ddd = 0.15
Note: Controlling dimension is millimeters.
Maximum
0.524
0.219
0.319
0.3
0.3879
0.2662
0.2907
0.266
BSC
BSC
BSC
4.8004
3.4972
9 Ordering Information
Table 9-1. Ordering Information
Product
CS42L92
Description
32-Bit 384-kHz Hi-Fi
Audio Codec
Package
104-ball
WLCSP
Halogen
Free
Pb
Free
Grade
Temperature
Range
Yes
Yes
Commercial
–40 to +85°C
Container
Order #
Tape and
Reel 1
CS42L92-CWZR
1.Reel quantity = 6000 units.
DS1162F1
333
CS42L92
10 References
10 References
•
MIPI Alliance, MIPI Alliance Specification for Serial Low-Power Inter-Chip Media Bus (SLIMbus). http://
www.mipi.org/
•
Google Inc, Android Wired Headset Specification, Version 1.1. http://source.android.com/accessories/
headset-spec.html
•
International Electrotechnical Commission, IEC60958-3 Digital Audio Interface—Consumer. http://www.ansi.org/
11 Revision History
Table 11-1. Revision History
Revision
F1
NOV ‘17
Changes
• AVDD maximum rating amended (Table 3-2).
• DSP memory sizes amended (Table 4-29).
• Package dimension tolerances added (Section 8).
Contacting Cirrus Logic Support
For all product questions and inquiries, contact a Cirrus Logic Sales Representative.
To find the one nearest you, go to www.cirrus.com.
IMPORTANT NOTICE
The products and services of Cirrus Logic International (UK) Limited; Cirrus Logic, Inc.; and other companies in the Cirrus Logic group (collectively either “Cirrus
Logic” or “Cirrus”) are sold subject to Cirrus Logic’s terms and conditions of sale supplied at the time of order acknowledgment, including those pertaining to
warranty, indemnification, and limitation of liability. Software is provided pursuant to applicable license terms. Cirrus Logic reserves the right to make changes to
its products and specifications or to discontinue any product or service without notice. Customers should therefore obtain the latest version of relevant information
from Cirrus Logic to verify that the information is current and complete. Testing and other quality control techniques are utilized to the extent Cirrus Logic deems
necessary. Specific testing of all parameters of each device is not necessarily performed. In order to minimize risks associated with customer applications, the
customer must use adequate design and operating safeguards to minimize inherent or procedural hazards. Cirrus Logic is not liable for applications assistance
or customer product design. The customer is solely responsible for its 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, SoundClear, and WISCE are among the trademarks
of Cirrus Logic. Other brand and product names may be trademarks or service marks of their respective owners.
Copyright © 2017 Cirrus Logic, Inc. All rights reserved.
MIPI and SLIMbus are trademarks or registered trademarks of MIPI Alliance, Inc.
USB-C is a trademark of USB Implementers Forum.
Android is a trademark of Google, Inc.
SPI is a trademark of Motorola.
334
DS1162F1