



Analog Reinvented



**ES9039Q2M**

**32-bit High Performance 2 Channel DAC**

**Product Datasheet**

The ESS SABRE® ES9039Q2M is a high performance 32-bit, 2-channel audio D/A converter. It has been designed for professional applications (mixer consoles, digital audio workstations), audiophiles-grade portable applications (headphones, network streamers and digital music players), and consumer applications (DACs and A/V receivers). The ES9039Q2M uses the newest ESS patented Hyperstream® IV Dual DAC™ technology, and advanced SABRE HiFi® architecture.

The ES9039Q2M delivers a performance level that will satisfy the most demanding audiophile and pro-audio enthusiast.

The ES9039Q2M SABRE® DAC improves on previous designs to include:

- TDM & SPI support for more options in connectivity
- Lower power consumption than previous generations which includes the Hyperstream IV DAC modulator
- New hardware mode (HW) programmability alleviates I<sup>2</sup>C/SPI programming for ease of use

The versatile audio input port accepts PCM (TDM/LJ/RJ/I<sup>2</sup>S), DSD, DoP, and S/PDIF formats. The integrates SABRE® DAC supports up to 32-bit 768kHz PCM & DSD1024 audio data via master/slave interface in synchronous and asynchronous sampling modes.

The integrated digital regulator reduces PCB area and BOM cost.

| FEATURE                                                               | DESCRIPTION                                                                                  |
|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Patented 32-bit Hyperstream® IV Architecture and Dual DAC™ Technology | 32-bit audio DAC with very high dynamic range & ultra-low distortion                         |
| +130dB Dynamic Range (DNR)                                            | High performance 32-bit audio DAC with unprecedented dynamic range and ultra-low distortion. |
| -126dB Total Harmonic Distortion (THD)                                |                                                                                              |
| -120dB Total Harmonic Distortion + Noise (THD+N)                      | Supports synchronous and asynchronous sampling modes                                         |
| Integrated low noise digital regulator                                | Reduced BOM cost and improved DNR                                                            |
| 32-bit processing                                                     | Distortion free signal processing                                                            |
| Versatile digital audio input port                                    | Supports master/slave PCM (TDM, I <sup>2</sup> S, LJ, RJ), DSD, DoP, S/PDIF formats.         |
| Customizable digital filter characteristics                           | 8 preset filters and a programmable filter for custom sound signature                        |
| FIR & IIR filter bypass                                               | To allow full customer ability to add custom filters                                         |

## APPLICATIONS

- Professional digital audio workstations and mixer consoles
- Digital music players, Portable multimedia players
- Consumer and Audiophile DAC headphone amplifiers and A/V receivers
- Wireless stereo devices & Networked audio
- DJ equipment

## Table of Contents

|                                                |    |
|------------------------------------------------|----|
| Table of Contents .....                        | 2  |
| List of Figures .....                          | 5  |
| List of Tables .....                           | 6  |
| Functional Block Diagram.....                  | 8  |
| ES9039Q2M Package .....                        | 9  |
| 32 QFN Pinout.....                             | 9  |
| 32 QFN Pin Descriptions .....                  | 10 |
| Feature List.....                              | 11 |
| Configuration Modes.....                       | 11 |
| Software Mode .....                            | 11 |
| I <sup>2</sup> C .....                         | 11 |
| SPI .....                                      | 11 |
| Hardware Mode.....                             | 12 |
| Design Information.....                        | 13 |
| Muting .....                                   | 13 |
| Hardware Mode Pin Configuration .....          | 14 |
| Recommended Hardware Mode Setup Sequence ..... | 16 |
| Digital Features.....                          | 17 |
| Digital Signal Path .....                      | 17 |
| Volume Control .....                           | 17 |
| Automute.....                                  | 18 |
| 8x FIR Interpolation Oversampling Filter.....  | 18 |
| THD Compensation .....                         | 19 |
| IIR Filter .....                               | 19 |
| GPIO Software Configuration .....              | 20 |
| GPIO Configuration Descriptions .....          | 21 |
| Analog Shutdown.....                           | 21 |
| Output 0 .....                                 | 21 |
| Output 1 .....                                 | 21 |
| Clocks .....                                   | 21 |
| Interrupt.....                                 | 21 |
| Mute .....                                     | 21 |
| System Mode Control .....                      | 21 |

## ES9039Q2M Product Datasheet

---

|                                               |    |
|-----------------------------------------------|----|
| SRC Lock Status.....                          | 21 |
| External DEM Output.....                      | 21 |
| PWM Signals .....                             | 22 |
| Minimum Volume .....                          | 22 |
| Automute Status .....                         | 22 |
| Soft Ramp Done .....                          | 22 |
| GPIO Pin Descriptions .....                   | 23 |
| Audio Input Formats .....                     | 24 |
| PCM (I <sup>2</sup> S, LJ, RJ).....           | 25 |
| TDM (Time-Division Multiplexing) .....        | 26 |
| DSD .....                                     | 29 |
| S/PDIF .....                                  | 29 |
| Digital Filters.....                          | 32 |
| Customizable Programmable FIR Filters .....   | 33 |
| PCM Filter Latency .....                      | 34 |
| PCM Filter Properties.....                    | 34 |
| PCM Filter Frequency Response .....           | 36 |
| PCM Filter Impulse Response .....             | 42 |
| 64FS Mode .....                               | 45 |
| Analog Features .....                         | 47 |
| Calibration Resistor .....                    | 47 |
| Absolute Maximum Ratings .....                | 48 |
| I/O Electrical Characteristics.....           | 48 |
| Recommended Operating Conditions .....        | 49 |
| Recommended Power Up/Down Sequence .....      | 49 |
| Power Consumption .....                       | 50 |
| Performance.....                              | 52 |
| Timing Requirements.....                      | 53 |
| I <sup>2</sup> C Slave Interface Timing ..... | 53 |
| SPI Slave Interface.....                      | 54 |
| Audio Interface Timing .....                  | 55 |
| Register Overview .....                       | 55 |
| Read/Write Register Addresses .....           | 55 |
| Read-Only Register Addresses .....            | 55 |
| Multi-Byte Registers .....                    | 55 |



|                                                               |     |
|---------------------------------------------------------------|-----|
| Register Map .....                                            | 56  |
| Register Listing .....                                        | 58  |
| System Registers .....                                        | 58  |
| GPIO Registers .....                                          | 68  |
| DAC Registers.....                                            | 78  |
| Readback Registers .....                                      | 91  |
| ES9039Q2M Reference Schematics .....                          | 95  |
| Typical Application Schematic.....                            | 95  |
| Hardware (HW) Mode .....                                      | 96  |
| Software (SW) Mode .....                                      | 97  |
| Recommended Output Stage .....                                | 98  |
| Recommended Power Supply.....                                 | 99  |
| Internal Pad Circuitry .....                                  | 100 |
| 32 QFN Package Dimensions .....                               | 102 |
| 32 QFN Top View Marking .....                                 | 103 |
| Reflow Process Considerations .....                           | 104 |
| Temperature Controlled .....                                  | 104 |
| Manual .....                                                  | 105 |
| RPC-1 Classification Reflow Profile .....                     | 105 |
| RPC-2-Pb-Free Process - Classification Temperatures (Tc)..... | 106 |
| Ordering Information.....                                     | 107 |
| Revision History.....                                         | 107 |

## ES9039Q2M Product Datasheet

---

### List of Figures

|                                                                                       |     |
|---------------------------------------------------------------------------------------|-----|
| Figure 1 - Functional Block Diagram.....                                              | 8   |
| Figure 2 - ES9039Q2M Pinout.....                                                      | 9   |
| Figure 3 - Hardware Mode Pin Configurations.....                                      | 13  |
| Figure 4 - Hardware Mode Startup Sequence .....                                       | 16  |
| Figure 5 - Digital Signal Path .....                                                  | 17  |
| Figure 6 - THD Compensation Block Diagram.....                                        | 19  |
| Figure 7 - LJ & I <sup>2</sup> S Input for 16bit and 32bit Word Depths .....          | 25  |
| Figure 8 - TDM128 Mode.....                                                           | 26  |
| Figure 9 - TDM256 Mode.....                                                           | 26  |
| Figure 10 - TDM512 Mode.....                                                          | 26  |
| Figure 11 - TDM1024 Mode.....                                                         | 26  |
| Figure 12 - TDM Connection of Several ES9039Q2M Devices in Parallel.....              | 27  |
| Figure 13 - TDM Connection of Several ES9039Q2M Devices in Daisy Chain Mode .....     | 28  |
| Figure 14 - DSD Format, 1-bit Stream .....                                            | 29  |
| Figure 15 - Minimum Phase 64FS Frequency Response .....                               | 46  |
| Figure 16 - Minimum Phase 64FS Impulse Response.....                                  | 46  |
| Figure 17 - GPIO8 Digital I/O with Calibration Resistor .....                         | 47  |
| Figure 18 – Recommended Power Up Sequence.....                                        | 49  |
| Figure 19 – Recommended Power Down Sequence .....                                     | 49  |
| Figure 18 - I <sup>2</sup> C Slave Control Interface Timing.....                      | 53  |
| Figure 19 - I <sup>2</sup> C Single Byte Examples of Read and Write Instructions..... | 53  |
| Figure 20 - SPI Single Byte Write .....                                               | 54  |
| Figure 21 - SPI Single Byte Read .....                                                | 54  |
| Figure 22 - SPI Multi-Byte Read .....                                                 | 54  |
| Figure 23 - Audio Interface Timing.....                                               | 55  |
| Figure 24 - Typical ES9039Q2M Software Mode Application Diagram.....                  | 95  |
| Figure 25 - Hardware (HW) Mode Reference Schematic for ES9039Q2M .....                | 96  |
| Figure 26 - Software Mode Reference Schematic for ES9039Q2M.....                      | 97  |
| Figure 27 - Output Stage Schematic for ES9039Q2M .....                                | 98  |
| Figure 28 - ES9039Q2M Power Supply Schematic .....                                    | 99  |
| Figure 29 - ES9039Q2M 32 QFN Package Dimensions.....                                  | 102 |
| Figure 30 - ES9039Q2M Marking .....                                                   | 103 |
| Figure 31 - IR/Convection Reflow Profile (IPC/JEDEC J-STD-020D.1) .....               | 104 |

## List of Tables

|                                                                     |     |
|---------------------------------------------------------------------|-----|
| Table 1 - 32 QFN Pin Descriptions .....                             | 10  |
| Table 2 - Mode Pin Configuration Options.....                       | 11  |
| Table 3 - I <sup>2</sup> C Addresses .....                          | 11  |
| Table 4 - SPI Commands .....                                        | 11  |
| Table 5 - GPIO Function in Hardware Mode .....                      | 12  |
| Table 6 - Mute Control for HW Mode Configuration.....               | 13  |
| Table 7 – Hardware Mode Pin Configurations Pt1 .....                | 14  |
| Table 8 – Hardware Mode Pin Configurations Pt2.....                 | 15  |
| Table 9 - Automute Configuration .....                              | 18  |
| Table 10 - GPIO Configuration Function.....                         | 20  |
| Table 11 - PCM Pin Connections.....                                 | 25  |
| Table 12 - TDM Pin Connections.....                                 | 26  |
| Table 13 - DSD Pin Connections .....                                | 29  |
| Table 14 - S/PDIF Pin Connections .....                             | 29  |
| Table 15 - S/PDIF Channel Status - Consumer Configuration .....     | 30  |
| Table 16 - S/PDIF Channel Status - Professional Configuration.....  | 31  |
| Table 17 - Pre-Programmed Digital Filter Descriptions.....          | 32  |
| Table 18 - PCM Filter Latency .....                                 | 34  |
| Table 19 - PCM Filter Properties .....                              | 35  |
| Table 20 - PCM Filter Frequency Response.....                       | 41  |
| Table 21 - PCM Filter Impulse Response .....                        | 44  |
| Table 22 - Minimum Phase 64FS Latency .....                         | 45  |
| Table 23 - Minimum Phase 64FS Properties .....                      | 45  |
| Table 24 - Absolute Maximum Ratings .....                           | 48  |
| Table 25 - I/O Electrical Characteristics.....                      | 48  |
| Table 26 - Recommended Operating Conditions .....                   | 49  |
| Table 27 - Power Consumption with Test Conditions 1 .....           | 50  |
| Table 28 - Power Consumption with Test Conditions 2 .....           | 51  |
| Table 29 - Performance Data .....                                   | 52  |
| Table 30 - I <sup>2</sup> C Slave Interface Timing Definitions..... | 53  |
| Table 31 - Audio Interface Timing Definitions .....                 | 55  |
| Table 32 - Register Map .....                                       | 57  |
| Table 33 - Internal Pad Circuitry .....                             | 101 |

## ES9039Q2M Product Datasheet

|                                                          |     |
|----------------------------------------------------------|-----|
| Table 34 - RPC-1 Classification Reflow Profile .....     | 105 |
| Table 35 - RPC-2 Pb Free Classification Temperature..... | 106 |
| Table 36 - Ordering Information.....                     | 107 |

## Functional Block Diagram



Figure 1 - Functional Block Diagram

## ES9039Q2M Package

### 32 QFN Pinout

(Pin 33 is QFN package pad, see package dimensions)



Figure 2 - ES9039Q2M Pinout



## 32 QFN Pin Descriptions

| Pin | Name                      | Pin Type | Reset State      | Pin Description                                                 |
|-----|---------------------------|----------|------------------|-----------------------------------------------------------------|
| 1   | AVCC_DAC1                 | Power    | Power            | 3.3V DAC analog output stage reference supply for the Channel 1 |
| 2   | DAC1B                     | AO       | Ground           | Differential Negative Output for Channel 1                      |
| 3   | DAC1                      | AO       | Ground           | Differential Positive Output for Channel 1                      |
| 4   | AGND_DAC1                 | Ground   | Ground           | DAC analog output stage ground for Channel 1                    |
| 5   | AGND_DAC2                 | Ground   | Ground           | DAC analog output stage ground for Channel 2                    |
| 6   | DAC2B                     | AO       | Ground           | Differential Negative Output for Channel 2                      |
| 7   | DAC2                      | AO       | Ground           | Differential Positive Output for Channel 2                      |
| 8   | AVCC_DAC2                 | Power    | Power            | 3.3V DAC analog output stage reference supply for the Channel 2 |
| 9   | DVDD                      | Power    | Power            | Digital Supply, 1.2V (Internally Supplied)                      |
| 10  | AVDD                      | Power    | Power            | 3.3V digital regulator supply                                   |
| 11  | GND                       | Ground   | Ground           | Device Ground                                                   |
| 12  | DATA_CLK                  | I        | HiZ              | Serial Data Clock pin                                           |
| 13  | DATA1                     | I        | HiZ              | Serial DATA1 pin                                                |
| 14  | DATA2                     | I        | HiZ              | Serial DATA2 pin                                                |
| 15  | SCLK                      | I        | HiZ              | SPI Serial Clock pin, controlled by MODE                        |
|     | SCL                       |          |                  | I <sup>2</sup> C Serial Clock pin, controlled by MODE           |
|     | HW1                       |          |                  | Hardware 1 interface pin, controlled by MODE                    |
| 16  | MOSI                      | I        | HiZ              | SPI Main Out Sub In pin, controlled by MODE                     |
|     | SDA                       |          |                  | I <sup>2</sup> C Serial Data pin, controlled by MODE            |
|     | HW0                       |          |                  | Hardware 0 interface pin, controlled by MODE                    |
| 17  | RT1                       | I/O      | HiZ              | Reserved. Must be connected to GND for normal operation.        |
| 18  | CHIP_EN                   | I/O      | HiZ              | Active-high Chip Enable                                         |
| 19  | SS                        | I        | HiZ              | SPI Slave Select pin, controlled by MODE                        |
|     | ADDR1                     |          |                  | I <sup>2</sup> C Address 1 pin, controlled by MODE              |
|     | HW2                       |          |                  | Hardware 2 interface pin, controlled by MODE                    |
| 20  | MISO                      | I        | HiZ              | SPI Main In Sub Out pin, controlled by MODE                     |
|     | ADDR0                     |          |                  | I <sup>2</sup> C Address 0 pin, controlled by MODE              |
|     | MUTE_CTRL                 |          |                  | Hardware Mute Control pin, controlled by MODE                   |
| 21  | GPIO1                     | I/O      | Ground           | Automute Output, General I/O w/extended functions               |
| 22  | GPIO2                     | I/O      | Ground           | Lock Status Output, General I/O w/extended functions            |
| 23  | GPIO3                     | I/O      | HiZ              | General I/O w/extended functions                                |
| 24  | GPIO4                     | I/O      | HiZ              | General I/O w/extended functions                                |
| 25  | GPIO5                     | I/O      | HiZ              | General I/O w/extended functions                                |
| 26  | GPIO6                     | I/O      | HiZ              | General I/O w/extended functions                                |
| 27  | GPIO7                     | I/O      | HiZ              | General I/O w/extended functions                                |
| 28  | GPIO8                     | I/O      | Res. to Ground** | Calibration Resistor & General I/O w/extended functions         |
| 29  | MODE                      | I/O      | HiZ              | I <sup>2</sup> C/SPI Control selection or HW mode               |
| 30  | GND                       | Ground   | Ground           | Device Ground                                                   |
| 31  | VCCA                      | Power    | Power            | Analog Supply, 3.3V                                             |
| 32  | MCLK                      | I/O      | HiZ              | Oscillator input                                                |
| 33  | External PAD <sup>1</sup> | -        | -                | External pad, connect to GND                                    |

Table 1 - 32 QFN Pin Descriptions

<sup>1</sup> Pin 33 is the package pad. See 32 QFN package dimensions for sizing. Connect to GND.

## Feature List

The ES9039Q2M is a SABRE® 2 channel high performance digital to analog converter (DAC) with features and performance including the new Hyperstream IV modulator that produced a very high-performance device that is well suited for a variety of applications.

In addition to improved performance, the new ES9039Q2M SABRE DAC now supports the TDM audio interface, SPI (or I<sup>2</sup>C) control interface and hardware modes for simplifying device configuration.

TDM, I<sup>2</sup>S including LJ & RJ, DSD & DoP audio interfaces are supported.

Sample rates up to 768kHz (@ 64FS Mode) with PCM data with 2 selectable digital filters to choose from and a programmable filter for custom sound signatures. DSD rates up to DSD1024 (512 x 44.1kHz) are also supported.

## Configuration Modes

The ES9039Q2M has 4 control programming modes. They are controlled by the state of the MODE pin (Pin 29).

| MODE PIN  | Configuration                             |
|-----------|-------------------------------------------|
| 0         | I <sup>2</sup> C Interface                |
| Pull Low  | HW control mode (see Hardware Mode Table) |
| Pull High | HW control mode (see Hardware Mode Table) |
| 1         | SPI Interface                             |

Table 2 - Mode Pin Configuration Options

## Software Mode

The ES9039Q2M supports I<sup>2</sup>C or SPI serial communication to configure registers. There are two types of registers, read/write and read-only registers.

### I<sup>2</sup>C

- MODE (Pin 29) - GND
- Connect per I<sup>2</sup>C standard
  - SDA (Pin 16)
  - SCL (Pin 15)
  - ADDR0 (Pin 20)
  - ADDR1 (Pin 19)

| I <sup>2</sup> C Address | ADDR1 | ADDR0 |
|--------------------------|-------|-------|
| 0x90                     | GND   | GND   |
| 0x92                     | GND   | AVDD  |
| 0x94                     | AVDD  | GND   |
| 0x96                     | AVDD  | AVDD  |

Table 3 - I<sup>2</sup>C Addresses

### SPI

- MODE (Pin 29) - AVDD
- Connect per SPI standard
  - MOSI (Pin 16)
  - SCLK (Pin 15)
  - SS (Pin 19)
  - MISO (Pin 20)

| SPI Command | First Byte |
|-------------|------------|
| Write       | 3          |
| Read        | 1          |

Table 4 - SPI Commands

## Hardware Mode

The ES9039Q2M has pre-configured modes that can be set with external pin configuration. These modes configure the DAC for different input serial data rates and set the DAC muting.

Note: All Synchronous hardware modes have Automatic FS (sample rate) detection enabled.

These modes are set with pins:

- MODE (Pin 29)
- HW0 (Pin 16)
- HW1 (Pin 15)
- HW2 (Pin 19)
- MUTE\_CTRL (Pin 20)

Each hardware mode pin has 4 states:

- 0 - Pin directly connected to GND
- 1 - Pin directly connected to AVDD
- Pull 0 - Pin pulled to GND through 47kΩ resistor
- Pull 1 - Pin pulled to AVDD through 47kΩ resistor

In Hardware mode, most GPIOs have specific functions.

| GPIO # | Input/Output | HW Mode Function                                                                                                                                                                                                          |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPIO1  | Output       | Automute Status (AND of both channels)                                                                                                                                                                                    |
| GPIO2  | Output       | SRC Lock (Reg 249[2] register for readback)                                                                                                                                                                               |
| GPIO3  | Output       | Daisy chain mode data output                                                                                                                                                                                              |
| GPIO4  | Input        | S/PDIF input in HW mode (HW modes 16-18)                                                                                                                                                                                  |
| GPIO5  | Input        | DoP HW enable:<br><ul style="list-style-type: none"> <li>• 1'b0: DoP disabled</li> <li>• 1'b1: DoP enabled</li> </ul> Note: Requires a PCM (I²S/LJ/TDM) HW mode to be selected                                            |
| GPIO6  | Input        | FIR filter selection:<br><ul style="list-style-type: none"> <li>• 1'b0: minimum phase (register default)</li> <li>• 1'b1: Linear phase fast roll-off</li> </ul> Note: See section on Digital Filters for more information |
| GPIO7  | Ground       | Must be connected to Ground in HW mode (Pin 27)                                                                                                                                                                           |
| GPIO8  | Input        | CAL_RES input (Calibration Resistor) See calibration section for more information                                                                                                                                         |

Table 5 - GPIO Function in Hardware Mode

## Design Information

Each hardware mode pin can be configured with either a pull-up or pull-down resistor. Therefore, it is important that the pin is configured to allow for the desired hardware modes. Some guidelines include the following:

- The HW0 and HW1 pins never require a pull up or pull-down resistor.



Figure 3 - Hardware Mode Pin Configurations

## Muting

MUTE\_CTRL (Pin 20) is used to control the muting of the output and enabling of the Automute feature while in Hardware Mode:

| HW MUTE Control (Pin 20) | Condition                        |
|--------------------------|----------------------------------|
| 0                        | Output Muted, No Automute        |
| 1                        | Output Unmuted, No Automute      |
| Pull 0                   | Output Muted, Automute Enabled   |
| Pull 1                   | Output Unmuted, Automute Enabled |

Table 6 - Mute Control for HW Mode Configuration



### Hardware Mode Pin Configuration

The following table shows the available hardware modes for the ES9039Q2M. All Synchronous Hardware modes (HW) have Automatic FS detection enabled with FS & BCK being detected. See Register 3[7] for more details.

| HW#                                 | Description                                                           | FS [kHz]  | BCK [MHz]         | MCLK [MHz]              | MODE   | HW2    | HW1 | HW0 |
|-------------------------------------|-----------------------------------------------------------------------|-----------|-------------------|-------------------------|--------|--------|-----|-----|
| <b>32-bit PCM Master Modes</b>      |                                                                       |           |                   |                         |        |        |     |     |
| 0                                   | I <sup>2</sup> S Master                                               | MCLK/128  | MCLK/2<br>(64FS)  | MCLK=128*FS<br>≤49.152  | Pull 0 | 0      | 0   | 0   |
| 1                                   | I <sup>2</sup> S Master                                               | MCLK/256  | MCLK/4<br>(64FS)  | MCLK=256*FS<br>≤49.152  | Pull 0 | 0      | 0   | 1   |
| 2                                   | I <sup>2</sup> S Master                                               | MCLK/512  | MCLK/8<br>(64FS)  | MCLK=512*FS<br>≤49.152  | Pull 0 | 0      | 1   | 0   |
| 3                                   | I <sup>2</sup> S Master                                               | MCLK/1024 | MCLK/16<br>(64FS) | MCLK=1024*FS<br>≤49.152 | Pull 0 | 0      | 1   | 1   |
| 4                                   | LJ Master Mode                                                        | MCLK/128  | MCLK/2<br>(64FS)  | MCLK=128*FS<br>≤49.152  | Pull 0 | Pull 0 | 0   | 0   |
| 5                                   | LJ Master Mode                                                        | MCLK/256  | MCLK/4<br>(64FS)  | MCLK=256*FS<br>≤49.152  | Pull 0 | Pull 0 | 0   | 1   |
| 6                                   | LJ Master Mode                                                        | MCLK/512  | MCLK/8<br>(64FS)  | MCLK=512*FS<br>≤49.152  | Pull 0 | Pull 0 | 1   | 0   |
| 7                                   | LJ Master Mode                                                        | MCLK/1024 | MCLK/16<br>(64FS) | MCLK=1024*FS<br>≤49.152 | Pull 0 | Pull 0 | 1   | 1   |
| <b>32-bit PCM Slave Modes, SYNC</b> |                                                                       |           |                   |                         |        |        |     |     |
| 8                                   | I <sup>2</sup> S Slave, SYNC, MCLK/1                                  | 8<FS<768  | 64FS              | 64*FS≤MCLK<br>≤49.152   | Pull 0 | Pull 1 | 0   | 0   |
| 9                                   | I <sup>2</sup> S Slave, SYNC, MCLK/2                                  | 8<FS<384  | 64FS              | 128*FS≤MCLK<br>≤49.152  | Pull 0 | Pull 1 | 0   | 1   |
| 10                                  | I <sup>2</sup> S Slave, SYNC, MCLK/4                                  | 8<FS<192  | 64FS              | 256*FS≤MCLK<br>≤49.152  | Pull 0 | Pull 1 | 1   | 0   |
| 11                                  | I <sup>2</sup> S Slave, SYNC,<br>Auto Clock Gear <sup>1</sup> (128FS) | 8<FS<384  | 64FS              | 64*FS≤MCLK<br>≤49.152   | Pull 0 | Pull 1 | 1   | 1   |
| 12                                  | LJ Slave, SYNC, MCLK/1                                                | 8<FS<768  | 64FS              | 64*FS≤MCLK<br>≤49.152   | Pull 0 | 1      | 0   | 0   |
| 13                                  | LJ Slave, SYNC, MCLK/2                                                | 8<FS<384  | 64FS              | 128*FS≤MCLK<br>≤49.152  | Pull 0 | 1      | 0   | 1   |
| 14                                  | LJ Slave, SYNC, MCLK/4                                                | 8<FS<192  | 64FS              | 256*FS≤MCLK<br>≤49.152  | Pull 0 | 1      | 1   | 0   |
| 15                                  | LJ Slave, SYNC,<br>Auto Clock Gear <sup>1</sup> (128FS)               | 8<FS<384  | 64FS              | 64*FS≤MCLK<br>≤49.152   | Pull 0 | 1      | 1   | 1   |

Table 7 – Hardware Mode Pin Configurations Pt1

<sup>1</sup> ACG (Auto Clock Gearing) is enabled, it will normally gear the MCLK down to  $\geq 128*FS$  in SYNC,  $\geq 130*FS$  in ASYNC, or  $2*DSDCLK$  in DSD modes.

## ES9039Q2M Product Datasheet



| HW#                                               | Description                                                                  | FS [kHz] | BCK [MHz]                                | MCLK [MHz]             | MODE   | HW2    | HW1 | HW0 |
|---------------------------------------------------|------------------------------------------------------------------------------|----------|------------------------------------------|------------------------|--------|--------|-----|-----|
| <b>32-bit PCM Slave Modes &amp; S/PDIF, ASYNC</b> |                                                                              |          |                                          |                        |        |        |     |     |
| 16                                                | S/PDIF <sup>1</sup> , I <sup>2</sup> S Slave, DoP <sup>2</sup> ASYNC, MCLK/1 | 8<FS<384 | 64FS                                     | 130*FS≤MCLK ≤50        | Pull 1 | 0      | 0   | 0   |
| 17                                                | S/PDIF <sup>1</sup> , I <sup>2</sup> S Slave, DoP <sup>2</sup> ASYNC, MCLK/2 | 8<FS<192 | 64FS                                     | 260*FS≤MCLK ≤50        | Pull 1 | 0      | 0   | 1   |
| 18                                                | S/PDIF <sup>1</sup> , I <sup>2</sup> S Slave, DoP <sup>2</sup> ASYNC, MCLK/4 | 8<FS<96  | 64FS                                     | 520*FS≤MCLK ≤50        | Pull 1 | 0      | 1   | 0   |
| 19                                                | I <sup>2</sup> S Slave, ASYNC, Auto Clock Gear <sup>3</sup> (>130FS)         | 8<FS<384 | 64FS                                     | 130*FS≤MCLK ≤50        | Pull 1 | 0      | 1   | 1   |
| 20                                                | LJ Slave, ASYNC, MCLK/1                                                      | 8<FS<384 | 64FS                                     | 130*FS≤MCLK ≤50        | Pull 1 | Pull 0 | 0   | 0   |
| 21                                                | LJ Slave, ASYNC, MCLK/2                                                      | 8<FS<192 | 64FS                                     | 260*FS≤MCLK ≤50        | Pull 1 | Pull 0 | 0   | 1   |
| 22                                                | LJ Slave, ASYNC, MCLK/4                                                      | 8<FS<96  | 64FS                                     | 520*FS≤MCLK ≤50        | Pull 1 | Pull 0 | 1   | 0   |
| 23                                                | LJ Slave, ASYNC, Auto Clock Gear <sup>3</sup> (>130FS)                       | 8<FS<384 | 64FS                                     | 130*FS≤MCLK ≤50        | Pull 1 | Pull 0 | 1   | 1   |
| <b>DSD &amp; TDM LJ Slave Modes</b>               |                                                                              |          |                                          |                        |        |        |     |     |
| 24                                                | DSD Slave SYNC, MCLK/1                                                       | BCK/64   | DSD64-512                                | 64*FS ≤ MCLK ≤ 45.1584 | Pull 1 | Pull 1 | 0   | 0   |
| 25                                                | DSD Slave SYNC, Auto Clock Gear (128*FS)                                     | BCK/64   | DSD64-512                                | 64*FS ≤ MCLK ≤ 45.1584 | Pull 1 | Pull 1 | 0   | 1   |
| 26                                                | DSD Slave ASYNC, MCLK/1                                                      | BCK/64   | DSD64-512                                | 130*FS ≤ MCLK ≤ 50     | Pull 1 | Pull 1 | 1   | 0   |
| 27                                                | DSD Slave ASYNC, Auto Clock Gear (>130*FS)                                   | BCK/64   | DSD64-512                                | 130*FS ≤ MCLK ≤ 50     | Pull 1 | Pull 1 | 1   | 1   |
| 28                                                | TDM <sup>4</sup> LJ Slave SYNC, Autodetect (Slots 1, 2)                      | 8<FS<768 | Auto (64FS, 128FS, 256FS, 512FS, 1024FS) | 64*FS≤MCLK ≤49.152     | Pull 1 | 1      | 0   | 0   |
| 29                                                | TDM <sup>4</sup> LJ Slave SYNC, Autodetect (Slots 3, 4)                      | 8<FS<384 | Auto (128FS, 256FS, 512FS, 1024FS)       | 128*FS≤MCLK ≤49.152    | Pull 1 | 1      | 0   | 1   |
| 30                                                | TDM <sup>4</sup> LJ Slave SYNC, Autodetect (Slots 5, 6)                      | 8<FS<192 | Auto (256FS, 512FS, 1024FS)              | 256*FS≤MCLK ≤49.152    | Pull 1 | 1      | 1   | 0   |
| 31                                                | TDM <sup>4</sup> LJ Slave SYNC, Autodetect (Slots 7, 8)                      | 8<FS<192 | Auto (256FS, 512FS, 1024FS)              | 256*FS≤MCLK ≤49.152    | Pull 1 | 1      | 1   | 1   |

Table 8 – Hardware Mode Pin Configurations Pt2

<sup>1</sup> For S/PDIF in HW mode, GPIO4 is the S/PDIF stream input. The ES9039Q2M must be reset (CHIP\_EN) when changing to and from S/PDIF.

<sup>2</sup> To enable DoP in HW mode, GPIO5 Pin must be high

<sup>3</sup> ACG (Auto Clock Gearing) is enabled, it will normally gear the MCLK down to >=128\*FS in SYNC, >130\*FS in ASYNC, or 2\*DSDCLK in DSD modes.

<sup>4</sup> TDM uses auto channel detect to determine the number of channels.

### Recommended Hardware Mode Setup Sequence

The hardware mode setup sequence is shown below with all hardware pins defined after CHIP\_EN is asserted.

Note: It is recommended that MUTE\_CTRL is set low until the HW mode is finalized and after CHIP\_EN is asserted, then asserted last.



Figure 4 - Hardware Mode Startup Sequence

## Digital Features

See Recommended Operating Conditions for additional information.

## Digital Signal Path

### SABRE DAC DIGITAL PATH



Figure 5 - Digital Signal Path

### Volume Control

This volume control is intended for use during audio playback. Each channel can be digitally attenuated from 0dB to -127.5dB in 0.5dB steps. When a new volume level is set, the attenuation circuit will ramp softly to the new level at a rate specified in the DAC VOL UP RATE, DAC VOL DOWN RATE and DAV VOL DOWN RATE FAST registers.

Muting the DAC output can be accomplished by DAC\_MUTE\_CHx from Register 86.

Channel volumes, by default, are updated as soon as the volume registers are written. However, the volume control can be updated for both channels together by using VOLUME\_HOLD.

### Volume Control Registers

- Register 74: VOLUME CH1
- Register 75: VOLUME CH2
- Register 82: DAC VOL UP RATE
- Register 83: DAC VOL DOWN RATE
- Register 84: DAC VOL RATE DOWN FAST
- Register 89[4]: VOLUME\_HOLD

Volume control is available for PCM (I<sup>2</sup>S, LJ, RJ, TDM), DoP (DSD over PCM), and DSD. There is separate control for each channel.

## Automute

In HW mode automute is controlled by the state of the MUTE\_CTRL pin (Pin 20), the pin must be “Pull 0” or “Pull 1” to enable automute.

In SW mode automute is enabled by default and can be disabled on each channel individually through Register 123 AUTOMUTE ENABLE.

The thresholds that engage and disengage automute can be configured through the AUTOMUTE LEVEL and AUTOMUTE OFF LEVEL registers.

If automute is enabled, it will be triggered when any one of the following conditions are met:

| Mode    | Detection Condition                                                                                                                                                                                                                | Time                                   |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| PCM     | Data is lower than automute_level for longer than the automute_time.<br>Data is at a constant DC level for longer than automute_time.                                                                                              | $\frac{2^{18}}{(automute\_time * FS)}$ |
| DoP/DSD | DSD data contains a DSD mute pattern (equal number of 1's and 0's in 8 consecutive bits of data), for longer than automute_time.<br>DSD data contains all 1's or 0's in 8 consecutive bits of data, for longer than automute_time. | $\frac{2^{18}}{(automute\_time * FS)}$ |

Table 9 - Automute Configuration

## Automute Configuration Registers

- Register 123: AUTOMUTE ENABLE
- Register 124-125: AUTOMUTE TIME
- Register 126-127: AUTOMUTE LEVEL
- Register 128-129: AUTOMUTE OFF LEVEL
- Register 62[7]: DISABLE\_DSD\_DC - Disables the DSD automute condition for 8 consecutive bits of 1'b1 or 1'b0
- Register 62[6]: DISABLE\_DSD\_MUTE - Disables the DSD automute condition for the DSD Mute pattern
- Register 62[0]: DISABLE\_PCM\_IC - Disables the PCM automute condition for a constant DC level

## 8x FIR Interpolation Oversampling Filter

Selection of the 8x interpolation filter is chosen from 8 pre-programmed filter shapes (Register 88[2:0] FILTER\_SHAPE) or custom sound signatures can be programmed.

For more information on filters see Digital Filters section.

## ES9039Q2M Product Datasheet

### THD Compensation

The ES9039Q2M has built-in THD compensation to help compensate for system second and third harmonics that may be present on the output signal. The compensation is controlled through 4 individual signed 16-bit coefficients in the THD Compensation Coefficient Registers.

The following equation displays how the second and third harmonics are affected by the C2 and C3 values:



Figure 6 - THD Compensation Block Diagram

### THD Compensation Coefficient Registers

- Registers 94-93: THD\_C2\_CH2      THD Compensation for C2 for Channel 2
- Registers 92-91: THD\_C2\_CH1      THD Compensation for C2 for Channel 1
- Registers 110-109: THD\_C3\_CH2      THD Compensation for C3 for Channel 2
- Registers 108-107: THD\_C3\_CH1      THD Compensation for C3 for Channel 1

Note: Coefficients are 16-bit signed values

### IIR Filter

The IIR filter in the ES9039Q2M can be bypassed by using Register 90[2]: IIR\_BYPASS.

The bandwidth of the filter is controlled by Register 89[2:0]: IIR\_BW

## GPIO Software Configuration

Each GPIO from 1 to 8 has 14 configurable modes (mode 8 & 15 are reserved). The table below shows the available configurations. See GPIO pin descriptions for Hardware and Software mode setups.

| GPIO#_CFG | Function                     | Input / Output | GPIO1     | GPIO2   | GPIO3   | GPIO4    | GPIO5     | GPIO6   | GPIO7   | GPIO8                           |
|-----------|------------------------------|----------------|-----------|---------|---------|----------|-----------|---------|---------|---------------------------------|
| 4'd0      | Analog Shutdown              | Output         |           |         |         |          |           |         |         | Shutdown                        |
| 4'd1      | Output 0                     | Output         |           |         |         |          |           |         |         | Output 0                        |
| 4'd2      | Output 1                     | Output         |           |         |         |          |           |         |         | Output 1                        |
| 4'd3      | Clocks                       | Output         | CLKEN_1FS | CLK_BCK | CLK_DAC | CLK_IDAC | CLKEN_1FS | CLK_BCK | CLK_DAC | CLK_IDAC                        |
| 4'd4      | Interrupt                    | Output         |           |         |         |          |           |         |         | OR of all interrupts            |
| 4'd5      | Mute                         | Input          |           |         |         |          |           |         |         | Mute all channels               |
| 4'd6      | System Mode Control          | Input          |           |         |         |          |           |         |         | See System mode control section |
| 4'd7      | SRC lock status              | Output         |           |         |         |          |           |         |         | src_locked flag                 |
| 4'd8      | External DEM                 | Output         |           |         |         |          |           |         |         | External DEM Output   Reserved  |
| 4'd9      | PWM1 signal                  | Output         |           |         |         |          |           |         |         | PWM1 signal                     |
| 4'd10     | PWM2 signal                  | Output         |           |         |         |          |           |         |         | PWM2 signal                     |
| 4'd11     | PWM3 signal                  | Output         |           |         |         |          |           |         |         | PWM3 signal                     |
| 4'd12     | Minimum volume <sup>1</sup>  | Output         |           |         |         |          |           |         |         | vol_min flag                    |
| 4'd13     | Automute status <sup>2</sup> | Output         |           |         |         |          |           |         |         | dac_automute flag               |
| 4'd14     | Soft ramp done <sup>2</sup>  | Output         |           |         |         |          |           |         |         | dac_ss_ramp flag                |
| 4'd15     | -                            | -              |           |         |         |          |           |         |         | Reserved                        |

Table 10 - GPIO Configuration Function

<sup>1</sup> Can be bitwise ANDed, ORed, or a specifical channel output; based on the values of Registers 46-47[6:0].

ESS TECHNOLOGY, INC. 109 Bonaventura Drive, San Jose, CA 95134, USA Tel (408) 643-8800 • WWW.ESSTECH.COM

## ES9039Q2M Product Datasheet

---

### GPIO Configuration Descriptions

#### Analog Shutdown

Output shutdown

#### Output 0

Outputs a constant 1'b0

#### Output 1

Outputs a constant 1'b1

#### Clocks

- GPIO1: CLKEN\_1FS (1\*FS pulse clock)
- GPIO2: CLK\_BCK
- GPIO3: CLK\_DAC (SYS\_CLK)
- GPIO4: CLK\_IDAC (128\*FS clock)
- GPIO5: CLKEN\_1FS
- GPIO6: CLK\_BCK
- GPIO7: CLK\_DAC
- GPIO8: CLK\_IDAC

#### Interrupt

Bitwise OR of all masked interrupts. See Register 10-21 for interrupt descriptions.

#### Mute

Mute all DAC channels.

#### System Mode Control

Works with Registers 46-47[15]: GPIO\_DAC\_MODE

When any GPIO<sub>x</sub>\_CFG = 4'b6 (system mode control):

- 1'b0: Disable datapath when GPIO<sub>x</sub> input is 1'b1
- 1'b1: Enable datapath when GPIO<sub>x</sub> input is 1'b1

When GPIO<sub>x</sub> input is 1'b0, system mode is determined by Register 0[1]: DAC\_MODE\_REG

#### SRC Lock Status

SRC (Sample Rate Converter) lock status output. If the device is in a synchronous mode, output will be 1'b0.

#### External DEM Output

The ES9039Q2M features a configuration mode that can combine multiple ES9039Q2M devices together to increase performance. The GPIO's can be used to transmit and receive the NSMOD data so that multiple devices work from the same data path. One ES9039Q2M is setup as a transmitter and the others work together as receivers. The receiver devices work in pairs with their DAC outputs combined into parallel output stages. Multiple pairs can then be combined into a single high-performance channel.

Note: For more information please ask your Local FAE for the External DEM Mode Application Note.



## PWM Signals

Outputs 1 of 3 PWM signals. Frequency and duty cycle on the PWM signals can be calculated with the following equations:

$$\text{frequency[Hz]} = \frac{\text{SYS\_CLK}}{\text{PWM\#\_FREQ} + 1}$$

$$\text{Duty Cycle[%]} = \left( \frac{\text{PWM\#\_COUNT}}{\text{PWM\#\_FREQ} + 1} \right) \times 100$$

Each PWM signal can be controlled by the following Registers:

- PWM1: Register 48 PWM1\_COUNT, Register 49-50 PWM1\_FREQ
- PWM2: Register 51 PWM2\_COUNT, Register 52-53 PWM2\_FREQ
- PWM3: Register 54 PWM3\_COUNT, Register 55-56 PWM3\_FREQ

## Minimum Volume

VOL\_MIN flag output is high during normal and abnormal mute conditions.

Normal mute conditions: register mute, gpio mute, override mute, and automute.

Abnormal mute conditions: loss of SRC lock, and BCK\_WS\_FAIL

Register 46-47[1]: GPIO\_AND\_VOL\_MIN sets the GPIO output to be the logical AND of all channel VOL\_MIN flags.  
Overrides GPIO\_OR\_VOL\_MIN.

Register 46-47[4]: GPIO\_OR\_VOL\_MIN sets the GPIO output to be the logical OR of all channel VOL\_MIN flags.

Register 46-47[6]: GPIO\_SEL will output the flag of a specific channel if GPIO\_OR\_VOL\_MIN and GPIO\_AND\_VOL\_MIN are both 1'b0.

## Automute Status

DAC\_AUTOMUTE flag output is high when automute is active.

Register 46-47[0]: GPIO\_AND\_AUTOMUTE sets the GPIO output to be the logical AND of all channel DAC\_AUTOMUTE flags.

Register 46-47[3]: GPIO\_OR\_AUTOMUTE set the GPIO output to be the logical OR of all channel DAC\_AUTOMUTE flags.

Register 46-47[6]: GPIO\_SEL will output the flag of a specific channel if GPIO\_OR\_AUTOMUTE and GPIO\_AND\_AUTOMUTE are both 1'b0.

## Soft Ramp Done

DAC\_SS\_RAMP flag output is high when the ES9039Q2M is not in the process of ramping either up or down.

Register 46-47[2]: GPIO\_AND\_SS\_RAMP sets the GPIO output to be the logical AND of all channel DAC\_SS\_RAMP flags.

Register 46-47[5]: GPIO\_OR\_SS\_RAMP sets the GPIO output to be the logical OR of all channel DAC\_SS\_RAMP flags.

Register 46-47[6]: GPIO\_SEL will output the flag of a specific channel if GPIO\_OR\_SS\_RAMP and GPIO\_AND\_SS\_RAMP are both 1'b0.

## GPIO Pin Descriptions

| GPIOx | Hardware Mode                                                                                                                                                  | Software mode                                                                                                                                                                                                                                   |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPIO1 | Automute status.                                                                                                                                               | Regular GPIO                                                                                                                                                                                                                                    |
| GPIO2 | Lock Status                                                                                                                                                    | Regular GPIO                                                                                                                                                                                                                                    |
| GPIO3 | No hardware mode connection                                                                                                                                    | GPIO3 is connected to the Reg60[5] <i>TDM_DAISY_CHAIN</i> logic. When <i>TDM_DAISY_CHAIN</i> = 1'b1, GPIO3 can ONLY be used as an output for daisy chain delayed data line. If <i>TDM_DAISY_CHAIN</i> = 1'b0, GPIO3 can then be used as a GPIO. |
| GPIO4 | S/PDIF input pin, requires HW modes 16-18.                                                                                                                     | Regular GPIO.                                                                                                                                                                                                                                   |
| GPIO5 | DoP input enable, requires HW modes 0-23, 28-31                                                                                                                | Regular GPIO.                                                                                                                                                                                                                                   |
| GPIO6 | FIR filter selection,<br>1'b0: Filter 0, Minimum phase<br>(register default),<br>1'b1: Filter 2, Linear phase fast roll-off.<br>Requires HW modes 0-23, 28-31. | Regular GPIO.                                                                                                                                                                                                                                   |
| GPIO7 | Connect to Ground*                                                                                                                                             | Regular GPIO.                                                                                                                                                                                                                                   |
| GPIO8 | CAL_RES (calibration resistor)                                                                                                                                 | CAL_RES, disable to use as regular GPIO.                                                                                                                                                                                                        |

Note\*: In Hardware mode GPIO7 needs to be connected to Ground.



## Audio Input Formats

The ES9039Q2M supports multiple serial input data formats. Input format is selected either through Hardware Mode or Software Mode (Register 1:SYS MODE CONFIG).

The ES9039Q2M can automatically determine the input data format by enabling Register 57[0]: AUTO\_INPUT\_SEL, data must be provided on the DATA2 pin, to properly decode the input format. The input data format can also be selected using Register 57[2:1]: INPUT\_SEL.

For Hardware Mode see hardware mode for inputs.

The formats include:

- PCM
  - Slave and master mode in 16, 24, and 32-bit widths
  - I<sup>2</sup>S, Left Justified (LJ), and Right Justified (RJ)
  - TDM up to TDM1024 mode with 32 slots including daisy chain mode
  - Sample rates up to 768kHz (64fs mode)
  - Channel Remapping & Invert
- DoP (DSD Over PCM)
  - Slave and master mode
  - Sample rates up to DoP512 (24bit, 1.4112MHz PCM)
  - Channel Remapping & Invert
- Native DSD
  - Slave and master mode
  - Sample rates from DSD64 (2.8224Mbits/sec, 64 x 44.1kHz) to DSD1024
  - Channel Remapping & Invert
- S/PDIF
  - Selectable input pin and payload information
  - S/PDIF input in HW mode (HW modes 16-18) using GPIO4

**ES9039Q2M Product Datasheet****PCM (I<sup>2</sup>S, LJ, RJ)**

Data is organized into 2 channels per data line. Any channel on any data line can be mapped to any DAC through the TDM\_CHx\_CONFIG channel mapping Registers 64-65. Data is latched on the positive edge of BCLK.

PCM Pin Connections (default configuration):

| Pin Name | Function              | Description                                                     |
|----------|-----------------------|-----------------------------------------------------------------|
| DATA_CLK | I <sup>2</sup> S BCLK | I <sup>2</sup> S Clock (Bit Clock), Master or Slave             |
| DATA1    | I <sup>2</sup> S WS   | I <sup>2</sup> S WS (Word Select/Frame Select), Master or Slave |
| DATA2    | I <sup>2</sup> S DATA | I <sup>2</sup> S Data                                           |

Table 11 - PCM Pin Connections

Figure 7 - LJ & I<sup>2</sup>S Input for 16bit and 32bit Word Depths

Note: RJ is supported but only in software mode.

## TDM (Time-Division Multiplexing)

The ES9039Q2M supports time-division multiplexing (TDM) format, allowing more than 2 channels (or slots) to be transmitted on each data line, up to a maximum of 32 channels per data line. Typical formats are TDM128 (4chx32bit), TDM256 (8chx32bit), TDM512 (16chx32bit) and TDM1024 (32chx32bit). In this mode, Registers 64[4:0] & 65[4:0] PCM\_CHx\_SLOT\_SEL can be used to internally map any TDM slot (channel) to either DAC. Data is latched on the positive edge of BCLK.

### TDM Pin Connection (default configuration)

| Pin Name | Function | Description                                        |
|----------|----------|----------------------------------------------------|
| DATA_CLK | TDM BCLK | TDM Clock, Master or Slave                         |
| DATA1    | TDM WS   | TDM WS (Word Select/Frame Select), Master or Slave |
| DATA2    | TDM DATA | TDM DATA                                           |

Table 12 - TDM Pin Connections



Figure 8 - TDM128 Mode



Figure 9 - TDM256 Mode



Figure 10 - TDM512 Mode



Figure 11 - TDM1024 Mode

## ES9039Q2M Product Datasheet

### Multiple ES9039Q2M Devices in Parallel in TDM Mode

In TDM modes, several ES9039Q2M can be used in parallel to increase the number of channels. Each ES9039Q2M can be configured in HW or SW mode to output its data to different slots on the TDM DATA line.

Note: in Hardware modes, only Left Justified TDM formats are supported. In Software mode, the user can configure it to be I<sup>2</sup>S TDM format.



Figure 12 - TDM Connection of Several ES9039Q2M Devices in Parallel

### Applicable Registers

- Register 60[7]: TDM\_LJ\_MODE set to 1'b1
- Register 60[6]: TDM\_VALID\_EDGE set to 1'b1
- Register 59[4:0]: TMD\_CH\_NUM
  - Or using Register 57[7]: AUTO\_CH\_DETECT
- Register 64-65[4:0]: PCM\_CHx\_SLOT\_SEL, sets the TDM slots for each device

**Daisy Chain Multiple ES9039Q2M Devices in TDM Mode**

Figure 13 - TDM Connection of Several ES9039Q2M Devices in Daisy Chain Mode

Applicable Registers (Daisy chain mode is only available in software mode)

- Register 60[7]: TDM\_LJ\_MODE set to 1'b1
- Register 60[6]: TDM\_VALID\_EDGE set to 1'b1
- Register 60[5]: TDM\_DAISY\_CHAIN: Enables Daisy Chain mode
  - GPIO3 will output data pass-through on DATA2 line delayed by 1 BCLK
- Register 59[4:0]: TDM\_CH\_NUM or using Register 57[7]: AUTO\_CH\_DETECT: Sets the # of TDM slots / frame
- Register 61[4:0]: TDM\_DATA\_LATCH\_ADJ: Sets the position of the start bit within each TDM slot
  - Value corresponds to the position of the device in the chain (zero-indexed)
- Register 64-65[4:0]: PCM\_CHx\_SLOT\_SEL: Sets the TDM slots for each device
  - Note: The first chip in the chain is required to be in the final 2 slots

Note: An application note for Daisy Chain mode and TDM in general is available from or your local ESS FAE distributor.

## ES9039Q2M Product Datasheet

DSD

ES9039Q2M supports Native DSD both in synchronous and asynchronous modes. DSD format requires a DSD clock, and each data channel requires its own independent DSD data line.

The ES9039Q2Ms DSD channels can be routed to each DAC by changing the respective channels DSD pin source. The pins can be chosen from DATA1, DATA2 or the GPIO input pins using:

- Register 64[7:5]: DSD\_CH1\_SOURCE
  - Register 65[7:5]: DSD\_CH2\_SOURCE

## DSD Pin Connections (default configuration)

| <b>Pin Name</b> | <b>Function</b> | <b>Description</b> |
|-----------------|-----------------|--------------------|
| DATA_CLK        | DSD Clock       | DSD Clock Input    |
| DATA1           | DSD CH1         | DSD DATA Channel 1 |
| DATA2           | DSD CH2         | DSD DATA Channel 2 |

**Table 13 - DSD Pin Connections**

Automute is available for DSD once a constant DC level (8 1's or 8 0's in a row) is detected. The ES9039Q2M will then automute to the proper DSD mute pattern.



Figure 14 - DSD Format, 1-bit Stream

S/PDIF

S/PDIF is supported in asynchronous mode only.

| Pin Name         | Description                                      |
|------------------|--------------------------------------------------|
| GPIO4            | HW mode 16-18 S/PDIF stream input                |
| GPIOx or DATA1/2 | Input selection from SPDIF_SEL for software mode |

Table 14 - S/PDIF Pin Connections

S/PDIF is transmitted over a single signal line using dual phase encoded data, which allows for clock extraction from the data signal line.

The ES9039Q2M has an integrated S/PDIF decoder that can be accessed in either Asynchronous Hardware or Software modes.

- For Hardware mode, the S/PDIF input is on GPIO4 using HW mode 16-18
    - S/PDIF unput stream must be disconnected in order to use other input formats
  - For Software mode, the applicable registers are:
    - Register 89[7:4]: SPDIF\_SEL
      - Selects the S/PDIF input pin
      - If a GPIO is selected, GPIO pins also require the GPIOx\_SDB input to be enabled
    - Register 136[4:0]: SPDIF\_DATA\_SEL
      - Selects the byte of the S/PDIF payload in Register 251[7:0]: SPDIF\_DATA\_READ
    - Register 251 SPDIF\_DATA\_READ
      - Readback the payload, 24 bytes total



For decoding the S/PDIF payload see Channel Status Table below:

| SPDIF CHANNEL STATUS - Consumer Configuration |                                                                                                                                                                                                                                                                                   |          |                                                                                                                 |          |                                                                                                                                                                                              |                                                                                                                                         |                     |                                                                                                                                    |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Address Offset (Bytes)                        | [7]                                                                                                                                                                                                                                                                               | [6]      | [5]                                                                                                             | [4]      | [3]                                                                                                                                                                                          | [2]                                                                                                                                     | [1]                 | [0]                                                                                                                                |
| 0                                             | Reserved                                                                                                                                                                                                                                                                          | Reserved | 0: 2 Channel<br>1: 4 Channel                                                                                    | Reserved | 0: No-Preemph<br>1: Preemph                                                                                                                                                                  | 0: CopyRight<br>1: Non-CopyRight                                                                                                        | 0: Audio<br>1: Data | 0: Consumer<br>1: Professional                                                                                                     |
| 1                                             | Category Code<br>0x00: General<br>0x01: Laser-Optical<br>0x02: DVD Converter<br>0x03: Magnetic<br>0x04: Digital Broadcast<br>0x05: Musical Instrument<br>0x06: Present A/D Converter<br>0x08: Solid State Memory<br>0x16: Future A/D Converter<br>0x19: DVD<br>0x40: Experimental |          |                                                                                                                 |          |                                                                                                                                                                                              |                                                                                                                                         |                     |                                                                                                                                    |
| 2                                             | Channel Number<br>0x0: Don't Care<br>0x1: A (Left)<br>0x2: B (Right)<br>0x3: C<br>0x4: D<br>0x5: E<br>0x6: F<br>0x7: G<br>0x8: H<br>0x9: I<br>0xA: J<br>0xB: K<br>0xC: L<br>0xD: M<br>0xE: N<br>0xF: O                                                                            |          |                                                                                                                 |          | Source Number<br>0x0: Don't Care<br>0x1: 1<br>0x2: 2<br>0x3: 3<br>0x4: 4<br>0x5: 5<br>0x6: 6<br>0x7: 7<br>0x8: 8<br>0x9: 9<br>0xA: 10<br>0xB: 11<br>0xC: 12<br>0xD: 13<br>0xE: 14<br>0xF: 15 |                                                                                                                                         |                     |                                                                                                                                    |
| 3                                             | Reserved                                                                                                                                                                                                                                                                          | Reserved | Clock Accuracy<br>0x0: Level 2 $\pm$ 1000ppm<br>0x1: Level 1 $\pm$ 50ppm<br>0x2: Level 3 variable pitch shifted |          |                                                                                                                                                                                              | Sample Frequency<br>0x0: 44.1k<br>0x2: 48k<br>0x3: 32k<br>0x4: 22.05k<br>0x6: 24k<br>0x8: 88.2k<br>0xA: 96k<br>0xC: 176.4k<br>0xE: 192k |                     |                                                                                                                                    |
| 4                                             | Reserved                                                                                                                                                                                                                                                                          | Reserved | Reserved                                                                                                        | Reserved | Word Length:<br>If Word Field Size = 0<br>000 = Not Indicated<br>100 = 19 bits<br>010 = 18 bits<br>110 = 17 bits<br>001 = 16 bits<br>101 = 20 bits                                           |                                                                                                                                         |                     | If Word Field Size = 1<br>000 = Not Indicated<br>100 = 23 bits<br>010 = 22 bits<br>110 = 21 bits<br>001 = 20 bits<br>101 = 24 bits |
| 5-23                                          | Word Field Size<br>0: Max 20 bits<br>1: Max 24 bits                                                                                                                                                                                                                               |          |                                                                                                                 |          |                                                                                                                                                                                              |                                                                                                                                         |                     |                                                                                                                                    |

Table 15 - S/PDIF Channel Status - Consumer Configuration

## ES9039Q2M Product Datasheet

| SPDIF CHANNEL STATUS - Professional Configuration |                                                                                                                                                                                                                                                    |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|--|--|
| Address Offset (Bytes)                            | [7]                                                                                                                                                                                                                                                | [6]                                                                                                                                                                    | [5]                                                                                                                                                 | [4] | [3]                                                                                                                                                                                                                                                                                                                                                                            | [2]                                                                                                                                                                | [1]                                                                                                                                                          | [0] |  |  |  |  |  |  |  |  |  |
| 0                                                 | Sampling Frequency:<br>00: Not Indicated (or see byte 4)<br>10: 48kHz<br>01: 44.1kHz<br>11: 32kHz                                                                                                                                                  | Lock:<br>0: Locked<br>1: Unlocked                                                                                                                                      | Emphasis:<br>000: Emphasis not Indicated<br>001: No Emphasis<br>011: CD-Type Emphasis<br>111: J-17 Emphasis                                         |     |                                                                                                                                                                                                                                                                                                                                                                                | 0: Audio<br>1: Non-Audio                                                                                                                                           | 0: Consumer<br>1: Professional                                                                                                                               |     |  |  |  |  |  |  |  |  |  |
| 1                                                 | User Bit Management:<br>0000: No Indication<br>1000: 192-bit Block as Channel Status<br>0100: As Defined in AES18<br>1100: User-Defined<br>0010: As in IEC60958-3 (consumer)                                                                       |                                                                                                                                                                        |                                                                                                                                                     |     | Channel Mode:<br>0000: Not Indicated (default to 2 ch)<br>1000: 2 Channel<br>0100: 1 Channel (monophonic)<br>1100: Primary / Secondary<br>0010: Stereo<br>1010: Reserved for User Applications<br>0110: Reserved for User Applications<br>1110: SCDSR (see byte 3 for ID)<br>0001: SCDSR (stereo left)<br>1001: SCDSR (stereo right)<br>1111: Multichannel (see byte 3 for ID) |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 2                                                 | Alignment Level:<br>00: Not Indicated<br>10: -20dBFS<br>01: -18.06dBFS                                                                                                                                                                             |                                                                                                                                                                        | Source Word Length:<br>If Max = 20 bits<br>000 = Not Indicated<br>100 = 19 bits<br>010 = 18 bits<br>110 = 17 bits<br>001 = 16 bits<br>101 = 20 bits |     | If Max = 24 bits<br>000 = Not Indicated<br>100 = 23 bits<br>010 = 22 bits<br>110 = 21 bits<br>001 = 20 bits<br>101 = 24 bits                                                                                                                                                                                                                                                   | Use of Aux Sample Word:<br>000: Not Defined, Audio Max 20 bits<br>100: Used for Main Audio, Max 24 bits<br>010: Used for Coord, Audio Max 20 bits<br>110: Reserved |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 3                                                 | Channel Identification:<br>If bit 7 = 0 then channel number is 1 plus the numeric value of bits 0-6 (bit reserved).<br>If bit 7 = 1 then bits 4-6 define a multichannel mode and bits 0-3 (bit reserved) give the channel number within that mode. |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 4                                                 | FS Scaling:<br>0: No Scaling<br>1: Apply Factor of 1/1.001 to Value                                                                                                                                                                                | Sample Frequency (FS):<br>0000: Not Indicated<br>0001: 24kHz<br>0010: 96kHz<br>1001: 22.05kHz<br>1010: 88.2kHz<br>1011: 176.4kHz<br>0011: 192kHz<br>1111: User defined |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                | Reserved                                                                                                                                                           | DARS (Digital Audio Reference Signal)<br>00: Not a DARS<br>01: DARS Grade 2 ( $\pm 10\text{ppm}$ )<br>10: DARS Grade 1 ( $\pm 1\text{ppm}$ )<br>11: Reserved |     |  |  |  |  |  |  |  |  |  |
| 5                                                 | Reserved                                                                                                                                                                                                                                           |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 6-9                                               | Alphanumeric Channel Origin: Four-Character Label using 7-bit ASCII with no Parity. Bits 55, 63, 71, 79 = 0.                                                                                                                                       |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 10-13                                             | Alphanumeric Channel Destination: Four-Character Label using 7-bit ASCII with no Parity. Bits 87, 95, 103, 111 = 0.                                                                                                                                |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 14-17                                             | Local Simple Address Code: 32-bit Binary Number Representing the Sample Count of the First Sample of the Channel Status Block                                                                                                                      |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 18-21                                             | Time of Dat Code: 32-bit Binary Number Representing the Time of Source Encoding in Sample Since Midnight                                                                                                                                           |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 22                                                | Reliability Flags<br>0: Data in Byte Range is Reliable<br>1: Data in Byte Range is Unreliable                                                                                                                                                      |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |
| 23                                                | CRCC<br>00000000: Not Implemented<br>X: Error Check Code for bits 0-183                                                                                                                                                                            |                                                                                                                                                                        |                                                                                                                                                     |     |                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                    |                                                                                                                                                              |     |  |  |  |  |  |  |  |  |  |

Table 16 - S/PDIF Channel Status - Professional Configuration

## Digital Filters

The ES9039Q2M has 8 pre-programmed digital filters. The latency for each filter reduces (scales) with increasing sample rates. (See Register 88[2:0] FILTER\_SHAPE for configuration)

| # | Filter                                     | Description                                                                                                                                                                                       |
|---|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | Minimum Phase (default)                    | Version 2 of minimum phase fast roll-off (#5) with less ripple and more image rejection                                                                                                           |
| 1 | Linear Phase Apodizing Fast Roll-Off       | Full image rejection by FS/2 to avoid any aliasing, with smooth roll-off starting before 20k.                                                                                                     |
| 2 | Linear Phase Fast Roll-Off                 | Sabre legacy filter, optimized for image rejection @ 0.55FS                                                                                                                                       |
| 3 | Linear Phase Fast Roll-Off Low-Ripple      | Sabre legacy filter, optimized for in-band ripple                                                                                                                                                 |
| 4 | Linear Phase Slow Roll-Off                 | Sabre legacy filter, optimized for lower latency, but symmetric impulse response                                                                                                                  |
| 5 | Minimum Phase Fast Roll-Off                | Low latency, minimal pre ringing and low passband ripple, image rejection @ 0.55FS                                                                                                                |
| 6 | Minimum Phase Slow Roll-Off                | Lowest latency at the cost of image rejection                                                                                                                                                     |
| 7 | Minimum Phase Fast Roll-Off Low Dispersion | Provides a nice balance of the low latency of minimum phase filters and the low dispersion of linear phase filters. Minimal pre-ringing is added to achieve the low dispersion in the audio band. |

Table 17 - Pre-Programmed Digital Filter Descriptions

Note: Minimum phase filters are asymmetric filters that work to minimize the pre-echo of the filter, while still maintaining an excellent frequency response and they peak earlier than linear phase filters, resulting in a lower group delay. Minimum phase filters usually feature zero cycles of pre-echo, which can result in improved audio quality.

## ES9039Q2M Product Datasheet

### Customizable Programmable FIR Filters

The ES9039Q2M has an 8x interpolation oversampling FIT filter that is programmable. It is a combination of 2 filters, a 4x FIR filter and a 2x FIR filter.

These filters can be bypassed using Register 90[1] BYPASS\_FIR4X & 90[0] BYPASS\_FIR2X, which will source data to the IIR filter. It is recommended to use an 8xFS input if the bypass is used. For example, an external signal at 44.1kHz can be oversampled externally to  $8 \times 44.1\text{kHz} = 352.8\text{kHz}$  and then applied to the serial decoder in either I<sup>2</sup>S, LJ or RJ format.

The addresses for the two filters are:

- 2x FIR, Address 0x00 - 0x7F (0 - 127), 128 coefficients
- 4x FIR, Address 0x80 - 0x9F (128 - 159), 32 coefficients

To program the filters, the following registers are required:

- Register 135: PROGRAM RAM CONTROL
  - [1] PROG\_COEFF\_WE
    - Enables writing to the programmable coefficient RAM
  - [0] PROG\_COEFF\_EN
    - Use the built-in filters or custom filter
- Register 137: PROGRAM RAM ADDRESS
  - [7] PROG\_COEFF\_STAGE
    - Choose which FIT stage to write to, either 4x or 2x
  - [6:0] PROG\_COEFF\_ADDR
    - Selects the coefficient address when writing custom coefficients for the interpolation oversampling filter
- Register 140-138: PROGRAM RAW DATA
  - 24-bit signed filter coefficient to the address defined by PROG\_COEFF\_ADDR
- Register 248-246: PROG COEFF OUT READ
  - Used to readback the programmed coefficients

An example sequence of programming a coefficient into RAM:

```

Write Reg 137 0      // RAM Address = 0, 2x stage
Write Reg 138 32     // Set data bits [7:0] of 24 bit coefficient
Write Reg 139 255     // Set data bits [15:8]
Write Reg 140 255     // Set data bits [23:16]
Write Reg 135 0x02     // Write 24 bit coefficient to RAM
Write Reg 135 0x00     // Reset write enable

```

Repeat for all 4x and 2x coefficient addresses.

An application note the programming sequence and sample code is available from your ESS Distributor or FAE.

## PCM Filter Latency

The following table shows the simulated latency of each filter at 44.1kHz sampling rate. Measurements were taken from the external impulse response. The extra sample delay to get the data encoded accounts for the external processing time to serialize the data stream.

| Digital Filter                             | Delay(us) @ FS = 44.1kHz |
|--------------------------------------------|--------------------------|
| Minimum Phase (default)                    | 174us                    |
| Linear Phase Apodizing Fast Roll-Off       | 840us                    |
| Linear Phase Fast Roll-Off                 | 854us                    |
| Linear Phase Fast Roll-Off Low-Ripple      | 808us                    |
| Linear Phase Slow Roll-Off                 | 229us                    |
| Minimum Phase Fast Roll-Off                | 174us                    |
| Minimum Phase Slow Roll-Off                | 152us                    |
| Minimum Phase Fast Roll-Off Low Dispersion | 310us                    |

Table 18 - PCM Filter Latency

## PCM Filter Properties

| Minimum Phase     |            |         |     |         |      |
|-------------------|------------|---------|-----|---------|------|
| Parameter         | Conditions | MIN     | TYP | MAX     | UNIT |
| Pass band         |            |         |     | 0.45FS  | Hz   |
| Stop band         | -96dB      | 0.55FS  |     |         | Hz   |
| Group Delay       |            | 2.91/FS |     | 9.01/FS | s    |
| Flatness (ripple) | 0.0012     |         |     |         | dB   |

| Linear Phase Apodizing |            |        |          |        |      |
|------------------------|------------|--------|----------|--------|------|
| Parameter              | Conditions | MIN    | TYP      | MAX    | UNIT |
| Pass band              |            |        |          | 0.41FS | Hz   |
| Stop band              | -107dB     | 0.50FS |          |        | Hz   |
| Group Delay            |            |        | 32.81/FS |        | s    |
| Flatness (ripple)      | 0.0027     |        |          |        | dB   |

| Linear Phase Fast Roll-off |            |        |          |        |      |
|----------------------------|------------|--------|----------|--------|------|
| Parameter                  | Conditions | MIN    | TYP      | MAX    | UNIT |
| Pass band                  |            |        |          | 0.45FS | Hz   |
| Stop band                  | -115dB     | 0.55FS |          |        | Hz   |
| Group Delay                |            |        | 33.43/FS |        | s    |
| Flatness (ripple)          | 0.0031     |        |          |        | dB   |

**ES9039Q2M Product Datasheet**

| <b>Linear Phase Fast Roll-off Low Ripple</b> |                   |            |            |            |             |
|----------------------------------------------|-------------------|------------|------------|------------|-------------|
| <b>Parameter</b>                             | <b>Conditions</b> | <b>MIN</b> | <b>TYP</b> | <b>MAX</b> | <b>UNIT</b> |
| Pass band                                    |                   |            |            | 0.46FS     | Hz          |
| Stop band                                    | -97dB             | 0.55FS     |            |            | Hz          |
| Group Delay                                  |                   |            | 31.37/FS   |            | s           |
| Flatness (ripple)                            | 0.0012            |            |            |            | dB          |

| <b>Linear Phase Slow Roll-off</b> |                   |            |            |            |             |
|-----------------------------------|-------------------|------------|------------|------------|-------------|
| <b>Parameter</b>                  | <b>Conditions</b> | <b>MIN</b> | <b>TYP</b> | <b>MAX</b> | <b>UNIT</b> |
| Pass band                         | -3dB              |            |            | 0.44FS     | Hz          |
| Stop band                         | -90dB             | 0.75FS     |            |            | Hz          |
| Group Delay                       |                   |            | 5.87/FS    |            | s           |
| Flatness (ripple)                 |                   |            |            |            | dB          |

| <b>Minimum Phase Fast Roll-off</b> |                   |            |            |            |             |
|------------------------------------|-------------------|------------|------------|------------|-------------|
| <b>Parameter</b>                   | <b>Conditions</b> | <b>MIN</b> | <b>TYP</b> | <b>MAX</b> | <b>UNIT</b> |
| Pass band                          |                   |            |            | 0.46FS     | Hz          |
| Stop band                          | -99dB             | 0.55FS     |            |            | Hz          |
| Group Delay                        |                   | 2.91/FS    |            | 9.14/FS    | s           |
| Flatness (ripple)                  | 0.0023            |            |            |            | dB          |

| <b>Minimum Phase Slow Roll-off</b> |                   |            |            |            |             |
|------------------------------------|-------------------|------------|------------|------------|-------------|
| <b>Parameter</b>                   | <b>Conditions</b> | <b>MIN</b> | <b>TYP</b> | <b>MAX</b> | <b>UNIT</b> |
| Pass band                          | -3dB              |            |            | 0.43FS     | Hz          |
| Stop band                          | -91dB             | 0.80FS     |            |            | Hz          |
| Group Delay                        |                   | 2.08/FS    |            | 3.56/FS    | s           |
| Flatness (ripple)                  |                   |            |            |            | dB          |

| <b>Minimum Phase Slow Roll-off Low Dispersion</b> |                   |            |            |            |             |
|---------------------------------------------------|-------------------|------------|------------|------------|-------------|
| <b>Parameter</b>                                  | <b>Conditions</b> | <b>MIN</b> | <b>TYP</b> | <b>MAX</b> | <b>UNIT</b> |
| Pass band                                         | -3dB              |            |            | 0.43FS     | Hz          |
| Stop band                                         | -90dB             | 0.80FS     |            |            | Hz          |
| Group Delay                                       |                   | 9.23/FS    |            | 9.75/FS    | s           |
| Flatness (ripple)                                 |                   |            |            |            | dB          |

Table 19 - PCM Filter Properties

## PCM Filter Frequency Response

The following frequency responses were obtained from software simulations of these filters. Simulation sample rate is 44.1kHz.

| Filter                 | Frequency Response                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Minimum Phase          | <p>Frequency Response at FS = 44.1 kHz</p> <p>This plot shows the frequency response of a minimum phase filter. The main plot displays the amplitude in dB on the y-axis (ranging from -180 to 20) against frequency in Hz on a logarithmic x-axis (from 10^2 to 10^5). An inset plot provides a detailed view of the low-frequency region, ranging from 10^2 to 10^4 Hz and -0.01 to 0.01 dB. The main plot shows a flat response at 0 dB until approximately 10^4 Hz, followed by a sharp roll-off. The inset plot shows a smooth, low-pass filtered signal with no ripples.</p>                                                |
| Linear Phase Apodizing | <p>Frequency Response at FS = 44.1 kHz</p> <p>This plot shows the frequency response of a linear phase apodizing filter. The main plot displays the amplitude in dB on the y-axis (ranging from -180 to 20) against frequency in Hz on a logarithmic x-axis (from 10^2 to 10^5). An inset plot provides a detailed view of the low-frequency region, ranging from 10^2 to 10^4 Hz and -0.01 to 0.01 dB. The main plot shows a flat response at 0 dB until approximately 10^4 Hz, followed by a sharp roll-off. The inset plot shows a signal with significant ripples and distortion, indicating a non-ideal filter response.</p> |

Linear Phase Fast Roll-Off



Linear Phase Fast Roll-Off  
Low Ripple



Linear Phase Slow Roll-Off



Minimum Phase Fast Roll-Off



Minimum Phase Slow Roll-Off



Minimum Phase Slow Roll-Off Low Dispersion



Linear Phase Slow Roll-Off



Minimum Phase Fast Roll-Off



Minimum Phase Slow Roll-Off



Minimum Phase Slow Roll-Off Low Dispersion



Table 20 - PCM Filter Frequency Response

## PCM Filter Impulse Response

The following impulse responses were obtained from software simulations of these filters. They were measured from external impulse response. The extra sample delay to get the data encoded accounts for the external processing time to serialize the data stream.

| Filter                 | Impulse Response                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Minimum Phase          | <p style="text-align: center;"><b>Impulse Response</b></p> <p>This graph shows the impulse response for a minimum phase filter. The x-axis is labeled "Samples of Fs" and ranges from 0 to 75. The y-axis is labeled "Amplitude" and ranges from -0.5 to 1.0. The response starts at zero, rises to a peak of approximately 0.65 at sample 12, then exhibits a series of damped oscillations with decreasing amplitude, eventually settling near zero by sample 40.</p> |
| Linear Phase Apodizing | <p style="text-align: center;"><b>Impulse Response</b></p> <p>This graph shows the impulse response for a linear phase apodizing filter. The x-axis is labeled "Samples of Fs" and ranges from 0 to 75. The y-axis is labeled "Amplitude" and ranges from -0.5 to 1.0. The response is zero until sample 30, where it rises to a single sharp peak of approximately 0.8 at sample 35, before rapidly decaying back towards zero.</p>                                    |

Linear Phase Fast Roll-Off



Linear Phase Fast Roll-Off  
Low Ripple



Linear Phase Slow Roll-Off





Table 21 - PCM Filter Impulse Response

## ES9039Q2M Product Datasheet

### 64FS Mode

When 64FS (MCLK/FS ratio) is required, it is necessary for the ES9039Q2M to be running in 64FS Mode. 64FS Mode can be manually entered by setting ENABLE\_64FS\_MODE to 1'b1, overriding the AUTO\_FS\_DETECT logic.

If using automatic sample rate detection with AUTO\_FS\_DETECT, 64FS Mode can be automatically accessed, unless AUTO\_FS\_DETECT\_BLOCK\_64FS is set to 1'b1.

### Software Registers

- Register 0[6] ENABLE\_64FS\_MODE
  - Use for 64FS ratios, including 705.6/768kHz sample rates
- Register 3[7] AUTO\_FS\_DETECT
  - 1'b0: Manually set sample rate with Register 1[6:0]
  - 1'b1: Automatically determine the sample rate (default)
- Register 5[0] AUTO\_FS\_DETECT\_BLOCK\_64FS
  - 1'b0: Allows AUTO\_FS\_DETECT to enter 64FS Mode (default)
  - 1'b1: Blocks AUTO\_FS\_DETECT from entering 64FS mode

This mode enables the Minimum Phase 64FS filter. See filter properties.

### Minimum Phase 64FS Mode Latency

The following table shows the simulated latency at 705.6kHz sampling rate and is scaled at 768kHz. The measurement was taken from the external impulse response. The extra sample delay to get the data encoded accounts for external processing time to serialize the data stream. Latency delay will reduce (scale) with sampling rate.

| Digital Filter            | Delay(us) @ FS = 705.6 kHz |
|---------------------------|----------------------------|
| Minimum Phase Double Rate | 8us                        |

Table 22 - Minimum Phase 64FS Latency

### Minimum Phase 64FS Properties

| Minimum Phase 64FS Mode |            |         |     |         |      |
|-------------------------|------------|---------|-----|---------|------|
| Parameter               | Conditions | MIN     | TYP | MAX     | UNIT |
| Pass band               | -3dB       |         |     | 0.45FS  | Hz   |
| Stop band               | -61dB      | 0.68FS  |     |         | Hz   |
| Group Delay             |            | 1.55/FS |     | 2.35/FS | s    |
| Flatness (ripple)       |            |         |     |         | dB   |

Table 23 - Minimum Phase 64FS Properties

## Minimum Phase 64FS Frequency Response

This filter gets selected automatically when MCLK/FS = 64. The following frequency response was obtained from software simulations with a sample rate of 705.6kHz.



Figure 15 - Minimum Phase 64FS Frequency Response

## Minimum Phase 64FS Impulse Response

The following impulse response was obtained from software simulations. It was measured from the external impulse response. The extra sample delay to get the data encoded accounts for external processing time to serialize the data stream.



Figure 16 - Minimum Phase 64FS Impulse Response

## Analog Features

### Calibration Resistor

The ES9039Q2M features a  $\sim 50\text{k}\Omega$  integrated resistor that is used for calibration of DAC voltage supplies AVCC\_DAC1 and AVCC\_DAC2. This calibration is required to maintain output level from device to device with the process varying DAC output impedance. The calibration resistor is accessible through GPIO8 (Pin 28) and terminated to ground as shown in the below figure.

To calibrate the AVCC\_DAC1 and AVCC\_DAC2 voltage supplies, a circuit is required to generate the voltage supply based on the resistor value. This can be done by generating a constant current and using that current through the internal calibration resistor to generate the reference voltage. This voltage is then buffered for the AVCC\_DACx supply.

The ultra low noise ESS ES9312 voltage regulator features a calibration mode that can be paired with the ES9039Q2M AVCC\_DAC1 and AVCC\_DAC2 supplies. The ES9312 connects to the ES9039Q2M integrated calibration resistor, on GPIO8, and adjusts the DAC output supplies to maintain a tighter distribution on the output level. See Recommended Power Supply for connections.

By default, the switch is closed (CAL\_RES\_ENB = 1'b0), Register 42[7] = 1'b0 (input disabled), and Register 41[7] GPIO8\_OE = 1'b0 (tristated).



Figure 17 - GPIO8 Digital I/O with Calibration Resistor

## Absolute Maximum Ratings

| PARAMETER                            | RATING                                   |
|--------------------------------------|------------------------------------------|
| Positive Supply Voltage              |                                          |
| • AVCC_DAC1                          | • -0.3V to +3.8V with respect to Ground  |
| • AVCC_DAC2                          | • -0.3V to +3.8 V with respect to Ground |
| • AVDD                               | • -0.3V to +3.7 V with respect to Ground |
| • VCCA                               | • -0.3V to +3.7 V with respect to Ground |
| • DVDD                               | • -0.3V to +1.4 V with respect to Ground |
| Storage Temperature                  | -65°C to +150°C                          |
| Operating Junction temperature       | +125°C                                   |
| Voltage Range for Digital Input Pins | -0.3V to AVDD(nom)+0.3V                  |
| ESD Protection                       |                                          |
| Human Body Model (HBM)               | 2kV                                      |
| Charge Device Model (CDM)            | 500V                                     |

Table 24 - Absolute Maximum Ratings

**WARNING:** Stresses beyond those listed under here may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those indicated under Recommended Operating Conditions is not implied.

**WARNING:** Electrostatic Discharge (ESD) can damage this device. Proper procedures must be followed to avoid ESD when handling this device.

## I/O Electrical Characteristics

| PARAMETER                 | SYMBOL | MINIMUM          | MAXIMUM | UNIT |
|---------------------------|--------|------------------|---------|------|
| High-Level Input Voltage  | VIH    | (AVDD / 2) + 0.4 |         | V    |
| Low-Level Input Voltage   | VIL    |                  | 0.4     | V    |
| High-Level Output Voltage | VOH    | AVDD - 0.2       |         | V    |
| Low-Level Output Voltage  | VOL    |                  | 0.2     | V    |

Table 25 - I/O Electrical Characteristics

## Recommended Operating Conditions

These are the recommended operating conditions for the ES9039Q2M.

| PARAMETER             | SYMBOL         | CONDITIONS      |
|-----------------------|----------------|-----------------|
| Operating Temperature | T <sub>A</sub> | -20°C to +85 °C |
| AVCC_DAC1             |                | 3.3V ±15%       |
| AVCC_DAC2             |                | 3.3V ±15%       |
| AVDD                  |                | 3.3V ±5%        |
| VCCA                  |                | 3.3V ±5%        |
| DVDD                  | Internal       | 1.2V            |

Table 26 - Recommended Operating Conditions

Notes:

1. AVCC\_DAC1/2 can change up to ±15% when using the ES9312Q Voltage Regulator in Calibration Mode. The output voltage will change as the DAC's output impedance changes. See ES9312Q Datasheet for more information.

## Recommended Power Up/Down Sequence

The recommended power up sequence for the ES9039Q2M, the AVDD supply is enabled ~200us before VCCA. Finally enable AVCC\_DAC1/2 then the chip can be enabled.



Figure 18 – Recommended Power Up Sequence

On power down, after CHIP\_EN is disabled, AVCC\_DAC1/2 are disabled, followed by VCCA, then finally AVDD.



Figure 19 – Recommended Power Down Sequence

## Power Consumption

Power numbers are given when the device is in slave mode.

Test Conditions 1 (unless otherwise noted)

$T_A=25^\circ\text{C}$ , AVCC\_R=AVCC\_L=VCCA=AVDD=+3.3V, DVDD=+1.2V,  $\text{fs}=48\text{kHz}$ , DAC enabled, 1kHz sine full scale.

| Parameter                                                                 | Min | Typ. | Max | Unit |
|---------------------------------------------------------------------------|-----|------|-----|------|
| <b>Hardware Mode: 11 (Slave mode with ACG (128*FS), MCLK = 49.152MHz)</b> |     |      |     |      |
| AVCC_DAC1                                                                 |     | 5.9  |     | mA   |
| AVCC_DAC2                                                                 |     | 5.9  |     | mA   |
| VCCA                                                                      |     | 0.4  |     | mA   |
| AVDD                                                                      |     | 4.0  |     | mA   |
| Power Consumption                                                         |     | 54   |     | mW   |
| <b>Hardware Mode: 2 (Master mode with MCLK = 24.576MHz, FS=MCLK/512)</b>  |     |      |     |      |
| AVCC_DAC1                                                                 |     | 6.8  |     | mA   |
| AVCC_DAC2                                                                 |     | 6.8  |     | mA   |
| VCCA                                                                      |     | 0.5  |     | mA   |
| AVDD                                                                      |     | 9.4  |     | mA   |
| Power Consumption                                                         |     | 78   |     | mW   |
| <b>Hardware Mode: 1 (Master mode with MCLK = 12.288MHz, FS=MCLK/256)</b>  |     |      |     |      |
| AVCC_DAC1                                                                 |     | 6.2  |     | mA   |
| AVCC_DAC2                                                                 |     | 6.2  |     | mA   |
| VCCA                                                                      |     | 0.22 |     | mA   |
| AVDD                                                                      |     | 6.9  |     | mA   |
| Power Consumption                                                         |     | 64   |     | mW   |

Table 27 - Power Consumption with Test Conditions 1

## ES9039Q2M Product Datasheet

Test Conditions 2 (unless otherwise noted)

$T_A=25^\circ\text{C}$ , AVCC\_R=AVCC\_L=VCCA=AVDD=+3.3V, DVDD=+1.2V,  $f_s=48\text{kHz}$ , DAC enabled, streaming zeros, automute enabled.

| Parameter                                                                 | Min | Typ. | Max | Unit |
|---------------------------------------------------------------------------|-----|------|-----|------|
| <b>Hardware Mode: 11 (Slave mode with ACG (128*FS), MCLK = 49.152MHz)</b> |     |      |     |      |
| AVCC_DAC1                                                                 |     | 0.8  |     | mA   |
| AVCC_DAC2                                                                 |     | 0.8  |     | mA   |
| VCCA                                                                      |     | 0.4  |     | mA   |
| AVDD                                                                      |     | 2.4  |     | mA   |
| Power Consumption                                                         |     | 15   |     | mW   |
| <b>Hardware Mode: 2 (Master mode with MCLK = 24.576MHz, FS=MCLK/512)</b>  |     |      |     |      |
| AVCC_DAC1                                                                 |     | 1.5  |     | mA   |
| AVCC_DAC2                                                                 |     | 1.5  |     | mA   |
| VCCA                                                                      |     | 0.44 |     | mA   |
| AVDD                                                                      |     | 6.9  |     | mA   |
| Power Consumption                                                         |     | 34   |     | mW   |
| <b>Hardware Mode: 1 (Master mode with MCLK = 12.288MHz, FS=MCLK/256)</b>  |     |      |     |      |
| AVCC_DAC1                                                                 |     | 1.0  |     | mA   |
| AVCC_DAC2                                                                 |     | 1.0  |     | mA   |
| VCCA                                                                      |     | 0.2  |     | mA   |
| AVDD                                                                      |     | 5.0  |     | mA   |
| Power Consumption                                                         |     | 24   |     | mW   |

Table 28 - Power Consumption with Test Conditions 2



## Performance

Test Conditions 1 (unless otherwise noted)

$T_A = 25^\circ\text{C}$ , AVCC\_DAC1 = AVCC\_DAC2 = VCCA = AVDD = +3.3V, DVDD= +1.2V,  $f_s = 48\text{kHz}$ , HW mode (I<sup>2</sup>S Master Mode)

Note: Performance numbers were measured using the ESS ES9039Q2M evaluation board v1.0, 10Vrms = 0dBFS input.

| Parameter                                                          |                       | Min | Typ.                                                                        | Max | Unit            |
|--------------------------------------------------------------------|-----------------------|-----|-----------------------------------------------------------------------------|-----|-----------------|
| Resolution                                                         |                       |     | 32                                                                          |     | Bit             |
| Max MCLK Frequency                                                 |                       |     |                                                                             | 50  | MHz             |
| THD+N Ratio / THD Ratio<br>@ $f_s=48\text{kHz}$<br>(differential)  | 0dBFS, BW=20Hz-20kHz  |     | -120/-126                                                                   |     | dB              |
| THD+N Ratio / THD Ratio<br>@ $f_s=96\text{kHz}$<br>(differential)  | 0dBFS, BW=20Hz-40kHz  |     | -117/-126                                                                   |     | dB              |
| THD+N Ratio / THD Ratio<br>@ $f_s=192\text{kHz}$<br>(differential) | 0dBFS, BW=20Hz-80kHz  |     | -114/-126                                                                   |     | dB              |
| THD+N Ratio / THD Ratio<br>@ $f_s=384\text{kHz}$<br>(differential) | 0dBFS, BW=20Hz-160kHz |     | -108/-126                                                                   |     | dB              |
| DNR (A-weighted)<br>(2 Channel mode - Single<br>Channel Diff)      | -60dBFS               |     | 130                                                                         |     | dB              |
| DNR (A-weighted)<br>(Mono mode - 2 Channel Sum<br>Diff)            |                       |     | 133                                                                         |     | dB              |
| Voltage Output Amplitude                                           | Full-Scale Out        |     | $0.889 * \text{AVCC}$                                                       |     | V <sub>pp</sub> |
| Voltage Output Offset                                              | Bipolar Zero Out      |     | $\frac{\text{AVCC}}{2}$                                                     |     | V               |
| Current Output Amplitude                                           | Full-Scale Out        |     | $\frac{1000 * 0.889 * \text{AVCC}}{\text{Rdac}}$                            |     | mApp            |
| Current Output Offset                                              | Bipolar Zero Out      |     | $\frac{1000 * \left(\frac{\text{AVCC}}{2} - \text{Vg}\right)}{\text{Rdac}}$ |     | mA              |
| Output Impedance<br>(Per + or - pin of each DAC<br>output)         | $R_{\text{DAC}}$      |     | $390 \pm 15\%$                                                              |     | $\Omega$        |

Table 29 - Performance Data

## Timing Requirements

### I<sup>2</sup>C Slave Interface Timing

Figure 20 - I<sup>2</sup>C Slave Control Interface Timing

| Parameter                                                                    | Symbol              | CLK Constraint | Standard-Mode |      | Fast-Mode  |     | Unit    |
|------------------------------------------------------------------------------|---------------------|----------------|---------------|------|------------|-----|---------|
|                                                                              |                     |                | MIN           | MAX  | MIN        | MAX |         |
| SCL Clock Frequency                                                          | f <sub>SCL</sub>    | < CLK/20       | 0             | 100  | 0          | 400 | kHz     |
| START condition hold time                                                    | t <sub>HD;STA</sub> |                | 4.0           | -    | 0.6        | -   | μs      |
| LOW period of SCL                                                            | t <sub>LOW</sub>    | >10/CLK        | 4.7           | -    | 1.3        | -   | μs      |
| HIGH period of SCL (>10/CLK)                                                 | t <sub>HIGH</sub>   | >10/CLK        | 4.0           | -    | 0.6        | -   | μs      |
| START condition setup time (repeat)                                          | t <sub>su;STA</sub> |                | 4.7           | -    | 0.6        | -   | μs      |
| SDA hold time from SCL falling<br>- All except NACK read<br>- NACK read only | t <sub>HD;DAT</sub> |                | 0<br>2/CLK    | -    | 0<br>2/CLK | -   | μs<br>s |
| SDA setup time from SCL rising                                               | t <sub>su;DAT</sub> |                | 250           | -    | 100        | -   | ns      |
| Rise time of SDA and SCL                                                     | t <sub>r</sub>      |                | -             | 1000 |            | 300 | ns      |
| Fall time of SDA and SCL                                                     | t <sub>f</sub>      |                | -             | 300  |            | 300 | ns      |
| STOP condition setup time                                                    | t <sub>su;STO</sub> |                | 4             | -    | 0.6        | -   | μs      |
| Bus free time between transmissions                                          | t <sub>BUF</sub>    |                | 4.7           | -    | 1.3        | -   | μs      |
| Capacitive load for each bus line                                            | C <sub>b</sub>      |                | -             | 400  | -          | 400 | pF      |

Table 30 - I<sup>2</sup>C Slave Interface Timing DefinitionsFigure 21 - I<sup>2</sup>C Single Byte Examples of Read and Write Instructions

## SPI Slave Interface

The 4-wire SPI data format is: Command (1 byte) + Address (1 byte) + Data.



Figure 22 - SPI Single Byte Write



Figure 23 - SPI Single Byte Read



Figure 24 - SPI Multi-Byte Read

## Audio Interface Timing

Audio data on DATA1-2 are sampled at the rising edges of DATA\_CLK and must satisfy the setup and hold time requirements relative to the rising edge of DATA\_CLK.



Figure 25 - Audio Interface Timing

| Parameter                                 | Symbol    | Min   | Max   | Unit |
|-------------------------------------------|-----------|-------|-------|------|
| DATA_CLK pulse width high                 | $t_{DCH}$ | 9.0   |       | ns   |
| DATA_CLK pulse width low                  | $t_{DCL}$ | 9.0   |       | ns   |
| DATA_CLK cycle time                       | $t_{DCY}$ | 20    |       | ns   |
| DATAx set-up time to DATA_CLK rising edge | $t_{DS}$  | 45:55 | 55:45 |      |
| DATAx hold time to DATA_CLK rising edge   | $t_{DH}$  | 4.1   |       | ns   |
|                                           |           | 2.0   |       | ns   |

Table 31 - Audio Interface Timing Definitions

## Register Overview

The ES9039Q2M contains read/write and read-only registers. A system clock must be present to access registers.

Multi-byte registers must be written from LSB to MSB. Data is latched when MSB is written.

Multi-byte register must be read from LSB to MSB. Data is latched when LSB is read.

MSB is always stored in the highest register address.

### Read/Write Register Addresses

Register 0 - 142 (0x00 - 0x8E) are read/write registers.

### Read-Only Register Addresses

Register 224 - 251 (0xE0 - 0xFB) are read only registers.

### Multi-Byte Registers

Multi-byte register must be written from LSB to MSB. Data is latched when MSB is written.

MSB is always stored in the highest register address.



## Register Map

| Addr<br>(Hex) | Addr<br>(Dec) | Register               | 7                 | 6                          | 5                           | 4                      | 3                       | 2                       | 1                 | 0                         |  |  |
|---------------|---------------|------------------------|-------------------|----------------------------|-----------------------------|------------------------|-------------------------|-------------------------|-------------------|---------------------------|--|--|
| 0x00          | 0             | SYSTEM CONFIG          | SOFT_RESET        | ENABLE_64FS_MODE           | RESERVED                    |                        |                         |                         | DAC_MODE          | RESERVED                  |  |  |
| 0x01          | 1             | SYS MODE CONFIG        | ENABLE_DAC_CLK    | SYNC_MODE                  | RESERVED                    |                        | ENABLE_SPDIF_DECODE     | ENABLE_DOP_DECODE       | ENABLE_DSD_DECODE | ENABLE_TDM_DECODE         |  |  |
| 0x02          | 2             | RESERVED               |                   |                            | RESERVED                    |                        |                         |                         |                   |                           |  |  |
| 0x03          | 3             | DAC CLOCK CONFIG       | AUTO_FS_DETECT    | SELECT_IDAC_HALF           | SELECT_IDAC_NUM             |                        |                         |                         |                   |                           |  |  |
| 0x04          | 4             | CLOCK CONFIG           |                   |                            | MASTER_BCK_DIV              |                        |                         |                         |                   |                           |  |  |
| 0x05          | 5             | CLK GEAR SELECT        |                   | RESERVED                   |                             | SEL_CLK_GEAR           | RESERVED                | AUTO_CLK_GEAR           | RESERVED          | AUTO_FS_DETECT_BLOCK_64FS |  |  |
| 0x06-0x09     | 6-9           | RESERVED               |                   |                            | RESERVED                    |                        |                         |                         |                   |                           |  |  |
| 0x0A          | 10            | INTERRUPT MASKP        | BCK_WS_FAIL_MASKP | DOP_VALID_MASKP            | SS_FULL_RAMP_CH2_MASKP      | SS_FULL_RAMP_CH1_MASKP | AUTOMUTE_FLAG_CH2_MASKP | AUTOMUTE_FLAG_CH1_MASKP | VOL_MIN_CH2_MASKP | VOL_MIN_CH1_MASKP         |  |  |
| 0x0B          | 11            |                        |                   | RESERVED                   | INPUT_SELECT_OVERRIDE_MASKP | TDM_VALID_EDGE_MASKP   |                         |                         | RESERVED          |                           |  |  |
| 0x0C-0x0E     | 12-14         | RESERVED               |                   |                            | RESERVED                    |                        |                         |                         |                   |                           |  |  |
| 0x0F          | 15            | INTERRUPT MASKN        | BCK_WS_FAIL_MASKN | DOP_VALID_MASKN            | SS_FULL_RAMP_CH2_MASKN      | SS_FULL_RAMP_CH1_MASKN | AUTOMUTE_FLAG_CH2_MASKN | AUTOMUTE_FLAG_CH1_MASKN | VOL_MIN_CH2_MASKN | VOL_MIN_CH1_MASKN         |  |  |
| 0x10          | 16            |                        |                   | RESERVED                   | INPUT_SELECT_OVERRIDE_MASKN | TDM_VALID_EDGE_MASKN   |                         |                         | RESERVED          |                           |  |  |
| 0x11-0x13     | 17-19         | RESERVED               |                   |                            | RESERVED                    |                        |                         |                         |                   |                           |  |  |
| 0x14          | 20            | INTERRUPT CLEAR        | BCK_WS_FAIL_CLEAR | DOP_VALID_CLEAR            | SS_FULL_RAMP_CH2_CLEAR      | SS_FULL_RAMP_CH1_CLEAR | AUTOMUTE_FLAG_CH2_CLEAR | AUTOMUTE_FLAG_CH1_CLEAR | VOL_MIN_CH2_CLEAR | VOL_MIN_CH1_CLEAR         |  |  |
| 0x15          | 21            |                        |                   | RESERVED                   | INPUT_SELECT_OVERRIDE_CLEAR | TDM_VALID_EDGE_CLEAR   |                         |                         | RESERVED          |                           |  |  |
| 0x16-0x1C     | 22-28         | RESERVED               |                   |                            | RESERVED                    |                        |                         |                         |                   |                           |  |  |
| 0x1D          | 29            | DPLL BW                |                   |                            | DPLL_BW                     |                        |                         |                         | RESERVED          |                           |  |  |
| 0x1E-0x21     | 30-33         | RESERVED               |                   |                            | RESERVED                    |                        |                         |                         |                   |                           |  |  |
| 0x22          | 34            | DATA PATH CONFIG       | MONO_MODE         | CAL_RES_ENB                |                             |                        | RESERVED                |                         |                   |                           |  |  |
| 0x23          | 35            | PCM 4X GAIN            |                   |                            | RESERVED                    |                        |                         |                         | CH2_PCM_4X_GAIN   | CH1_PCM_4X_GAIN           |  |  |
| 0x24          | 36            | RESERVED               |                   |                            | RESERVED                    |                        |                         |                         |                   |                           |  |  |
| 0x25          | 37            | GPIO1/2 CONFIG         |                   |                            | GPIO2_CFG                   |                        |                         |                         | GPIO1_CFG         |                           |  |  |
| 0x26          | 38            | GPIO3/4 CONFIG         |                   |                            | GPIO4_CFG                   |                        |                         |                         | GPIO3_CFG         |                           |  |  |
| 0x27          | 39            | GPIO5/6 CONFIG         |                   |                            | GPIO6_CFG                   |                        |                         |                         | GPIO5_CFG         |                           |  |  |
| 0x28          | 40            | GPIO7/8 CONFIG         |                   |                            | GPIO8_CFG                   |                        |                         |                         | GPIO7_CFG         |                           |  |  |
| 0x29          | 41            | GPIO OUTPUT ENABLE     | GPIO8_OE          | GPIO7_OE                   | GPIO6_OE                    | GPIO5_OE               | GPIO4_OE                | GPIO3_OE                | GPIO2_OE          | GPIO1_OE                  |  |  |
| 0x2A          | 42            | GPIO INPUT             | GPIO8_SDB         | GPIO7_SDB                  | GPIO6_SDB                   | GPIO5_SDB              | GPIO4_SDB               | GPIO3_SDB               | GPIO2_SDB         | GPIO1_SDB                 |  |  |
| 0x2B          | 43            | GPIO WK EN             | GPIO8_WK_EN       | GPIO7_WK_EN                | GPIO6_WK_EN                 | GPIO5_WK_EN            | GPIO4_WK_EN             | GPIO3_WK_EN             | GPIO2_WK_EN       | GPIO1_WK_EN               |  |  |
| 0x2C          | 44            | INVERT GPIO            | INVERT_GPIO8      | INVERT_GPIO7               | INVERT_GPIO6                | INVERT_GPIO5           | INVERT_GPIO4            | INVERT_GPIO3            | INVERT_GPIO2      | INVERT_GPIO1              |  |  |
| 0x2D          | 45            | GPIO READ              | GPIO8_READ        | GPIO7_READ                 | GPIO6_READ                  | GPIO5_READ             | GPIO4_READ              | GPIO3_READ              | GPIO2_READ        | GPIO1_READ                |  |  |
| 0x2E          | 46            | GPIO OUTPUT LOGIC      | RESERVED          | GPIO_SEL                   | GPIO_OR_SS_RAMP             | GPIO_OR_VOL_MIN        | GPIO_OR_AUTOMUTE        | GPIO_AND_SS_RAMP        | GPIO_AND_VOL_MIN  | GPIO_AND_AUTOMUTE         |  |  |
| 0x2F          | 47            |                        | GPIO_DAC_MODE     |                            |                             | RESERVED               |                         |                         |                   |                           |  |  |
| 0x30          | 48            | PWM1 COUNT             |                   |                            | PWM1_COUNT                  |                        |                         |                         |                   |                           |  |  |
| 0x31          | 49            | PWM1 FREQUENCY         |                   |                            | PWM1_FREQ                   |                        |                         |                         |                   |                           |  |  |
| 0x32          | 50            |                        |                   |                            | PWM1_FREQ                   |                        |                         |                         |                   |                           |  |  |
| 0x33          | 51            | PWM2 COUNT             |                   |                            | PWM2_COUNT                  |                        |                         |                         |                   |                           |  |  |
| 0x34          | 52            | PWM2 FREQUENCY         |                   |                            | PWM2_FREQ                   |                        |                         |                         |                   |                           |  |  |
| 0x35          | 53            |                        |                   |                            | PWM2_FREQ                   |                        |                         |                         |                   |                           |  |  |
| 0x36          | 54            | PWM3 COUNT             |                   |                            | PWM3_COUNT                  |                        |                         |                         |                   |                           |  |  |
| 0x37          | 55            | PWM3 FREQUENCY         |                   |                            | PWM3_FREQ                   |                        |                         |                         |                   |                           |  |  |
| 0x38          | 56            |                        |                   |                            | PWM3_FREQ                   |                        |                         |                         |                   |                           |  |  |
| 0x39          | 57            | INPUT SELECTION        | AUTO_CH_DETECT    | ENABLE_DSD_FAULT_DETECTION | DSD_MASTER_MODE             | PCM_MASTER_MODE        | RESERVED                | INPUT_SEL               |                   | AUTO_INPUT_SEL            |  |  |
| 0x3A          | 58            | MASTER ENCODER CONFIG  | TDM_RESETNC       | BCK_INV                    | RESERVED                    | MASTER_FRAME_LENGTH    | MASTER_WS_PULSE_MODE    | MASTER_WS_INVERT        | MASTER_BCK_INVERT |                           |  |  |
| 0x3B          | 59            | TDM CONFIG             |                   |                            | RESERVED                    |                        |                         |                         | TDM_CH_NUM        |                           |  |  |
| 0x3C          | 60            | TDM CONFIG1            | TDM_LJ_MODE       | TDM_VALID_EDGE             | TDM_DAISY_CHAIN             |                        | RESERVED                |                         |                   |                           |  |  |
| 0x3D          | 61            | TDM CONFIG2            | RESERVED          |                            | TDM_BIT_WIDTH               |                        | TDM_DATA_LATCH_ADJ      |                         |                   |                           |  |  |
| 0x3E          | 62            | BCKWS MONITOR CONFIG   | DISABLE_DSD_DC    | DISABLE_DSD_MUTE           | ENABLE_WS_MONITOR           | ENABLE_BCK_MONITOR     | DISABLE_PCM_DC          |                         | RESERVED          |                           |  |  |
| 0x3F          | 63            | RESERVED               |                   |                            |                             | RESERVED               |                         |                         |                   |                           |  |  |
| 0x40          | 64            | CH1 SLOT CONFIG        |                   | DSD_CH1_SOURCE             |                             |                        | TDM_CH1_SLOT_SEL        |                         |                   |                           |  |  |
| 0x41          | 65            | CH2 SLOT CONFIG        |                   | DSD_CH2_SOURCE             |                             |                        | TDM_CH2_SLOT_SEL        |                         |                   |                           |  |  |
| 0x42-0x49     | 66-73         | RESERVED               |                   |                            |                             | RESERVED               |                         |                         |                   |                           |  |  |
| 0x4A          | 74            | VOLUME CH1             |                   |                            |                             | VOLUME_CH1             |                         |                         |                   |                           |  |  |
| 0x4B          | 75            | VOLUME CH2             |                   |                            |                             | VOLUME_CH2             |                         |                         |                   |                           |  |  |
| 0x4C-0x51     | 76-81         | RESERVED               |                   |                            |                             | RESERVED               |                         |                         |                   |                           |  |  |
| 0x52          | 82            | DAC VOL UP RATE        |                   |                            | DAC_VOL_RATE_UP             |                        |                         |                         |                   |                           |  |  |
| 0x53          | 83            | DAC VOL DOWN RATE      |                   |                            | DAC_VOL_RATE_DOWN           |                        |                         |                         |                   |                           |  |  |
| 0x54          | 84            | DAC VOL DOWN RATE FAST |                   |                            | DAC_VOL_RATE_FAST           |                        |                         |                         |                   |                           |  |  |
| 0x55          | 85            | RESERVED               |                   |                            |                             | RESERVED               |                         |                         |                   |                           |  |  |
| 0x56          | 86            | DAC MUTE               |                   |                            | RESERVED                    |                        |                         | DAC_MUTE_CH2            | DAC_MUTE_CH1      |                           |  |  |

## ES9039Q2M Product Datasheet



|           |         |                            |                      |                  |                              |                       |                  |                       |  |
|-----------|---------|----------------------------|----------------------|------------------|------------------------------|-----------------------|------------------|-----------------------|--|
| 0x57      | 87      | DAC INVERT                 | RESERVED             |                  |                              |                       | DAC_INVERT_CH2   | DAC_INVERT_CH1        |  |
| 0x58      | 88      | FILTER SHAPE               | RESERVED             |                  |                              |                       | FILTER_SHAPE     |                       |  |
| 0x59      | 89      | IIR BANDWIDTH & S/PDIF SEL | SPDIF_SEL            |                  | VOLUME_HOLD                  | IIR_BW                |                  |                       |  |
| 0x5A      | 90      | DAC PATH CONFIG            | RESERVED             |                  |                              |                       | BYPASS_IIR       | BYPASS_FIR4X          |  |
| 0x5B      | 91      | THD C2                     | THD_C2_CH1           |                  |                              |                       | BYPASS_FIR2X     |                       |  |
| 0x5C      | 92      |                            | THD_C2_CH1           |                  |                              |                       |                  |                       |  |
| 0x5D      | 93      |                            | THD_C2_CH2           |                  |                              |                       |                  |                       |  |
| 0x5E      | 94      |                            | THD_C2_CH2           |                  |                              |                       |                  |                       |  |
| 0x5F-0x6A | 95-106  | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0x6B      | 107     | THD C3                     | THD_C3_CH1           |                  |                              |                       |                  |                       |  |
| 0x6C      | 108     |                            | THD_C3_CH1           |                  |                              |                       |                  |                       |  |
| 0x6D      | 109     |                            | THD_C3_CH2           |                  |                              |                       |                  |                       |  |
| 0x6E      | 110     |                            | THD_C3_CH2           |                  |                              |                       |                  |                       |  |
| 0x6F-0x7A | 111-122 | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0x7B      | 123     | AUTOMUTE ENABLE            | RESERVED             |                  |                              |                       | AUTOMUTE_EN_CH2  | AUTOMUTE_EN_CH1       |  |
| 0x7C      | 124     | AUTOMUTE TIME              | AUTOMUTE_TIME        |                  |                              |                       |                  |                       |  |
| 0x7D      | 125     |                            | EXTERNAL_DEM_IE      | EXTERNAL_DEM     | RESERVED                     | MUTE_RAMP_TO_GROUND   | AUTOMUTE_TIME    |                       |  |
| 0x7E      | 126     |                            | AUTOMUTE_LEVEL       |                  |                              |                       |                  |                       |  |
| 0x7F      | 127     | AUTOMUTE OFF LEVEL         | AUTOMUTE_LEVEL       |                  |                              |                       |                  |                       |  |
| 0x80      | 128     |                            | AUTOMUTE_OFF_LEVEL   |                  |                              |                       |                  |                       |  |
| 0x81      | 129     |                            | AUTOMUTE_OFF_LEVEL   |                  |                              |                       |                  |                       |  |
| 0x82      | 130     | SOFT RAMP CONFIG           | RESERVED             |                  | SOFT_RAMP_TIME               |                       |                  |                       |  |
| 0x83-0x86 | 131-134 | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0x87      | 135     | PROGRAM RAM CONTROL        | SPDIF_LOAD_USER_BITS | RESERVED         |                              |                       |                  | PROG_COEFF_WE         |  |
| 0x88      | 136     | S/PDIF READ CONTROL        | RESERVED             |                  | SPDIF_DATA_SEL               |                       |                  |                       |  |
| 0x89      | 137     | PROGRAM RAM ADDRESS        | PROG_COEFF_STAGE     | PROG_COEFF_ADDR  |                              |                       |                  |                       |  |
| 0x8A      | 138     | PROGRAM RAM DATA           | PROG_COEFF_IN        |                  |                              |                       |                  |                       |  |
| 0x8B      | 139     |                            | PROG_COEFF_IN        |                  |                              |                       |                  |                       |  |
| 0x8C      | 140     |                            | PROG_COEFF_IN        |                  |                              |                       |                  |                       |  |
| 0x8D-0x91 | 141-145 | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0xE0      | 224     | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0xE1      | 225     | CHIP ID READ               | CHIP_ID              |                  |                              |                       |                  |                       |  |
| 0xE2-0xE4 | 226     | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0xE5      | 229     | INTERRUPT STATES           | BCK_WS_FAIL_STATE    | DOP_VALID_STATE  | SS_FULL_RAMP_STATE           | AUTOMUTE_STATE        |                  | VOL_MIN_STATE         |  |
| 0xE6      | 230     |                            | RESERVED             |                  | INPUT_SELECT_OVERRIDE_STATE  | TDM_DATA_VALID_STATE  | RESERVED         |                       |  |
| 0xE7-0xE9 | 231-233 | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0xEA      | 234     | INTERRUPT SOURCES          | BCK_WS_FAIL_SOURCE   | DOP_VALID_SOURCE | SS_FULL_RAMP_SOURCE          | AUTOMUTE_SOURCE       |                  | VOL_MIN_SOURCE        |  |
| 0xEB      | 235     |                            | RESERVED             |                  | INPUT_SELECT_OVERRIDE_SOURCE | TDM_DATA_VALID_SOURCE | RESERVED         |                       |  |
| 0xEC-0xEF | 236-239 | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0xF0      | 240     | GPIO READBACK              | GPIO8_I_READ         | GPIO7_I_READ     | GPIO6_I_READ                 | GPIO5_I_READ          | GPIO4_I_READ     | GPIO2_I_READ          |  |
| 0xF1      | 241     | VOL MIN READ               | RESERVED             |                  |                              |                       | VOL_MIN_CH2      | VOL_MIN_CH1           |  |
| 0xF2      | 242     | AUTOMUTE READ              | RESERVED             |                  |                              |                       | AUTOMUTE_CH2     | AUTOMUTE_CH1          |  |
| 0xF3      | 243     | SOFT RAMP UP READ          | RESERVED             |                  |                              |                       | SS_RAMP_UP_CH2   | SS_RAMP_UP_CH1        |  |
| 0xF4      | 244     | SOFT RAMP DOWN READ        | RESERVED             |                  |                              |                       | SS_RAMP_DOWN_CH2 | SS_RAMP_DOWN_CH1      |  |
| 0xF5      | 245     | INPUT STREAM READBACK      | RESERVED             |                  | SPDIF_VALID                  | TDM_DATA_VALID        | DOP_VALID        | INPUT_SELECT_OVERRIDE |  |
| 0xF6      | 246     | PROG COEFF OUT READ        | PROG_COEFF_OUT       |                  |                              |                       |                  |                       |  |
| 0xF7      | 247     |                            | PROG_COEFF_OUT       |                  |                              |                       |                  |                       |  |
| 0xF8      | 248     |                            | PROG_COEFF_OUT       |                  |                              |                       |                  |                       |  |
| 0xF9-0xFA | 249-250 | RESERVED                   | RESERVED             |                  |                              |                       |                  |                       |  |
| 0xFB      | 251     | S/PDIF DATA READ           | SPDIF_DATA_READ      |                  |                              |                       |                  |                       |  |

Table 32 - Register Map

## Register Listing

### System Registers

#### Register 0: SYSTEM CONFIG

| Bits    | [7]  | [6]  | [5:2] | [1]  | [0]  |
|---------|------|------|-------|------|------|
| Default | 1'b0 | 1'b0 | 4'd0  | 1'b0 | 1'b0 |

| Bits  | Mnemonic         | Description                                                                                                                                                                                                                                                                                                                    |
|-------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | SOFT_RESET       | <p>Performs soft reset to digital core.</p> <ul style="list-style-type: none"> <li>• 1'b0: Normal operation</li> <li>• 1'b1: Reset digital core (all settings are set to default)</li> </ul>                                                                                                                                   |
| [6]   | ENABLE_64FS_MODE | <p>Enables 64FS mode to run the DAC interpolation path at 64FS.</p> <ul style="list-style-type: none"> <li>• 1'b0: 64FS mode disabled (default)</li> <li>• 1'b1: 64FS mode enabled</li> </ul> <p>Note: This mode is used only for PCM high sample rates such as<br/>768kHz with a 49.152MHz or 384kHz with 24.576MHz clock</p> |
| [5:2] | RESERVED         | N/A                                                                                                                                                                                                                                                                                                                            |
| [1]   | DAC_MODE         | <p>Enables the analog section of the DAC.</p> <ul style="list-style-type: none"> <li>• 1'b0: DAC disabled (default)</li> <li>• 1'b1: DAC enabled</li> </ul>                                                                                                                                                                    |
| [0]   | RESERVED         | N/A                                                                                                                                                                                                                                                                                                                            |

## Register 1: SYS MODE CONFIG

| Bits    | [7]  | [6]  | [5:4] | [3]  | [2]  | [1]  | [0]  |
|---------|------|------|-------|------|------|------|------|
| Default | 1'b1 | 1'b0 | 2'b11 | 1'b0 | 1'b0 | 1'b0 | 1'b1 |

| Bits  | Mnemonic            | Description                                                                                                                                                |
|-------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | ENABLE_DAC_CLK      | Enables DAC interpolation path clock.<br><ul style="list-style-type: none"> <li>• 1'b0: Clock disabled</li> <li>• 1'b1: Clock enabled (default)</li> </ul> |
| [6]   | SYNC_MODE           | Enables SYNC mode.<br><ul style="list-style-type: none"> <li>• 1'b0: ASYNC mode enabled (default)</li> <li>• 1'b1: SYNC mode enabled</li> </ul>            |
| [5:4] | RESERVED            | N/A                                                                                                                                                        |
| [3]   | ENABLE_SPDIF_DECODE | Enables S/PDIF decoding.<br><ul style="list-style-type: none"> <li>• 1'b0: Disabled (default)</li> <li>• 1'b1: Enabled</li> </ul>                          |
| [2]   | ENABLE_DOP_DECODE   | Enables DoP decoding.<br><ul style="list-style-type: none"> <li>• 1'b0: Disabled (default)</li> <li>• 1'b1: Enabled</li> </ul>                             |
| [1]   | ENABLE_DSD_DECODE   | Enables DSD decoding.<br><ul style="list-style-type: none"> <li>• 1'b0: Disabled (default)</li> <li>• 1'b1: Enabled</li> </ul>                             |
| [0]   | ENABLE_TDM_DECODE   | Enables TDM decoding.<br><ul style="list-style-type: none"> <li>• 1'b0: Disabled</li> <li>• 1'b1: Enabled (default)</li> </ul>                             |

**Register 2: RESERVED****Register 3: DAC CLOCK CONFIG**

| Bits    | [7]  | [6]  | [5:0] |
|---------|------|------|-------|
| Default | 1'b1 | 1'b0 | 6'd0  |

| Bits  | Mnemonic         | Description                                                                                                                                                                                                                                                                                                       |
|-------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | AUTO_FS_DETECT   | Automatically determine optimal (SYS_CLK/CLK_IDAC ratio) according to detected FS. <ul style="list-style-type: none"><li>• 1'b0: Disabled, use reg 3[5:0] SELECT_IDAC_NUM to set ratio.</li><li>• 1'b1: Enabled, overrides reg 3[5:0] SELECT_IDAC_NUM (default)<br/>Note: Cannot be used in ASYNC mode.</li></ul> |
| [6]   | SELECT_IDAC_HALF | <ul style="list-style-type: none"><li>• 1'b0: Divide by SELECT_IDAC_NUM + 1 (default)</li><li>• 1'b1: Divide by half of SELECT_IDAC_NUM + 1<br/>Note: Can only produce half of an odd number divide</li></ul>                                                                                                     |
| [5:0] | SELECT_IDAC_NUM  | CLK_IDAC divider. Whole number divide value + 1 for CLK_IDAC (SYS_CLK/divide_value). <ul style="list-style-type: none"><li>• 6'd0: Whole number divide value + 1 = 1</li><li>• 6'd1: Whole number divide value + 1 = 2</li><li>• 6'd63: Whole number divide value + 1 = 64</li></ul>                              |

**Register 4: CLOCK CONFIG**

| Bits    | [7:0] |
|---------|-------|
| Default | 8'd7  |

| Bits  | Mnemonic       | Description                                                                                     |
|-------|----------------|-------------------------------------------------------------------------------------------------|
| [7:0] | MASTER_BCK_DIV | Master mode clock divider. Whole number divide value + 1 for CLK_Master (SYS_CLK/divide_value). |

## Register 5: CLK GEAR SELECT

| Bits    | [7:6] | [5:4] | [3]  | [2]  | [1]  | [0]  |
|---------|-------|-------|------|------|------|------|
| Default | 2'b00 | 2'd0  | 1'b0 | 1'b0 | 1'b0 | 1'b0 |

| Bits  | Mnemonic                  | Description                                                                                                                                                                                                                                                                                                                                                                    |
|-------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6] | RESERVED                  | N/A                                                                                                                                                                                                                                                                                                                                                                            |
| [5:4] | SEL_CLK_GEAR              | MCLK clock gearing, outputs SYS_CLK to the rest of the device. <ul style="list-style-type: none"> <li>• 2'd0: SYS_CLK = MCLK/1</li> <li>• 2'd1: SYS_CLK = MCLK/2</li> <li>• 2'd2: SYS_CLK = MCLK/4</li> <li>• 2'd3: SYS_CLK = MCLK/8</li> </ul>                                                                                                                                |
| [3]   | RESERVED                  | N/A                                                                                                                                                                                                                                                                                                                                                                            |
| [2]   | AUTO_CLK_GEAR             | Enable automatic clock gearing.<br>In automatic clock gearing, MCLK will be geared down until $128FS \leq SYS\_CLK < 256FS$ . <ul style="list-style-type: none"> <li>• 1'b0: Disabled, SYS_CLK = SEL_CLK_GEAR (default)</li> <li>• 1'b1: Enabled, SYS_CLK will decrease by up to SEL_CLK_GEAR</li> <li>• 1'b1: Enabled, SYS_CLK will decrease by up to SEL_CLK_GEAR</li> </ul> |
| [1]   | RESERVED                  | N/A                                                                                                                                                                                                                                                                                                                                                                            |
| [0]   | AUTO_FS_DETECT_BLOCK_64FS | Block AUTO_FS_DETECT from transitioning to 64FS mode when the detected SYS_CLK/CLK_IDAC ratio is 64. <ul style="list-style-type: none"> <li>• 1'b0: Disabled (default)</li> <li>• 1'b1: Enabled</li> </ul>                                                                                                                                                                     |

**Register 9-6: RESERVED****Register 11-10: INTERRUPT MASKP**

| Bits    | [15:14] | [13:12] | [11] | [10:8] | [7]  | [6]  | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|---------|---------|------|--------|------|------|------|------|------|------|------|------|
| Default | 2'b00   | 2'b00   | 1'b0 | 3'b000 | 1'b0 |

## ES9039Q2M Product Datasheet



| Bits    | Mnemonic                    | Description                                                                                                                                                                                                              |
|---------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:14] | RESERVED                    | N/A                                                                                                                                                                                                                      |
| [13:12] | INPUT_SELECT_OVERRIDE_MASKP | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>2'b00: Ignore interrupt (default)</li> <li>2'b11: Service interrupt if flag transitions from negative to positive</li> </ul> |
| [11]    | TDM_VALID_EDGE_MASKP        | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |
| [10:8]  | RESERVED                    | N/A                                                                                                                                                                                                                      |
| [7]     | BCK_WS_FAIL_MASKP           | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |
| [6]     | DOP_VALID_MASKP             | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |
| [5]     | SS_FULL_RAMP_CH2_MASKP      | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |
| [4]     | SS_FULL_RAMP_CH1_MASKP      | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |
| [3]     | AUTOMUTE_FLAG_CH2_MASKP     | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |
| [2]     | AUTOMUTE_FLAG_CH1_MASKP     | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |
| [1]     | VOL_MIN_CH2_MASKP           | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |
| [0]     | VOL_MIN_CH1_MASKP           | Masks negative to positive interrupt transitions.<br><ul style="list-style-type: none"> <li>1'b0: Ignore interrupt (default)</li> <li>1'b1: Service interrupt if flag transitions from negative to positive</li> </ul>   |

**Register 14-12: RESERVED****Register 16-15: INTERRUPT MASKN**

| Bits    | [15:14] | [13:12] | [11] | [10:8] | [7]  | [6]  | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|---------|---------|------|--------|------|------|------|------|------|------|------|------|
| Default | 2'b00   | 2'b00   | 1'b0 | 3'b000 | 1'b0 |

## ES9039Q2M Product Datasheet



| Bits    | Mnemonic                    | Description                                                                                                                                                                                                                  |
|---------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:14] | RESERVED                    | N/A                                                                                                                                                                                                                          |
| [13:12] | INPUT_SELECT_OVERRIDE_MASKN | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 2'b00: Ignore interrupt (default)</li> <li>• 2'b11: Service interrupt if flag transitions from positive to negative</li> </ul> |
| [11]    | TDM_VALID_EDGE_MASKN        | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if flag transitions from positive to negative</li> </ul>   |
| [10:8]  | RESERVED                    | N/A                                                                                                                                                                                                                          |
| [7]     | BCK_WS_FAIL_MASKN           | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if flag transitions from positive to negative</li> </ul>   |
| [6]     | DOP_VALID_MASKN             | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if toggled from positive to negative</li> </ul>            |
| [5]     | SS_FULL_RAMP_CH2_MASKN      | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if flag transitions from positive to negative</li> </ul>   |
| [4]     | SS_FULL_RAMP_CH1_MASKN      | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if flag transitions from positive to negative</li> </ul>   |
| [3]     | AUTOMUTE_FLAG_CH2_MASKN     | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if flag transitions from positive to negative</li> </ul>   |
| [2]     | AUTOMUTE_FLAG_CH1_MASKN     | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if flag transitions from positive to negative</li> </ul>   |
| [1]     | VOL_MIN_CH2_MASKN           | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if flag transitions from positive to negative</li> </ul>   |
| [0]     | VOL_MIN_CH1_MASKN           | Masks positive to negative interrupt transitions.<br><ul style="list-style-type: none"> <li>• 1'b0: Ignore interrupt (default)</li> <li>• 1'b1: Service interrupt if flag transitions from positive to negative</li> </ul>   |



## Register 19-17: RESERVED

## Register 21-20: INTERRUPT CLEAR

| Bits    | [15:14] | [13:12] | [11] | [10:8] | [7]  | [6]  | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|---------|---------|------|--------|------|------|------|------|------|------|------|------|
| Default | 2'b00   | 2'b00   | 1'b0 | 3'b000 | 1'b0 |

| Bits    | Mnemonic                    | Description                                    |
|---------|-----------------------------|------------------------------------------------|
| [15:14] | RESERVED                    | N/A                                            |
| [13:12] | INPUT_SELECT_OVERRIDE_CLEAR | Toggle high-low to clear and re-arm interrupt. |
| [11]    | TDM_VALID_EDGE_CLEAR        | Toggle high-low to clear and re-arm interrupt. |
| [10:8]  | RESERVED                    | N/A                                            |
| [7]     | BCK_WS_FAIL_CLEAR           | Toggle high-low to clear and re-arm interrupt. |
| [6]     | DOP_VALID_CLEAR             | Toggle high-low to clear and re-arm interrupt. |
| [5]     | SS_FULL_RAMP_CH2_CLEAR      | Toggle high-low to clear and re-arm interrupt. |
| [4]     | SS_FULL_RAMP_CH1_CLEAR      | Toggle high-low to clear and re-arm interrupt. |
| [3]     | AUTOMUTE_FLAG_CH2_CLEAR     | Toggle high-low to clear and re-arm interrupt. |
| [2]     | AUTOMUTE_FLAG_CH1_CLEAR     | Toggle high-low to clear and re-arm interrupt. |
| [1]     | VOL_MIN_CH2_CLEAR           | Toggle high-low to clear and re-arm interrupt. |
| [0]     | VOL_MIN_CH1_CLEAR           | Toggle high-low to clear and re-arm interrupt. |

## Register 28-22: RESERVED

## Register 29: DPLL BW

| Bits    | [7:4] | [3:0] |
|---------|-------|-------|
| Default | 4'd4  | 4'd0  |

| Bits  | Mnemonic | Description                                                                                             |
|-------|----------|---------------------------------------------------------------------------------------------------------|
| [7:4] | DPLL_BW  | Sets the bandwidth of the DPLL.<br>4'd0: Reserved<br>4'd1: Lowest Bandwidth<br>4'd15: Highest Bandwidth |
| [3:0] | RESERVED | N/A                                                                                                     |

## ES9039Q2M Product Datasheet

### Register 33-30: RESERVED

### Register 34: DATA PATH CONFIG

| Bits    | [7]  | [6]  | [5:0]     |
|---------|------|------|-----------|
| Default | 1'b0 | 1'b0 | 6'b000000 |

| Bits  | Mnemonic    | Description                                                                                                                                                                                                             |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | MONO_MODE   | Enables MONO Mode<br>Note: Does not turn off unused data path for power saving                                                                                                                                          |
| [6]   | CAL_RES_ENB | Selects the calibration resistor connection on GPIO8. <ul style="list-style-type: none"><li>• 1'b0: DAC calibration resistor enabled (default)</li><li>• 1'b1: DAC calibration resistor disabled, normal GPIO</li></ul> |
| [5:0] | RESERVED    | N/A                                                                                                                                                                                                                     |

### Register 35: PCM 4X GAIN

| Bits    | [7:2] | [1]  | [0]  |
|---------|-------|------|------|
| Default | 6'd0  | 1'b0 | 1'b0 |

| Bits  | Mnemonic        | Description                                                                                                                                                                            |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:2] | RESERVED        | N/A                                                                                                                                                                                    |
| [1]   | CH2_PCM_4X_GAIN | Changes the gain on the CH2 interpolation path after the IIR. <ul style="list-style-type: none"><li>• 1'b0: 1x gain</li><li>• 1'b1: 4x gain</li></ul> Note: Not available in DSD mode. |
| [0]   | CH1_PCM_4X_GAIN | Changes the gain on the CH1 interpolation path after the IIR. <ul style="list-style-type: none"><li>• 1'b0: 1x gain</li><li>• 1'b1: 4x gain</li></ul> Note: Not available in DSD mode. |

### Register 36: RESERVED



## GPIO Registers

### Register 37: GPIO1/2 CONFIG

|                |              |              |
|----------------|--------------|--------------|
| <b>Bits</b>    | <b>[7:4]</b> | <b>[3:0]</b> |
| <b>Default</b> | 4'd7         | 4'd13        |

| <b>Bits</b>  | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>[7:4]</b> | GPIO2_CFG       | <p>Configures GPIO2</p> <ul style="list-style-type: none"> <li>• 4'd0: Analog shutdown - shutdown</li> <li>• 4'd1: Output 0 – output</li> <li>• 4'd2: Output 1 – output</li> <li>• 4'd3: CLK_BCK – output</li> <li>• 4'd4: Interrupt – output</li> <li>• 4'd5: Mute all channels – input</li> <li>• 4'd6: System mode control – input</li> <li>• 4'd7: Lock status – output (default)</li> <li>• 4'd8: External DEM – output</li> <li>• 4'd9: PWM1 signal – output</li> <li>• 4'd10: PWM2 signal – output</li> <li>• 4'd11: PWM3 signal – output</li> <li>• 4'd12: Minimum volume – output</li> <li>• 4'd13: Automute status – output</li> <li>• 4'd14: Soft ramp done – output</li> <li>• 4'd15: Reserved</li> </ul>   |
| <b>[3:0]</b> | GPIO1_CFG       | <p>Configures GPIO1</p> <ul style="list-style-type: none"> <li>• 4'd0: Analog shutdown - shutdown</li> <li>• 4'd1: Output 0 – output</li> <li>• 4'd2: Output 1 – output</li> <li>• 4'd3: CLKEN_1FS – output</li> <li>• 4'd4: Interrupt – output</li> <li>• 4'd5: Mute all channels – input</li> <li>• 4'd6: System mode control – input</li> <li>• 4'd7: Lock status – output</li> <li>• 4'd8: External DEM – output</li> <li>• 4'd9: PWM1 signal – output</li> <li>• 4'd10: PWM2 signal – output</li> <li>• 4'd11: PWM3 signal – output</li> <li>• 4'd12: Minimum volume – output</li> <li>• 4'd13: Automute status – output (default)</li> <li>• 4'd14: Soft ramp done – output</li> <li>• 4'd15: Reserved</li> </ul> |

## ES9039Q2M Product Datasheet

### Register 38: GPIO3/4 CONFIG

| Bits    | [7:4] | [3:0] |
|---------|-------|-------|
| Default | 4'd0  | 4'd0  |

| Bits  | Mnemonic  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:4] | GPIO4_CFG | <p>Configures GPIO4</p> <ul style="list-style-type: none"> <li>• 4'd0: Analog shutdown - shutdown (default)</li> <li>• 4'd1: Output 0 – output</li> <li>• 4'd2: Output 1 – output</li> <li>• 4'd3: CLK_IDAC – output</li> <li>• 4'd4: Interrupt – output</li> <li>• 4'd5: Mute all channels – input</li> <li>• 4'd6: System mode control – input</li> <li>• 4'd7: Lock status – output</li> <li>• 4'd8: External DEM – output</li> <li>• 4'd9: PWM1 signal – output</li> <li>• 4'd10: PWM2 signal – output</li> <li>• 4'd11: PWM3 signal – output</li> <li>• 4'd12: Minimum volume – output</li> <li>• 4'd13: Automute status – output</li> <li>• 4'd14: Soft ramp done – output</li> <li>• 4'd15: Reserved</li> </ul> |
| [3:0] | GPIO3_CFG | <p>Configures GPIO3</p> <ul style="list-style-type: none"> <li>• 4'd0: Analog shutdown - shutdown (default)</li> <li>• 4'd1: Output 0 – output</li> <li>• 4'd2: Output 1 – output</li> <li>• 4'd3: SYS_CLK – output</li> <li>• 4'd4: Interrupt – output</li> <li>• 4'd5: Mute all channels – input</li> <li>• 4'd6: System mode control – input</li> <li>• 4'd7: Lock status – output</li> <li>• 4'd8: External DEM – output</li> <li>• 4'd9: PWM1 signal – output</li> <li>• 4'd10: PWM2 signal – output</li> <li>• 4'd11: PWM3 signal – output</li> <li>• 4'd12: Minimum volume – output</li> <li>• 4'd13: Automute status – output</li> <li>• 4'd14: Soft ramp done – output</li> <li>• 4'd15: Reserved</li> </ul>  |



## Register 39: GPIO5/6 CONFIG

| Bits    | [7:4] | [3:0] |
|---------|-------|-------|
| Default | 4'd0  | 4'd0  |

| Bits  | Mnemonic  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:4] | GPIO6_CFG | <p>Configures GPIO6</p> <ul style="list-style-type: none"> <li>• 4'd0: Analog shutdown - shutdown (default)</li> <li>• 4'd1: Output 0 – output</li> <li>• 4'd2: Output 1 – output</li> <li>• 4'd3: CLK_BCK – output</li> <li>• 4'd4: Interrupt – output</li> <li>• 4'd5: Mute all channels – input</li> <li>• 4'd6: System mode control – input</li> <li>• 4'd7: Lock status – output</li> <li>• 4'd8: External DEM – output</li> <li>• 4'd9: PWM1 signal – output</li> <li>• 4'd10: PWM2 signal – output</li> <li>• 4'd11: PWM3 signal – output</li> <li>• 4'd12: Minimum volume – output</li> <li>• 4'd13: Automute status – output</li> <li>• 4'd14: Soft ramp done – output</li> <li>• 4'd15: Reserved</li> </ul>   |
| [3:0] | GPIO5_CFG | <p>Configures GPIO5</p> <ul style="list-style-type: none"> <li>• 4'd0: Analog shutdown - shutdown (default)</li> <li>• 4'd1: Output 0 – output</li> <li>• 4'd2: Output 1 – output</li> <li>• 4'd3: CLKEN_1FS – output</li> <li>• 4'd4: Interrupt – output</li> <li>• 4'd5: Mute all channels – input</li> <li>• 4'd6: System mode control – input</li> <li>• 4'd7: Lock status – output</li> <li>• 4'd8: External DEM – output</li> <li>• 4'd9: PWM1 signal – output</li> <li>• 4'd10: PWM2 signal – output</li> <li>• 4'd11: PWM3 signal – output</li> <li>• 4'd12: Minimum volume – output</li> <li>• 4'd13: Automute status – output</li> <li>• 4'd14: Soft ramp done – output</li> <li>• 4'd15: Reserved</li> </ul> |

## ES9039Q2M Product Datasheet

### Register 40: GPIO7/8 CONFIG

| Bits    | [7:4] | [3:0] |
|---------|-------|-------|
| Default | 4'd0  | 4'd0  |

| Bits  | Mnemonic  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:4] | GPIO8_CFG | <p>Configures GPIO8</p> <ul style="list-style-type: none"> <li>• 4'd0: Analog shutdown - shutdown (default)</li> <li>• 4'd1: Output 0 – output</li> <li>• 4'd2: Output 1 – output</li> <li>• 4'd3: CLK_IDAC – output</li> <li>• 4'd4: Interrupt – output</li> <li>• 4'd5: Mute all channels – input</li> <li>• 4'd6: System mode control – input</li> <li>• 4'd7: Lock status – output</li> <li>• 4'd8: Reserverd</li> <li>• 4'd9: PWM1 signal – output</li> <li>• 4'd10: PWM2 signal – output</li> <li>• 4'd11: PWM3 signal – output</li> <li>• 4'd12: Minimum volume – output</li> <li>• 4'd13: Automute status – output</li> <li>• 4'd14: Soft ramp done – output</li> <li>• 4'd15: Reserved</li> </ul> |
| [3:0] | GPIO7_CFG | <p>Configures GPIO7</p> <ul style="list-style-type: none"> <li>• 4'd0: Analog shutdown - shutdown (default)</li> <li>• 4'd1: Output 0 – output</li> <li>• 4'd2: Output 1 – output</li> <li>• 4'd3: SYS_CLK – output</li> <li>• 4'd4: Interrupt – output</li> <li>• 4'd5: Mute all channels – input</li> <li>• 4'd6: System mode control – input</li> <li>• 4'd7: Lock status – output</li> <li>• 4'd8: Reserverd</li> <li>• 4'd9: PWM1 signal – output</li> <li>• 4'd10: PWM2 signal – output</li> <li>• 4'd11: PWM3 signal – output</li> <li>• 4'd12: Minimum volume – output</li> <li>• 4'd13: Automute status – output</li> <li>• 4'd14: Soft ramp done – output</li> <li>• 4'd15: Reserved</li> </ul>  |



## Register 41: GPIO OUTPUT ENABLE

| Bits    | [7]  | [6]  | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|------|------|------|------|------|------|------|------|
| Default | 1'b0 | 1'b0 | 1'b0 | 1'b0 | 1'b0 | 1'b0 | 1'b1 | 1'b1 |

| Bits | Mnemonic | Description                                                                                                              |
|------|----------|--------------------------------------------------------------------------------------------------------------------------|
| [7]  | GPIO8_OE | <ul style="list-style-type: none"> <li>• 1'b0: Tristate GPIO8 (default)</li> <li>• 1'b1: GPIO8 Output enabled</li> </ul> |
| [6]  | GPIO7_OE | <ul style="list-style-type: none"> <li>• 1'b0: Tristate GPIO7 (default)</li> <li>• 1'b1: GPIO7 Output enabled</li> </ul> |
| [5]  | GPIO6_OE | <ul style="list-style-type: none"> <li>• 1'b0: Tristate GPIO6 (default)</li> <li>• 1'b1: GPIO6 Output enabled</li> </ul> |
| [4]  | GPIO5_OE | <ul style="list-style-type: none"> <li>• 1'b0: Tristate GPIO5 (default)</li> <li>• 1'b1: GPIO5 Output enabled</li> </ul> |
| [3]  | GPIO4_OE | <ul style="list-style-type: none"> <li>• 1'b0: Tristate GPIO4 (default)</li> <li>• 1'b1: GPIO4 Output enabled</li> </ul> |
| [2]  | GPIO3_OE | <ul style="list-style-type: none"> <li>• 1'b0: Tristate GPIO3 (default)</li> <li>• 1'b1: GPIO3 Output enabled</li> </ul> |
| [1]  | GPIO2_OE | <ul style="list-style-type: none"> <li>• 1'b0: Tristate GPIO2</li> <li>• 1'b1: GPIO2 Output enabled (default)</li> </ul> |
| [0]  | GPIO1_OE | <ul style="list-style-type: none"> <li>• 1'b0: Tristate GPIO1</li> <li>• 1'b1: GPIO1 Output enabled (default)</li> </ul> |

## ES9039Q2M Product Datasheet

### Register 42: GPIO INPUT

| Bits    | [7]  | [6]  | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|------|------|------|------|------|------|------|------|
| Default | 1'b0 |

| Bits | Mnemonic  | Description                                                                                                                   |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------|
| [7]  | GPIO8_SDB | <ul style="list-style-type: none"> <li>• 1'b0: Disables GPIO8 input (default)</li> <li>• 1'b1: Enables GPIO8 input</li> </ul> |
| [6]  | GPIO7_SDB | <ul style="list-style-type: none"> <li>• 1'b0: Disables GPIO7 input (default)</li> <li>• 1'b1: Enables GPIO7 input</li> </ul> |
| [5]  | GPIO6_SDB | <ul style="list-style-type: none"> <li>• 1'b0: Disables GPIO6 input (default)</li> <li>• 1'b1: Enables GPIO6 input</li> </ul> |
| [4]  | GPIO5_SDB | <ul style="list-style-type: none"> <li>• 1'b0: Disables GPIO5 input (default)</li> <li>• 1'b1: Enables GPIO5 input</li> </ul> |
| [3]  | GPIO4_SDB | <ul style="list-style-type: none"> <li>• 1'b0: Disables GPIO4 input (default)</li> <li>• 1'b1: Enables GPIO4 input</li> </ul> |
| [2]  | GPIO3_SDB | <ul style="list-style-type: none"> <li>• 1'b0: Disables GPIO3 input (default)</li> <li>• 1'b1: Enables GPIO3 input</li> </ul> |
| [1]  | GPIO2_SDB | <ul style="list-style-type: none"> <li>• 1'b0: Disables GPIO2 input (default)</li> <li>• 1'b1: Enables GPIO2 input</li> </ul> |
| [0]  | GPIO1_SDB | <ul style="list-style-type: none"> <li>• 1'b0: Disables GPIO1 input (default)</li> <li>• 1'b1: Enables GPIO1 input</li> </ul> |

### Register 43: GPIO WK EN

| Bits    | [7]  | [6]  | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|------|------|------|------|------|------|------|------|
| Default | 1'b0 |

| Bits | Mnemonic    | Description                                                                                                                               |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| [7]  | GPIO8_WK_EN | <ul style="list-style-type: none"> <li>• 1'b0: GPIO8 weak keeper disabled (default)</li> <li>• 1'b1: GPIO8 weak keeper enabled</li> </ul> |
| [6]  | GPIO7_WK_EN | <ul style="list-style-type: none"> <li>• 1'b0: GPIO7 weak keeper disabled (default)</li> <li>• 1'b1: GPIO7 weak keeper enabled</li> </ul> |
| [5]  | GPIO6_WK_EN | <ul style="list-style-type: none"> <li>• 1'b0: GPIO6 weak keeper disabled (default)</li> <li>• 1'b1: GPIO6 weak keeper enabled</li> </ul> |
| [4]  | GPIO5_WK_EN | <ul style="list-style-type: none"> <li>• 1'b0: GPIO5 weak keeper disabled (default)</li> <li>• 1'b1: GPIO5 weak keeper enabled</li> </ul> |
| [3]  | GPIO4_WK_EN | <ul style="list-style-type: none"> <li>• 1'b0: GPIO4 weak keeper disabled (default)</li> <li>• 1'b1: GPIO4 weak keeper enabled</li> </ul> |
| [2]  | GPIO3_WK_EN | <ul style="list-style-type: none"> <li>• 1'b0: GPIO3 weak keeper disabled (default)</li> <li>• 1'b1: GPIO3 weak keeper enabled</li> </ul> |
| [1]  | GPIO2_WK_EN | <ul style="list-style-type: none"> <li>• 1'b0: GPIO2 weak keeper disabled (default)</li> <li>• 1'b1: GPIO2 weak keeper enabled</li> </ul> |
| [0]  | GPIO1_WK_EN | <ul style="list-style-type: none"> <li>• 1'b0: GPIO1 weak keeper disabled (default)</li> <li>• 1'b1: GPIO1 weak keeper enabled</li> </ul> |



## Register 44: INVERT GPIO

| Bits    | [7]  | [6]  | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|------|------|------|------|------|------|------|------|
| Default | 1'b0 |

| Bits | Mnemonic     | Description                                                                     |
|------|--------------|---------------------------------------------------------------------------------|
| [7]  | INVERT_GPIO8 | <ul style="list-style-type: none"> <li>• 1'b1: Inverts GPIO8 output.</li> </ul> |
| [6]  | INVERT_GPIO7 | <ul style="list-style-type: none"> <li>• 1'b1: Inverts GPIO7 output.</li> </ul> |
| [5]  | INVERT_GPIO6 | <ul style="list-style-type: none"> <li>• 1'b1: Inverts GPIO6 output.</li> </ul> |
| [4]  | INVERT_GPIO5 | <ul style="list-style-type: none"> <li>• 1'b1: Inverts GPIO5 output.</li> </ul> |
| [3]  | INVERT_GPIO4 | <ul style="list-style-type: none"> <li>• 1'b1: Inverts GPIO4 output.</li> </ul> |
| [2]  | INVERT_GPIO3 | <ul style="list-style-type: none"> <li>• 1'b1: Inverts GPIO3 output.</li> </ul> |
| [1]  | INVERT_GPIO2 | <ul style="list-style-type: none"> <li>• 1'b1: Inverts GPIO2 output.</li> </ul> |
| [0]  | INVERT_GPIO1 | <ul style="list-style-type: none"> <li>• 1'b1: Inverts GPIO1 output.</li> </ul> |

## Register 45: GPIO READ

| Bits    | [7]  | [6]  | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|------|------|------|------|------|------|------|------|
| Default | 1'b0 |

| Bits | Mnemonic   | Description                                                                                                                                                                                     |
|------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]  | GPIO8_READ | <ul style="list-style-type: none"> <li>• 1'b0: GPIO8 Readback disabled (default)</li> <li>• 1'b1: Allow readback of GPIO8_I</li> </ul> <p>Note: Requires corresponding GPIOx_SDB to be set.</p> |
| [6]  | GPIO7_READ | <ul style="list-style-type: none"> <li>• 1'b0: GPIO7 Readback disabled (default)</li> <li>• 1'b1: Allow readback of GPIO7_I</li> </ul> <p>Note: Requires corresponding GPIOx_SDB to be set.</p> |
| [5]  | GPIO6_READ | <ul style="list-style-type: none"> <li>• 1'b0: GPIO6 Readback disabled (default)</li> <li>• 1'b1: Allow readback of GPIO6_I</li> </ul> <p>Note: Requires corresponding GPIOx_SDB to be set.</p> |
| [4]  | GPIO5_READ | <ul style="list-style-type: none"> <li>• 1'b0: GPIO5 Readback disabled (default)</li> <li>• 1'b1: Allow readback of GPIO5_I</li> </ul> <p>Note: Requires corresponding GPIOx_SDB to be set.</p> |
| [3]  | GPIO4_READ | <ul style="list-style-type: none"> <li>• 1'b0: GPIO4 Readback disabled (default)</li> <li>• 1'b1: Allow readback of GPIO4_I</li> </ul> <p>Note: Requires corresponding GPIOx_SDB to be set.</p> |
| [2]  | GPIO3_READ | <ul style="list-style-type: none"> <li>• 1'b0: GPIO3 Readback disabled (default)</li> <li>• 1'b1: Allow readback of GPIO3_I</li> </ul> <p>Note: Requires corresponding GPIOx_SDB to be set.</p> |
| [1]  | GPIO2_READ | <ul style="list-style-type: none"> <li>• 1'b0: GPIO2 Readback disabled (default)</li> <li>• 1'b1: Allow readback of GPIO2_I</li> </ul> <p>Note: Requires corresponding GPIOx_SDB to be set.</p> |
| [0]  | GPIO1_READ | <ul style="list-style-type: none"> <li>• 1'b0: GPIO1 Readback disabled (default)</li> <li>• 1'b1: Allow readback of GPIO1_I</li> </ul> <p>Note: Requires corresponding GPIOx_SDB to be set.</p> |

**ES9039Q2M Product Datasheet****Register 47-46: GPIO OUTPUT LOGIC**

| Bits    | [15] | [14:7] | [6] | [5]  | [4]  | [3]  | [2]  | [1]  | [0]  |
|---------|------|--------|-----|------|------|------|------|------|------|
| Default | 1'b0 | 8'd0   |     | 1'b0 | 1'b0 | 1'b0 | 1'b0 | 1'b1 | 1'b1 |

| Bits   | Mnemonic          | Description                                                                                                                                                                                                                                                                                       |
|--------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15]   | GPIO_DAC_MODE     | <p>When any GPIO_CFG is "System mode control":</p> <ul style="list-style-type: none"> <li>• 1'b0: Disable datapath when GPIO input is 1'b1</li> <li>• 1'b1: Enable datapath when GPIO input is 1</li> </ul> <p>When GPIOx input is 1'b0, system mode is determined by register 0[1] DAC_MODE.</p> |
| [14:7] | RESERVED          | N/A                                                                                                                                                                                                                                                                                               |
| [6]    | GPIO_SEL          | <p>Outputs a specific channel's flag if the corresponding GPIO_AND and GPIO_OR are not set.</p> <ul style="list-style-type: none"> <li>• 1'b0: Outputs status(flag from CH1</li> <li>• 1'b1: Outputs status(flag from CH2</li> </ul>                                                              |
| [5]    | GPIO_OR_SS_RAMP   | <p>Sets the GPIO_CFG "Soft Ramp Done" flag output as the bitwise OR of both channel's flags.</p> <ul style="list-style-type: none"> <li>• 1'b0: Disabled (default)</li> <li>• 1'b1: Enabled, GPIO_CFG output is  (ss_full_ramp[CHx])</li> </ul>                                                   |
| [4]    | GPIO_OR_VOL_MIN   | <p>Sets the GPIO_CFG "Automute Status" output as the bitwise OR of both channel's statuses.</p> <ul style="list-style-type: none"> <li>• 1'b0: Disabled (default)</li> <li>• 1'b1: Enabled, GPIO_CFG output is  (automute[CHx])</li> </ul>                                                        |
| [3]    | GPIO_OR_AUTOMUTE  | <p>Sets the GPIO_CFG "Minimum Volume" flag output as the bitwise OR of both channel's flags.</p> <ul style="list-style-type: none"> <li>• 1'b0: Disabled (default)</li> <li>• 1'b1: Enabled, GPIO_CFG output is  (vol_min[CHx])</li> </ul>                                                        |
| [2]    | GPIO_AND_SS_RAMP  | <p>Sets the GPIO_CFG "Soft Ramp Done" flag output as the bitwise AND of both channel's flags.</p> <ul style="list-style-type: none"> <li>• 1'b0: Disabled</li> <li>• 1'b1: Enabled, GPIO_CFG output is &amp;(ss_full_ramp[CHx]) (default)</li> </ul> <p>Note: Overridden by GPIO_OR_SS_RAMP.</p>  |
| [1]    | GPIO_AND_VOL_MIN  | <p>Sets the GPIO_CFG "Automute Status" output as the bitwise AND of both channel's statuses.</p> <ul style="list-style-type: none"> <li>• 1'b0: Disabled</li> <li>• 1'b1: Enabled, GPIO_CFG output is &amp;(automute[CHx]) (default)</li> </ul> <p>Note: Overridden by GPIO_OR_AUTOMUTE.</p>      |
| [0]    | GPIO_AND_AUTOMUTE | <p>Sets the GPIO_CFG "Minimum Volume" flag output as the bitwise AND of both channel's flags.</p> <ul style="list-style-type: none"> <li>• 1'b0: Disabled</li> <li>• 1'b1: Enabled, GPIO_CFG output is &amp;(vol_min[CHx]) (default)</li> </ul> <p>Note: Overridden by GPIO_OR_VOL_MIN.</p>       |



## Register 48: PWM1 COUNT

|                |       |
|----------------|-------|
| <b>Bits</b>    | [7:0] |
| <b>Default</b> | 8'h00 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                    |
|-------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]       | PWM1_COUNT      | <p>8-bit value to set the number of SYS_CLK periods the PWM signal is high for.</p> <ul style="list-style-type: none"> <li>• 8'h00: Disabled (default)</li> <li>• 8'h01: Minimum</li> <li>• 8'hFF: Maximum</li> </ul> |

## Register 50-49: PWM1 FREQUENCY

|                |          |
|----------------|----------|
| <b>Bits</b>    | [15:0]   |
| <b>Default</b> | 16'h0000 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0]      | PWM1_FREQ       | <p>16-bit value to set the frequency of the PWM signal in terms of SYS_CLK divisions.</p> <ul style="list-style-type: none"> <li>• 16'h0000: Disabled (default)</li> <li>• 16'h0001: Minimum</li> <li>• 16'hFFFF: Maximum</li> </ul> $\text{frequency [Hz]} = \frac{\text{SYS\_CLK}}{\text{PWM1\_FREQ} + 1}$ $\text{Duty Cycle [%]} = \frac{\text{PWM1\_COUNT}}{\text{PWM1\_FREQ} + 1} \cdot 100$ |

## Register 51: PWM2 COUNT

|                |       |
|----------------|-------|
| <b>Bits</b>    | [7:0] |
| <b>Default</b> | 8'h00 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                    |
|-------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]       | PWM2_COUNT      | <p>8-bit value to set the number of SYS_CLK periods the PWM signal is high for.</p> <ul style="list-style-type: none"> <li>• 8'h00: Disabled (default)</li> <li>• 8'h01: Minimum</li> <li>• 8'hFF: Maximum</li> </ul> |

**ES9039Q2M Product Datasheet****Register 53-52: PWM2 FREQUENCY**

|                |          |
|----------------|----------|
| <b>Bits</b>    | [15:0]   |
| <b>Default</b> | 16'h0000 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0]      | PWM2_FREQ       | <p>16-bit value to set the frequency of the PWM signal in terms of SYS_CLK divisions.</p> <ul style="list-style-type: none"> <li>• 16'h0000: Disabled (default)</li> <li>• 16'h0001: Minimum</li> <li>• 16'hFFFF: Maximum</li> </ul> $\text{frequency [Hz]} = \frac{\text{SYS\_CLK}}{\text{PWM2\_FREQ} + 1}$ $\text{Duty Cycle [%]} = \frac{\text{PWM2\_COUNT}}{\text{PWM2\_FREQ} + 1} \cdot 100$ |

**Register 54: PWM3 COUNT**

|                |       |
|----------------|-------|
| <b>Bits</b>    | [7:0] |
| <b>Default</b> | 8'h00 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                    |
|-------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]       | PWM3_COUNT      | <p>8-bit value to set the number of SYS_CLK periods the PWM signal is high for.</p> <ul style="list-style-type: none"> <li>• 8'h00: Disabled (default)</li> <li>• 8'h01: Minimum</li> <li>• 8'hFF: Maximum</li> </ul> |

**Register 56-55: PWM3 FREQUENCY**

|                |          |
|----------------|----------|
| <b>Bits</b>    | [15:0]   |
| <b>Default</b> | 16'h0000 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0]      | PWM3_FREQ       | <p>16-bit value to set the frequency of the PWM signal in terms of SYS_CLK divisions.</p> <ul style="list-style-type: none"> <li>• 16'h0000: Disabled (default)</li> <li>• 16'h0001: Minimum</li> <li>• 16'hFFFF: Maximum</li> </ul> $\text{frequency [Hz]} = \frac{\text{SYS\_CLK}}{\text{PWM3\_FREQ} + 1}$ $\text{Duty Cycle [%]} = \frac{\text{PWM3\_COUNT}}{\text{PWM3\_FREQ} + 1} \cdot 100$ |



## DAC Registers

### Register 57: INPUT SELECTION

| Bits    | [7]  | [6]  | [5]  | [4]  | [3]  | [2:1] | [0]  |
|---------|------|------|------|------|------|-------|------|
| Default | 1'b0 | 1'b1 | 1'b0 | 1'b0 | 1'b0 | 2'd0  | 1'b0 |

| Bits  | Mnemonic                   | Description                                                                                                                                                                                                                                                                                                                                              |
|-------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | AUTO_CH_DETECT             | Auto detect BCK/FRAME ratio to determine the number of TDM channels. <ul style="list-style-type: none"><li>• 1'b0: Disabled (default)</li><li>• 1'b1: Enabled</li></ul>                                                                                                                                                                                  |
| [6]   | ENABLE_DSD_FAULT_DETECTION | Sets a channel to a DSD mute pattern (0x96) if the DSD data has no changes in 64 DATA_CLKs. <ul style="list-style-type: none"><li>• 1'b0: Disabled</li><li>• 1'b1: Enabled (default)</li></ul>                                                                                                                                                           |
| [5]   | DSD_MASTER_MODE            | DSD master mode config. <ul style="list-style-type: none"><li>• 1'b0: DSD slave mode (default)</li><li>• 1'b1: DSD master mode. DSD_CLK outputs from DATA_CLK</li></ul>                                                                                                                                                                                  |
| [4]   | PCM_MASTER_MODE            | PCM master mode config. <ul style="list-style-type: none"><li>• 1'b0: PCM slave mode (default)</li><li>• 1'b1: PCM master mode enabled. Master BCK and WS output from DATA_CLK and DATA1</li></ul>                                                                                                                                                       |
| [3]   | RESERVED                   | N/A                                                                                                                                                                                                                                                                                                                                                      |
| [2:1] | INPUT_SEL                  | Selects input data format when AUTO_INPUT_SEL is disabled. <ul style="list-style-type: none"><li>• 2'd0: PCM (default)</li><li>• 2'd1: DSD</li><li>• 2'd2: DoP</li><li>• 2'd3: S/PDIF</li></ul>                                                                                                                                                          |
| [0]   | AUTO_INPUT_SEL             | Automatic input data selection config. <ul style="list-style-type: none"><li>• 1'b0: Disables auto input select. Input data format is set by INPUT_SEL (default)</li><li>• 1'b1: Automatically determine the input data format.</li></ul> <p>Note: When using AUTO_INPUT_SEL &amp; DSD, it is required that DSD data lines are on DATA1 &amp; DATA2.</p> |

**ES9039Q2M Product Datasheet****Register 58: MASTER ENCODER CONFIG**

| Bits    | [7]  | [6]  | [5]  | [4:3] | [2]  | [1]  | [0]  |
|---------|------|------|------|-------|------|------|------|
| Default | 1'b0 | 1'b0 | 1'b0 | 2'd0  | 1'b0 | 1'b0 | 1'b1 |

| Bits  | Mnemonic             | Description                                                                                                                                                                                                                                       |
|-------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | TDM_RESYNC           | Force TDM decoder to resync.<br><ul style="list-style-type: none"> <li>• 1'b0: Enable TDM decoder synchronization (default)</li> <li>• 1'b1: Force TDM decoder to desynchronize.</li> </ul>                                                       |
| [6]   | BCK_INV              | Invert the slave BCK<br><ul style="list-style-type: none"> <li>• 1'b0: Normal operation</li> <li>• 1'b1: Invert slave BCK</li> </ul>                                                                                                              |
| [5]   | RESERVED             | N/A                                                                                                                                                                                                                                               |
| [4:3] | MASTER_FRAME_LENGTH  | Selects the bit length in each TDM channel in master mode.<br><ul style="list-style-type: none"> <li>• 2'd0: 32-bit (default)</li> <li>• 2'd1: 24-bit</li> <li>• 2'd2: 16-bit</li> <li>• 2'd3: Reserved</li> </ul>                                |
| [2]   | MASTER_WS_PULSE_MODE | When enabled, master WS is a pulse signal instead of a 50% duty cycle signal.<br>The pulse width is 1 BCK cycle.<br><ul style="list-style-type: none"> <li>• 1'b0: 50% duty cycle WS signal (default)</li> <li>• 1'b1: Pulse WS signal</li> </ul> |
| [1]   | MASTER_WS_INVERT     | Inverts master WS.<br><ul style="list-style-type: none"> <li>• 1'b0: Non-inverted (default)</li> <li>• 1'b1: Inverted</li> </ul>                                                                                                                  |
| [0]   | MASTER_BCK_INVERT    | Inverts master BCK or DSD_CLK.<br><ul style="list-style-type: none"> <li>• 1'b0: Non-inverted</li> <li>• 1'b1: Inverted (default)</li> </ul>                                                                                                      |

**Register 59: TDM CONFIG**

| Bits    | [7:5] | [4:0] |
|---------|-------|-------|
| Default | 3'd0  | 5'd1  |

| Bits  | Mnemonic   | Description                                           |
|-------|------------|-------------------------------------------------------|
| [7:5] | RESERVED   | N/A                                                   |
| [4:0] | TDM_CH_NUM | Total number of TDM slots per frame = TDM_CH_NUM + 1. |



## Register 60: TDM CONFIG1

| Bits    | [7]  | [6]  | [5]  | [4:0] |
|---------|------|------|------|-------|
| Default | 1'b0 | 1'b0 | 1'b0 | 5'd0  |

| Bits  | Mnemonic        | Description                                                                    |
|-------|-----------------|--------------------------------------------------------------------------------|
| [7]   | TDM_LJ_MODE     | TDM LJ mode.<br>• 1'b0: Standard I <sup>2</sup> S (default)<br>• 1'b1: LJ mode |
| [6]   | TDM_VALID_EDGE  | TDM WS valid edge.<br>• 1'b0: negative edge (default)<br>• 1'b1: positive edge |
| [5]   | TDM_DAISY_CHAIN | TDM daisy chain mode.<br>• 1'b0: Disabled (default)<br>• 1'b1: Enabled         |
| [4:0] | RESERVED        | N/A                                                                            |

## Register 61: TDM CONFIG2

| Bits    | [7]  | [6:5] | [4:0] |
|---------|------|-------|-------|
| Default | 1'b1 | 2'b00 | 5'd0  |

| Bits  | Mnemonic           | Description                                                                                                                                                                          |
|-------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | RESERVED           | N/A                                                                                                                                                                                  |
| [6:5] | TDM_BIT_WIDTH      | Bit width of each TDM slot.<br>• 2'b00: 32-bit (default)<br>• 2'b01: 24-bit<br>• 2'b10: 16-bit<br>• 2'b11: Reserved                                                                  |
| [4:0] | TDM_DATA_LATCH_ADJ | Sets the position of the start bit within each TDM slot.<br>Can be moved by TDM_DATA_LATCH_ADJ clock cycles.<br>• 5'd0: Normal position<br>• 5'd1-31: Number of clock cycles to wait |

## ES9039Q2M Product Datasheet

### Register 62: BCK/WS MONITOR CONFIG

| Bits    | [7]  | [6]  | [5]  | [4]  | [3]  | [2:0] |
|---------|------|------|------|------|------|-------|
| Default | 1'b0 | 1'b0 | 1'b1 | 1'b1 | 1'b0 | 3'd0  |

| Bits  | Mnemonic           | Description                                                                                                                                                                   |
|-------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | DISABLE_DSD_DC     | <ul style="list-style-type: none"> <li>1'b0: DSD DC can trigger an automute if automute is enabled (default)</li> <li>1'b1: DSD DC is ignored.</li> </ul>                     |
| [6]   | DISABLE_DSD_MUTE   | <ul style="list-style-type: none"> <li>1'b0: DSD mute pattern can trigger an automute if automute is enabled (default)</li> <li>1'b1: DSD mute pattern is ignored.</li> </ul> |
| [5]   | ENABLE_WS_MONITOR  | Enable WS monitor. <ul style="list-style-type: none"> <li>1'b0: Disable</li> <li>1'b1: Enable (default)</li> </ul>                                                            |
| [4]   | ENABLE_BCK_MONITOR | Enable BCK monitor. <ul style="list-style-type: none"> <li>1'b0: Disable</li> <li>1'b1: Enable (default)</li> </ul>                                                           |
| [3]   | DISABLE_PCM_DC     | <ul style="list-style-type: none"> <li>1'b0: PCM DC signal can trigger an automute if automute is enabled. (default)</li> <li>1'b1: PCM DC is ignored.</li> </ul>             |
| [2:0] | RESERVED           | N/A                                                                                                                                                                           |

### Register 63: RESERVED

### Register 64: CH1 SLOT CONFIG

| Bits    | [7:5] | [4:0] |
|---------|-------|-------|
| Default | 3'd0  | 5'd0  |

| Bits  | Mnemonic         | Description                                                                                                                                                                                                                                                                                                                                                         |
|-------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:5] | DSD_CH1_SOURCE   | Selects the source for the CH1 DSD data. <ul style="list-style-type: none"> <li>3'd0: DATA1 (default)</li> <li>3'd1: DATA2</li> <li>3'd2: GPIO1</li> <li>3'd3: GPIO2</li> <li>3'd4: GPIO3</li> <li>3'd5: GPIO4</li> <li>3'd6: GPIO5</li> <li>3'd7: GPIO6</li> </ul> Note: When using AUTO_INPUT_SEL & DSD, it is required that DSD data lines are on DATA1 & DATA2. |
| [4:0] | TDM_CH1_SLOT_SEL | CH1 data slot selection. CH1 receives data from Mth slot.<br>M = TDM_CH1_SLOT_SEL + 1.<br>Note: Valid for TDM, I <sup>2</sup> S and DoP.                                                                                                                                                                                                                            |



## Register 65: CH2 SLOT CONFIG

| Bits    | [7:5] | [4:0] |
|---------|-------|-------|
| Default | 3'd1  | 5'd1  |

| Bits  | Mnemonic         | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:5] | DSD_CH2_SOURCE   | <p>Selects the source for the CH2 DSD data.</p> <ul style="list-style-type: none"> <li>• 3'd0: DATA1</li> <li>• 3'd1: DATA2 (default)</li> <li>• 3'd2: GPIO1</li> <li>• 3'd3: GPIO2</li> <li>• 3'd4: GPIO3</li> <li>• 3'd5: GPIO4</li> <li>• 3'd6: GPIO5</li> <li>• 3'd7: GPIO6</li> </ul> <p>Note: When using AUTO_INPUT_SEL &amp; DSD, it is required that DSD data lines are on DATA1 &amp; DATA2.</p> |
| [4:0] | TDM_CH2_SLOT_SEL | <p>CH2 data slot selection. CH2 receives data from Mth slot.<br/> <math>M = TDM\_CH2\_SLOT\_SEL + 1</math>.</p> <p>Note: Valid for TDM, I<sup>2</sup>S and DoP.</p>                                                                                                                                                                                                                                       |

## Register 73-66: RESERVED

## Register 74: VOLUME CH1

| Bits    | [7:0] |
|---------|-------|
| Default | 8'd0  |

| Bits  | Mnemonic   | Description                                                                                                                                    |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | VOLUME_CH1 | <p>DAC CH1 volume. -0dB to -127.5dB, 0.5dB steps</p> <ul style="list-style-type: none"> <li>• 8'd0: 0dB</li> <li>• 8'd255: -127.5dB</li> </ul> |

## Register 75: VOLUME CH2

| Bits    | [7:0] |
|---------|-------|
| Default | 8'd0  |

| Bits  | Mnemonic   | Description                                                                                                                                    |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | VOLUME_CH2 | <p>DAC CH2 volume. -0dB to -127.5dB, 0.5dB steps</p> <ul style="list-style-type: none"> <li>• 8'd0: 0dB</li> <li>• 8'd255: -127.5dB</li> </ul> |

## ES9039Q2M Product Datasheet

### Register 81-76: RESERVED

### Register 82: DAC VOL UP RATE

|                |       |
|----------------|-------|
| <b>Bits</b>    | [7:0] |
| <b>Default</b> | 8'h04 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                      |
|-------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]       | DAC_VOL_RATE_UP | <p>Linear step size from the current volume to a target volume, represented as a fraction of full-scale.</p> $\text{vol\_step\_rate [inc/s]} = \frac{\text{DAC\_VOL\_RATE\_UP} \cdot FS}{2^{12}}$ <ul style="list-style-type: none"> <li>• 8'h00: Instant change</li> <li>• 8'h01: Slowest change</li> <li>• 8'h04: Default</li> <li>• 8'hFF: Fastest change</li> </ul> |

### Register 83: DAC VOL DOWN RATE

|                |       |
|----------------|-------|
| <b>Bits</b>    | [7:0] |
| <b>Default</b> | 8'h04 |

| <b>Bits</b> | <b>Mnemonic</b>   | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                        |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]       | DAC_VOL_RATE_DOWN | <p>Linear step size from the current volume to a target volume, represented as a fraction of full-scale.</p> $\text{vol\_step\_rate [inc/s]} = \frac{\text{DAC\_VOL\_RATE\_DOWN} \cdot FS}{2^{12}}$ <ul style="list-style-type: none"> <li>• 8'h00: Instant change</li> <li>• 8'h01: Slowest change</li> <li>• 8'h04: Default</li> <li>• 8'hFF: Fastest change</li> </ul> |

### Register 84: DAC VOL DOWN RATE FAST

|                |       |
|----------------|-------|
| <b>Bits</b>    | [7:0] |
| <b>Default</b> | 8'hFF |

| <b>Bits</b> | <b>Mnemonic</b>   | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]       | DAC_VOL_RATE_FAST | <p>Linear step size from the current volume to a target volume, represented as a fraction of full-scale.</p> <p>Only used during abnormal mute (PLL unlock or BCK_WS ratio failed)</p> $\text{vol\_step\_rate [inc/s]} = \frac{\text{DAC\_VOL\_RATE\_FAST} \cdot FS}{2^{12}}$ <ul style="list-style-type: none"> <li>• 8'h00: Instant change</li> <li>• 8'h01: Slowest change</li> <li>• 8'hFF: Fastest change (default)</li> </ul> |

**Register 85: RESERVED****Register 86: DAC MUTE**

| Bits    | [7:2] | [1]  | [0]  |
|---------|-------|------|------|
| Default | 6'd0  | 1'b0 | 1'b0 |

| Bits  | Mnemonic     | Description                                                                                                    |
|-------|--------------|----------------------------------------------------------------------------------------------------------------|
| [7:2] | RESERVED     | N/A                                                                                                            |
| [1]   | DAC_MUTE_CH2 | <ul style="list-style-type: none"> <li>1'b0: Normal CH2 operation (default)</li> <li>1'b1: Mute CH2</li> </ul> |
| [0]   | DAC_MUTE_CH1 | <ul style="list-style-type: none"> <li>1'b0: Normal CH1 operation (default)</li> <li>1'b1: Mute CH1</li> </ul> |

**Register 87: DAC INVERT**

| Bits    | [7:2] | [1]  | [0]  |
|---------|-------|------|------|
| Default | 6'd0  | 1'b0 | 1'b0 |

| Bits  | Mnemonic       | Description                                                                                                                                                                                                            |
|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:2] | RESERVED       | N/A                                                                                                                                                                                                                    |
| [1]   | DAC_INVERT_CH2 | <p>Invert the output on CH2 at the input to the noise shaped modulator (NSMOD).</p> <ul style="list-style-type: none"> <li>1'b0: Uninverted CH2 DAC output (default)</li> <li>1'b1: Inverted CH2 DAC output</li> </ul> |
| [0]   | DAC_INVERT_CH1 | <p>Invert the output on CH1 at the input to the noise shaped modulator (NSMOD).</p> <ul style="list-style-type: none"> <li>1'b0: Uninverted CH1 DAC output (default)</li> <li>1'b1: Inverted CH1 DAC output</li> </ul> |

**Register 88: FILTER SHAPE**

| Bits    | [7:3]    | [2:0] |
|---------|----------|-------|
| Default | 5'b10111 | 3'd0  |

| Bits  | Mnemonic     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:3] | RESERVED     | N/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [2:0] | FILTER_SHAPE | <p>Selects the 8x interpolation FIR filter shape.</p> <ul style="list-style-type: none"> <li>3'd0: Minimum phase (default)</li> <li>3'd1: Linear phase fast roll-off apodizing</li> <li>3'd2: Linear phase fast roll-off</li> <li>3'd3: Linear phase fast roll-off low ripple</li> <li>3'd4: Linear phase slow roll-off</li> <li>3'd5: Minimum phase fast roll-off</li> <li>3'd6: Minimum phase slow roll-off</li> <li>3'd7: Minimum phase slow roll-off low dispersion</li> </ul> |

**ES9039Q2M Product Datasheet****Register 89: IIR BANDWIDTH & S/PDIF SEL**

|                |              |            |              |
|----------------|--------------|------------|--------------|
| <b>Bits</b>    | <b>[7:4]</b> | <b>[3]</b> | <b>[2:0]</b> |
| <b>Default</b> | 4'd0         | 1'b0       | 3'd4         |

| <b>Bits</b>  | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>[7:4]</b> | SPDIF_SEL       | <p>Selects the S/PDIF data input pin.</p> <ul style="list-style-type: none"> <li>• 4'd0: Disconnected</li> <li>• 4'd1: DATA1</li> <li>• 4'd2: DATA2</li> <li>• 4'd3: GPIO1</li> <li>• 4'd4: GPIO2</li> <li>• 4'd5: GPIO3</li> <li>• 4'd6: GPIO4</li> <li>• 4'd7: GPIO5</li> <li>• 4'd8: GPIO6</li> <li>• 4'd9: GPIO7</li> <li>• 4'd10: GPIO8</li> <li>• Others: Reserved</li> </ul> <p>Note: GPIOx pins also require the GPIOx_SDB to be enabled.</p> |
| <b>[3]</b>   | VOLUME_HOLD     | <p>Hold volume coefficients to allow for all channels to update at same time.</p> <ul style="list-style-type: none"> <li>• 1'b0: Channel volume will update with changes to reg 74-75.</li> <li>• 1'b1: Channel volumes will not update.</li> </ul>                                                                                                                                                                                                   |
| <b>[2:0]</b> | IIR_BW          | <p>Controls the IIR bandwidth in the digital datapath.</p> <ul style="list-style-type: none"> <li>• 3'd0: Reserved</li> <li>• 3'd1: BW * 8</li> <li>• 3'd2: BW * 4</li> <li>• 3'd3: BW * 2</li> <li>• 3'd4: BW (default)</li> <li>• 3'd5: BW / 2</li> <li>• 3'd6: BW / 4</li> <li>• 3'd7: BW / 8</li> </ul>                                                                                                                                           |



## Register 90: DAC PATH CONFIG

| Bits    | [7:3]    | [2]  | [1]  | [0]  |
|---------|----------|------|------|------|
| Default | 5'b00000 | 1'b0 | 1'b0 | 1'b0 |

| Bits  | Mnemonic     | Description                                                                                                                          |
|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------|
| [7:3] | RESERVED     | N/A                                                                                                                                  |
| [2]   | BYPASS_IIR   | Bypass the IIR filter. <ul style="list-style-type: none"> <li>• 1'b0: Non-bypassed (default)</li> <li>• 1'b1: Bypassed</li> </ul>    |
| [1]   | BYPASS_FIR4X | Bypass the 4X FIR filter. <ul style="list-style-type: none"> <li>• 1'b0: Non-bypassed (default)</li> <li>• 1'b1: Bypassed</li> </ul> |
| [0]   | BYPASS_FIR2X | Bypass the 2X FIR filter. <ul style="list-style-type: none"> <li>• 1'b0: Non-bypassed (default)</li> <li>• 1'b1: Bypassed</li> </ul> |

## Register 94-91: THD C2

| Bits    | [31:16] | [15:0] |
|---------|---------|--------|
| Default | 16'd0   | 16'd0  |

| Bits    | Mnemonic   | Description                                                                                                                             |
|---------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | THD_C2_CH2 | A 16-bit signed coefficient for correcting for the CH2 second harmonic distortion.<br>$\text{output} = x + c2 \cdot x^2 + c3 \cdot x^3$ |
| [15:0]  | THD_C2_CH1 | A 16-bit signed coefficient for correcting for the CH1 second harmonic distortion.<br>$\text{output} = x + c2 \cdot x^2 + c3 \cdot x^3$ |

## Register 106-95: RESERVED

## Register 110-107: THD C3

| Bits    | [31:16] | [15:0] |
|---------|---------|--------|
| Default | 16'd0   | 16'd0  |

| Bits    | Mnemonic   | Description                                                                                                                            |
|---------|------------|----------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | THD_C3_CH2 | A 16-bit signed coefficient for correcting for the CH2 third harmonic distortion.<br>$\text{output} = x + c2 \cdot x^2 + c3 \cdot x^3$ |
| [15:0]  | THD_C3_CH1 | A 16-bit signed coefficient for correcting for the CH1 third harmonic distortion.<br>$\text{output} = x + c2 \cdot x^2 + c3 \cdot x^3$ |

## ES9039Q2M Product Datasheet

### Register 122-111: RESERVED

### Register 123: AUTOMUTE ENABLE

| Bits    | [7:2] | [1]  | [0]  |
|---------|-------|------|------|
| Default | 6'd63 | 1'b1 | 1'b1 |

| Bits  | Mnemonic        | Description                                                                                                                 |
|-------|-----------------|-----------------------------------------------------------------------------------------------------------------------------|
| [7:2] | RESERVED        | N/A                                                                                                                         |
| [1]   | AUTOMUTE_EN_CH2 | <ul style="list-style-type: none"> <li>1'b0: Disables ch2 automute</li> <li>1'b1: Enables ch2 automute (default)</li> </ul> |
| [0]   | AUTOMUTE_EN_CH1 | <ul style="list-style-type: none"> <li>1'b0: Disables ch1 automute</li> <li>1'b1: Enables ch1 automute (default)</li> </ul> |

### Register 125-124: AUTOMUTE TIME

| Bits    | [15] | [14] | [13:12] | [11] | [10:0] |
|---------|------|------|---------|------|--------|
| Default | 1'b0 | 1'b0 | 2'b00   | 1'b1 | 11'h0F |

| Bits    | Mnemonic            | Description                                                                                                                                                                                                                                                                                                                                          |
|---------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15]    | EXTERNALDEMIE       | Forces GPIO1-6 as inputs with 1 control bit.<br><ul style="list-style-type: none"> <li>1'b0: GPIO_SDB determined by register 42[5:0]. (default)</li> <li>1'b1: GPIO1-6 inputs enabled. Overrides register 42[5:0].</li> </ul>                                                                                                                        |
| [14]    | EXTERNALDEM         | Allows GPIO1-6 to be programmed into a full external loopback.<br><ul style="list-style-type: none"> <li>1'b0: Connect NSMOD output to DEM input (default)</li> <li>1'b1: Connect GPIO1-6 to DEM inputs</li> </ul>                                                                                                                                   |
| [13:12] | RESERVED            | N/A                                                                                                                                                                                                                                                                                                                                                  |
| [11]    | MUTE_RAMP_TO_GROUND | <ul style="list-style-type: none"> <li>1'b0: When ramped to min volume during normal mute, do not soft ramp to ground</li> <li>1'b1: When ramped to min volume during normal mute, soft ramp to ground for power saving (default)</li> </ul> <p>normal mute includes: automute, mute by register, mute by GPIO</p>                                   |
| [10:0]  | AUTOMUTE_TIME       | Configures the amount of time in seconds the audio must remain below AUTOMUTE_LEVEL before an automute condition is flagged.<br><ul style="list-style-type: none"> <li>11'h000: Disabled</li> <li>11'h001: Slowest</li> <li>11'h00F: Default</li> <li>11'h7FF: Fastest</li> </ul> $\text{Time [s]} = \frac{2^{18}}{\text{AUTOMUTE\_TIME} \cdot F_S}$ |



## Register 127-126: AUTOMUTE LEVEL

|                |          |
|----------------|----------|
| <b>Bits</b>    | [15:0]   |
| <b>Default</b> | 16'h0008 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                 |
|-------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0]      | AUTOMUTE_LEVEL  | <p>The threshold which the audio must be below before an automute condition is flagged.<br/>Shift right 1 bit corresponds to -6dB.</p> <ul style="list-style-type: none"> <li>• 16'h0001: -132dB</li> <li>• 16'h0008: -119dB (default)</li> <li>• 16'hFFFF: -42dB</li> </ul> <p>Note: Only applies to PCM automute conditions.</p> |

## Register 129-128: AUTOMUTE OFF LEVEL

|                |          |
|----------------|----------|
| <b>Bits</b>    | [15:0]   |
| <b>Default</b> | 16'h000A |

| <b>Bits</b> | <b>Mnemonic</b>    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                |
|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0]      | AUTOMUTE_OFF_LEVEL | <p>The threshold which the audio must be above before the automute condition is immediately cleared.<br/>Shift right 1 bit corresponds to -6dB.</p> <ul style="list-style-type: none"> <li>• 16'h0001: -132dB</li> <li>• 16'h000A: -117.5dB (default)</li> <li>• 16'hFFFF: -42dB</li> </ul> <p>Note: Only applies to PCM automute conditions.</p> |

## Register 130: SOFT RAMP CONFIG

|                |        |       |
|----------------|--------|-------|
| <b>Bits</b>    | [7:5]  | [4:0] |
| <b>Default</b> | 3'b000 | 5'd3  |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|-------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:5]       | RESERVED        | N/A                                                                                                                                                                                                                                                                    |
| [4:0]       | SOFT_RAMP_TIME  | <p>Sets the amount of time that it takes to perform a soft start ramp.<br/>This time affects both ramp to ground and ramp to AVCC/2.<br/>Valid from 0 to 20 (inclusive).</p> $\text{Time [s]} = 4096 \cdot \frac{2^{\text{SOFT\_RAMP\_TIME}+1}}{\text{CLK\_IDAC[Hz]}}$ |

## ES9039Q2M Product Datasheet

### Register 134-131: RESERVED

### Register 135: PROGRAM RAM CONTROL

| Bits    | [7]  | [6:2]    | [1]  | [0]  |
|---------|------|----------|------|------|
| Default | 1'b0 | 5'b00000 | 1'b0 | 1'b0 |

| Bits  | Mnemonic             | Description                                                                                                                                                                                                                                                                                                                                                         |
|-------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | SPDIF_LOAD_USER_BITS | Selects whether the S/PDIF Channel Status or User Data bits are available to readback from the register interface.<br>Subframes A and B must have the same user data bits for readback. <ul style="list-style-type: none"> <li>• 1'b0: Channel Status bits on the register interface (default)</li> <li>• 1'b1: User Data bits on the register interface</li> </ul> |
| [6:2] | RESERVED             | N/A                                                                                                                                                                                                                                                                                                                                                                 |
| [1]   | PROG_COEFF_WE        | Enables writing to the programmable coefficient RAM. <ul style="list-style-type: none"> <li>• 1'b0: Disables write signal to the coefficient RAM (default).</li> <li>• 1'b1: Enables write signal to the coefficient RAM.</li> </ul>                                                                                                                                |
| [0]   | PROG_COEFF_EN        | Enables the custom oversampling filter coefficients. <ul style="list-style-type: none"> <li>• 1'b0: Uses a built-in filter selected by filter_shape (default).</li> <li>• 1'b1: Uses the coefficients programmed via prog_coeff_data.</li> </ul>                                                                                                                    |

### Register 136: S/PDIF READ CONTROL

| Bits    | [7:5]  | [4:0] |
|---------|--------|-------|
| Default | 3'b000 | 5'd0  |

| Bits  | Mnemonic       | Description                                                                                                                                     |
|-------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:5] | RESERVED       | N/A                                                                                                                                             |
| [4:0] | SPDIF_DATA_SEL | Selects the byte of the S/PDIF payload in register 251<br>spdif_payload_read <ul style="list-style-type: none"> <li>• 24 bytes total</li> </ul> |

### Register 137: PROGRAM RAM ADDRESS

| Bits    | [7]  | [6:0] |
|---------|------|-------|
| Default | 1'b0 | 7'd0  |

| Bits  | Mnemonic         | Description                                                                                                                                                                                                                        |
|-------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | PROG_COEFF_STAGE | Selects which stage of the filter to write. <ul style="list-style-type: none"> <li>• 1'b0: Selects the 2x stage of the oversampling filter (default).</li> <li>• 1'b1: Selects the 4x stage of the oversampling filter.</li> </ul> |
| [6:0] | PROG_COEFF_ADDR  | Selects the coefficient address when writing custom coefficients for the oversampling filter.                                                                                                                                      |



## Register 140-138: PROGRAM RAM DATA

|                |        |
|----------------|--------|
| <b>Bits</b>    | [23:0] |
| <b>Default</b> | 24'd0  |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                                 |
|-------------|-----------------|----------------------------------------------------------------------------------------------------|
| [23:0]      | PROG_COEFF_IN   | A 24-bit signed filter coefficient that will be written to the address defined in prog_coeff_addr. |

## Register 145-141: RESERVED

**ES9039Q2M Product Datasheet****Readback Registers****Register 224: RESERVED****Register 225: CHIP ID READ**

|                |       |
|----------------|-------|
| <b>Bits</b>    | [7:0] |
| <b>Default</b> | 8'h63 |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>            |
|-------------|-----------------|-------------------------------|
| [7:0]       | CHIP_ID         | Chip ID.<br>• ES9039Q2M: 0x63 |

**Register 228-226: RESERVED****Register 230-229: INTERRUPT STATES**

|                |         |         |      |        |     |     |       |       |       |
|----------------|---------|---------|------|--------|-----|-----|-------|-------|-------|
| <b>Bits</b>    | [15:14] | [13:12] | [11] | [10:8] | [7] | [6] | [5:4] | [3:2] | [1:0] |
| <b>Default</b> |         | -       | -    |        | -   | -   | -     | -     | -     |

| <b>Bits</b> | <b>Mnemonic</b>             | <b>Description</b>                                                                                         |
|-------------|-----------------------------|------------------------------------------------------------------------------------------------------------|
| [15:14]     | RESERVED                    | N/A                                                                                                        |
| [13:12]     | INPUT_SELECT_OVERRIDE_STATE | State of the INPUT_SELECT_OVERRIDE interrupt.<br>Note: Interrupt clear bits are required to reset value.   |
| [11]        | TDM_DATA_VALID_STATE        | State of the TDM_DATA_VALID interrupt.<br>Note: Interrupt clear bit is required to reset value.            |
| [10:8]      | RESERVED                    | N/A                                                                                                        |
| [7]         | BCK_WS_FAIL_STATE           | State of the BCK_WS_FAIL interrupt.<br>Note: Interrupt clear bit is required to reset value.               |
| [6]         | DOP_VALID_STATE             | State of the DOP_VALID interrupt.<br>Note: Interrupt clear bit is required to reset value.                 |
| [5:4]       | SS_FULL_RAMP_STATE          | State of each channel's SS_FULL_RAMP interrupt.<br>Note: Interrupt clear bit is required to reset value.   |
| [3:2]       | AUTOMUTE_STATE              | State of each channel's AUTOMUTE_STATE interrupt.<br>Note: Interrupt clear bit is required to reset value. |
| [1:0]       | VOL_MIN_STATE               | State of each channel's VOL_MIN_STATE interrupt.<br>Note: Interrupt clear bit is required to reset value.  |

**Register 233-231: RESERVED****Register 235-234: INTERRUPT SOURCES**

| Bits    | [15:14] | [13:12] | [11] | [10:8] | [7] | [6] | [5:4] | [3:2] | [1:0] |
|---------|---------|---------|------|--------|-----|-----|-------|-------|-------|
| Default |         | -       | -    |        | -   | -   | -     | -     | -     |

| Bits    | Mnemonic                     | Description                                                                              |
|---------|------------------------------|------------------------------------------------------------------------------------------|
| [15:14] | RESERVED                     | N/A                                                                                      |
| [13:12] | INPUT_SELECT_OVERRIDE_SOURCE | Output of the AUTO_INPUT_SELECT logic.                                                   |
| [11]    | TDM_DATA_VALID_SOURCE        | TDM data valid flag.                                                                     |
| [10:8]  | RESERVED                     | N/A                                                                                      |
| [7]     | BCK_WS_FAIL_SOURCE           | Validity of BCK, WS, and ASYNC_LOCK flag.<br>Requires respective monitor bits to be set. |
| [6]     | DOP_VALID_SOURCE             | Valid DoP flag for Channels 1 and 2.                                                     |
| [5:4]   | SS_FULL_RAMP_SOURCE          | Channel flag for whether it is automute is active.                                       |
| [3:2]   | AUTOMUTE_SOURCE              | Channel flag for whether it is automute is active.                                       |
| [1:0]   | VOL_MIN_SOURCE               | Channel flag for whether the corresponding volume register = 0x00                        |

**Register 239-236: RESERVED****Register 240: GPIO READBACK**

| Bits    | [7] | [6] | [5] | [4] | [3] | [2] | [1] | [0] |
|---------|-----|-----|-----|-----|-----|-----|-----|-----|
| Default | -   | -   | -   | -   | -   | -   | -   | -   |

| Bits | Mnemonic     | Description           |
|------|--------------|-----------------------|
| [7]  | GPIO8_I_READ | GPIO8 input readback. |
| [6]  | GPIO7_I_READ | GPIO7 input readback. |
| [5]  | GPIO6_I_READ | GPIO6 input readback. |
| [4]  | GPIO5_I_READ | GPIO5 input readback. |
| [3]  | GPIO4_I_READ | GPIO4 input readback. |
| [2]  | GPIO3_I_READ | GPIO3 input readback. |
| [1]  | GPIO2_I_READ | GPIO2 input readback. |
| [0]  | GPIO1_I_READ | GPIO1 input readback. |

**Register 241: VOL MIN READ**

| Bits    | [7:2] | [1] | [0] |
|---------|-------|-----|-----|
| Default |       | -   | -   |

| Bits  | Mnemonic    | Description         |
|-------|-------------|---------------------|
| [7:2] | RESERVED    | N/A                 |
| [1]   | VOL_MIN_CH2 | Volume min flag ch2 |
| [0]   | VOL_MIN_CH1 | Volume min flag ch1 |

**ES9039Q2M Product Datasheet****Register 242: AUTOMUTE READ**

|                |       |     |     |
|----------------|-------|-----|-----|
| <b>Bits</b>    | [7:2] | [1] | [0] |
| <b>Default</b> |       | -   | -   |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>  |
|-------------|-----------------|---------------------|
| [7:2]       | RESERVED        | N/A                 |
| [1]         | AUTOMUTE_CH2    | Automute status ch2 |
| [0]         | AUTOMUTE_CH1    | Automute status ch1 |

**Register 243: SOFT RAMP UP READ**

|                |       |     |     |
|----------------|-------|-----|-----|
| <b>Bits</b>    | [7:2] | [1] | [0] |
| <b>Default</b> |       | -   | -   |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>      |
|-------------|-----------------|-------------------------|
| [7:2]       | RESERVED        | N/A                     |
| [1]         | SS_RAMP_UP_CH2  | Soft ramped up flag ch2 |
| [0]         | SS_RAMP_UP_CH1  | Soft ramped up flag ch1 |

**Register 244: SOFT RAMP DOWN READ**

|                |       |     |     |
|----------------|-------|-----|-----|
| <b>Bits</b>    | [7:2] | [1] | [0] |
| <b>Default</b> |       | -   | -   |

| <b>Bits</b> | <b>Mnemonic</b>  | <b>Description</b>        |
|-------------|------------------|---------------------------|
| [7:2]       | RESERVED         | N/A                       |
| [1]         | SS_RAMP_DOWN_CH2 | Soft ramped down flag ch2 |
| [0]         | SS_RAMP_DOWN_CH1 | Soft ramped down flag ch1 |

**Register 245: INPUT STREAM READBACK**

|                |       |     |     |     |       |
|----------------|-------|-----|-----|-----|-------|
| <b>Bits</b>    | [7:5] | [4] | [3] | [2] | [1:0] |
| <b>Default</b> |       | -   | -   | -   | -     |

| <b>Bits</b> | <b>Mnemonic</b>       | <b>Description</b>                                                                                                                                             |
|-------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:5]       | RESERVED              | N/A                                                                                                                                                            |
| [4]         | SPDIF_VALID           | S/PDIF valid flag                                                                                                                                              |
| [3]         | TDM_DATA_VALID        | TDM valid data flag                                                                                                                                            |
| [2]         | DOP_VALID             | DoP valid flag                                                                                                                                                 |
| [1:0]       | INPUT_SELECT_OVERRIDE | AUTO_INPUT_SEL value <ul style="list-style-type: none"> <li>• 2'd0: PCM (default)</li> <li>• 2'd1: DSD</li> <li>• 2'd2: DoP</li> <li>• 2'd3: S/PDIF</li> </ul> |



## Register 248-246: PROG COEFF OUT READ

|                |        |
|----------------|--------|
| <b>Bits</b>    | [23:0] |
| <b>Default</b> | -      |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                    |
|-------------|-----------------|---------------------------------------|
| [23:0]      | PROG_COEFF_OUT  | Programmable FIR coefficient readback |

## Register 250-249: RESERVED

## Register 251: S/PDIF DATA READ

|                |       |
|----------------|-------|
| <b>Bits</b>    | [7:0] |
| <b>Default</b> | -     |

| <b>Bits</b> | <b>Mnemonic</b> | <b>Description</b>                                                                       |
|-------------|-----------------|------------------------------------------------------------------------------------------|
| [7:0]       | SPDIF_DATA_READ | Contains a byte of the S/PDIF payload.<br>Controlled by register 136[4:0] spdif_data_sel |

## ES9039Q2M Reference Schematics

## Typical Application Schematic



Figure 26 - Typical ES9039Q2M Software Mode Application Diagram

Note: See GPIO section for configuration of GPIOs including GPIO8.

## Hardware (HW) Mode

-- All AVCC\_DAC1/AVCC\_DAC2 pins must be powered with an ultra-low-noise regulator. --



Figure 27 - Hardware (HW) Mode Reference Schematic for ES9039Q2M

Note: ES9039Q2M has an exposed pad (EPAD, Pin 33) and should be connected to ground.

**Software (SW) Mode**

-- All AVCC\_DAC1/AVCC\_DAC2 pins must be powered with an ultra-low-noise regulator. --



Figure 28 - Software Mode Reference Schematic for ES9039Q2M

Note: ES9039Q2M has an exposed pad (EPAD, Pin 33) and should be connected to ground.

## Recommended Output Stage



Figure 29 - Output Stage Schematic for ES9039Q2M

Note 1: Schematic is representative of ES9039Q2M EVB v2.1

Note 2: A 3 op-amp output stage schematic with slightly improved THD+N performance with a slight increase in noise is available, see distributor or FAE for more information if required.

Note 3: C1, C3 & C9 values are chosen specifically for OPA1612, change depending on desired frequency response.

## Recommended Power Supply



Figure 30 - ES9039Q2M Power Supply Schematic

Note: In all configurations  $V_{BG}$  must remain floating.  $VSENSEx$  and  $OUTx$  pins need to be star connected to  $4.7\mu F$  capacitors which are located close to ES9312.

**Internal Pad Circuitry**

| Pin Name                                                                                                                                                                         | Type        | Pin                                                                                          | Equivalent Circuit                                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| AVCC_DAC1<br>AVCC_DAC2<br>AVDD<br>VCCA                                                                                                                                           | Power       | 1<br>8<br>10<br>31                                                                           | <p>Power Pad</p> <p>ESD</p> <p>GND</p>                                                                        |
| AGND_DAC1<br>AGND_DAC2<br>GND<br>GND                                                                                                                                             | Ground      | 4<br>5<br>11<br>30                                                                           | <p>VDD</p> <p>ESD</p> <p>Ground Pad</p>                                                                       |
| CHIP_EN                                                                                                                                                                          | Reset       | 18                                                                                           | <p>VDD</p> <p>ESD</p> <p>ESD</p> <p>GND</p> <p>I</p> <p>O</p> <p>PU/PD</p> <p>R</p> <p>Digital I</p>          |
| DATA_CLK<br>DATA1<br>DATA2<br>SCLK/SCL/HW1<br>MOSI/SDA/HW0<br>RT1<br>SS/ADDR1/HW2<br>MISO/ADDR0/MUTE_CTRL<br>GPIO1<br>GPIO2<br>GPIO3<br>GPIO4<br>GPIO5<br>GPIO6<br>GPIO7<br>MODE | Digital I/O | 12<br>13<br>14<br>15<br>16<br>17<br>19<br>20<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>29 | <p>VDD</p> <p>ESD</p> <p>ESD</p> <p>GND</p> <p>I</p> <p>O</p> <p>OE</p> <p>PD</p> <p>R</p> <p>Digital I/O</p> |

|                                        |                        |                        |  |
|----------------------------------------|------------------------|------------------------|--|
| GPIO 8                                 | Digital I/O<br>Cal_Res | 28                     |  |
| DAC1B<br>DAC1<br>DAC2B<br>DAC2<br>MCLK | Analog IO DAC          | 2<br>3<br>6<br>7<br>32 |  |
| DVDD                                   | IO Power               | 9                      |  |

Table 33 - Internal Pad Circuitry

## 32 QFN Package Dimensions



Figure 31 - ES9039Q2M 32 QFN Package Dimensions

## 32 QFN Top View Marking



Figure 32 - ES9039Q2M Marking

| Package Type     | Dimension in mm |     |     |     |     |     |     |
|------------------|-----------------|-----|-----|-----|-----|-----|-----|
|                  | A               | B   | C   | D   | E   | F   | G   |
| 32 QFN 5mm x 5mm | 4.0             | 1.6 | 0.2 | 0.4 | 0.2 | 0.1 | 0.3 |

|   |                    |
|---|--------------------|
| T | Tracking Number    |
| W | Work Week          |
| Y | Last Digit of Year |
| L | Low Number         |
| R | Silicon Revision   |

## Reflow Process Considerations

### Temperature Controlled

For lead-free soldering, the characterization and optimization of the reflow process is the most important factor to consider.

The lead-free alloy solder has a melting point of 217°C. This alloy requires a minimum reflow temperature of 235°C to ensure good wetting. The maximum reflow temperature is in the 245°C to 260°C range, depending on the package size ([RPC-2-Pb-Free Process - Classification Temperatures \(T<sub>c</sub>\)](#)). This narrows the process window for lead-free soldering to 10°C to 20°C.

The increase in peak reflow temperature in combination with the narrow process window makes the development of an optimal reflow profile a critical factor for ensuring a successful lead-free assembly process. The major factors contributing to the development of an optimal thermal profile are the size and weight of the assembly, the density of the components, the mix of large and small components, and the paste chemistry being used.

Reflow profiling needs to be performed by attaching calibrated thermocouples well adhered to the device as well as other critical locations on the board to ensure that all components are heated to temperatures above the minimum reflow temperatures and that smaller components do not exceed the maximum temperature limits (Table RPC-2).

To ensure that all packages can be successfully and reliably assembled, the reflow profiles studied and recommended by ESS are based on the JEDEC/IPC standard J-STD-020 revision D.1.



Figure 33 - IR/Convection Reflow Profile (IPC/JEDEC J-STD-020D.1)

Reflow is allowed 3 times. Caution must be taken to ensure time between re-flow runs does not exceed the allowed time by the moisture sensitivity label. If the time elapsed between the re-flows exceeds the moisture sensitivity time bake the board according to the moisture sensitivity label instructions.

## Manual

Allowed up to 2 times with maximum temperature of 350°C no longer than 3 seconds.

### RPC-1 Classification Reflow Profile

| Profile Feature                                                        | Pb-Free Assembly                                                                                                                                      |
|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Preheat/Soak</b>                                                    |                                                                                                                                                       |
| Temperature Min (Tsmin)                                                | 150°C                                                                                                                                                 |
| Temperature Max (Tsmax)                                                | 200°C                                                                                                                                                 |
| Time (ts) from (Tsmin to Tsmax)                                        | 60-120 seconds                                                                                                                                        |
| Ramp-up rate (TL to Tp)                                                | 3°C / second maximum                                                                                                                                  |
| Liquidous temperature (TL)                                             | 217°C                                                                                                                                                 |
| Time (tL) maintained above TL                                          | 60-150 seconds                                                                                                                                        |
| Peak package body temperature (Tp)                                     | For users Tp must not exceed the classification temp in Table RPC-2.<br>For suppliers Tp must equal or exceed the Classification temp in Table RPC-2. |
| Time (tp)* within 5°C of the specified classification temperature (Tc) | 30* seconds                                                                                                                                           |
| Ramp-down rate (Tp to TL)                                              | 6°C / second maximum                                                                                                                                  |
| Time 25°C to peak temperature                                          | 8 minutes maximum                                                                                                                                     |

\* Tolerance for peak profile temperature (Tp) is defined as a supplier minimum and a user maximum.

Table 34 - RPC-1 Classification Reflow Profile

All temperatures refer to the center of the package, measured on the package body surface that is facing up during assembly reflow (e.g., live-bug). If parts are reflowed in other than the normal live-bug assembly reflow orientation (i.e., dead-bug), Tp shall be within  $\pm 2^\circ\text{C}$  of the live-bug Tp and still meet the Tc requirements, otherwise, the profile shall be adjusted to achieve the latter. To accurately measure actual peak package body temperatures, refer to JEP140 for recommended thermocouple use.

Reflow profiles in this document are for classification/preconditioning and are not meant to specify board assembly profiles. Actual board assembly profiles should be developed based on specific process needs and board designs and should not exceed the parameters in Table RPC-1.

For example, if Tc is 260°C and time tp is 30 seconds, this means the following for the supplier and the user.

For a supplier: The peak temperature must be at least 260°C. The time above 255°C must be at least 30 seconds.

For a user: The peak temperature must not exceed 260°C. The time above 255°C must not exceed 30 seconds.

All components in the test load shall meet the classification profile requirements.

## RPC-2-Pb-Free Process - Classification Temperatures (Tc)

| Package Thickness | Volume mm <sup>3</sup> , <350 | Volume mm <sup>3</sup> , 350 to 2000 | Volume mm <sup>3</sup> , >2000 |
|-------------------|-------------------------------|--------------------------------------|--------------------------------|
| <1.6 mm           | 260°C                         | 260°C                                | 260°C                          |
| 1.6 mm – 2.5 mm   | 260°C                         | 250°C                                | 245°C                          |
| >2.5 mm           | 250°C                         | 245°C                                | 245°C                          |

Table 35 - RPC-2 Pb Free Classification Temperature

At the discretion of the device manufacturer, but not the board assembler/user, the maximum peak package body temperature (Tp) can exceed the values specified in Table RPC-2. The use of a higher Tp does not change the classification temperature (Tc).

Package volume excludes external terminals (e.g., balls, bumps, lands, leads) and/or nonintegral heat sinks.

The maximum component temperature reached during reflow depends on package thickness and volume. The use of convection reflow processes reduces the thermal gradients between packages. However, thermal gradients due to differences in thermal mass of SMD packages may still exist.

## ES9039Q2M Product Datasheet

### Ordering Information

| Part Number | Description                                 | Package          |
|-------------|---------------------------------------------|------------------|
| ES9039Q2M   | SABRE 32-bit High Performance 2 Channel DAC | 5mm x 5mm 32 QFN |

Table 36 - Ordering Information

### Revision History

Current Version 0.2.2

| Rev.  | Date            | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0.1.2 | March, 2023     | Initial release                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0.2   | September, 2024 | <ul style="list-style-type: none"> <li>• Updated PCM Digital Filters with 64FS Mode Filter</li> <li>• Updated 32 QFN Package Dimensions clarity</li> <li>• Updated Calibration Resistor section</li> <li>• Updated Reference Schematic power supplies and output stage</li> <li>• Updated reference to MCLK &amp; SYS_CLK for clock gearing for clarity</li> <li>• Updated register description Reg5[5:4,2], 42[6, 4, 3], 48-56, 57[0], 62[4, 3], 64[4:0], 65[4:0], 123[1,0]</li> <li>• Unreserved Reg 60[5] TDM_DAIY_CHAIN</li> <li>• Unreserved Reg 135[7] SPDIF_LOAD_USER_BITS</li> </ul> |
| 0.2.1 | March, 2025     | <ul style="list-style-type: none"> <li>• Unreserved Register 124-125[15:14] and External DEM Output (GPIO_CFG)</li> <li>• Updated Hardware Mode Pin Configurations #16-27</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0.2.2 | June, 2025      | <ul style="list-style-type: none"> <li>• Added Recommended Power Up/Down Sequence</li> <li>• Updated Recommended Operating Conditions and Absolute Maximum Rating</li> <li>• Updated DSD Audio Input Formats section</li> </ul>                                                                                                                                                                                                                                                                                                                                                              |

© 2023-2025 ESS Technology, Inc.

ESS ICs are not intended, authorized, or warranted for use as components in military applications, medical devices or life support systems. ESS assumes no liability and disclaims any expressed, implied or statutory warranty for use of ESS ICs in such unsuitable applications.

No part of this publication may be reproduced, stored in a retrieval system, transmitted, or translated in any form or by any means, electronic, mechanical, manual, optical, or otherwise, without the prior written permission of ESS Technology, Inc. ESS Technology, Inc. makes no representations or warranties regarding the content of this document. All specifications are subject to change without prior notice. ESS Technology, Inc. assumes no responsibility for any errors contained herein. U.S. patents pending.