

# **USB-to-I2S Bridging with Microchip Hubs**

Author: Jeffrey Hunt

Microchip Technology, Inc.

#### INTRODUCTION

The I2S (Inter-IC-Sound) bus is the standard interface for connecting audio devices, such as audio codecs.

The USB Audio/Video (AV) Device Class Definition describes among other things the methods used to communicate with devices containing sound-related functionality. This includes digital and analog audio data with its associated metadata and the functionality used to control the audio environment, such as volume controls.

Microchip USB hubs provide a bridge from USB to an audio device codec via I2S. These devices support only USB Audio Device Class Specification v1.0. The I2S interface is a five-wire connection to the ADAU1961 codec. There is sufficient configuration flexibility to change the settings of the Analog Devices ADAU1961, or to implement a different codec.

While the audio data to and from the audio codec is through the I2S interface, USB Audio Device control data is transferred through the I2C (master) interface of the hub.

For more details regarding the implementation, refer to the device data sheets listed in the References section.

## **SECTION**

Section 1.0, General Information

## **REFERENCES**

Consult the following documents for details on the specific parts referred to in this document.

- · Microchip USB4715 Data Sheet
- · Microchip USB4914 Data Sheet
- Microchip USB4916 Data Sheet
- Microchip USB4925 Data Sheet
- Microchip USB4927 Data Sheet
- Microchip USB4712 Data Sheet
- Microchip USB4912 Data Sheet
- Microchip USB7002 Data Sheet
- Microchip USB7050 Data Sheet
- Microchip USB7051 Data Sheet
  Microchip USB7152 Data Sheet
- Microchip USB7056 Data Sheet
- · Microcrip 03B7030 Data Sheet
- Microchip USB7202 Data SheetMicrochip USB7250 Data Sheet
- Microchip USB7251 Data Sheet
- · Microchip USB7252 Data Sheet
- · Microchip USB7256 Data Sheet
- · Microchip USB7206 Data Sheet
- · Microchip USB7216 Data Sheet

- UM10204, I2C-bus specification and user manual, https://www.nxp.com/docs/en/user-guide/UM10204.pdf
- Audio Device Class Spec v1.0, http://www.usb.org/developers/docs/devclass\_docs
- ADAU1961 Data Sheet, https://www.analog.com/en/products/adau1961.html

## 1.0 GENERAL INFORMATION

Microchip hub USB-to-I2S Bridging features work via host commands sent to an embedded Hub Feature Controller within the device, located on an additional internal USB port. In order for the bridging features to work correctly, this internal Hub Feature Controller must be enabled by default. Table 1 provides details on default Hub Feature Controllers settings per device that contains the I2S Bridge implementation described in this document.

TABLE 1: DEFAULT SETTINGS FOR HUB FEATURE CONTROLLER ENABLE

| Part Number | Part Summary                                              | Hub Feature Controller Default Setting |
|-------------|-----------------------------------------------------------|----------------------------------------|
| USB4715     | 5-Port USB2.0 FlexConnect Hub                             | Enabled by default on Port 5           |
| USB4914     | 3-Port USB2.0 Multi-Host Reflector Hub                    | Enabled by default on Port 5           |
| USB4916     | 5-Port USB2.0 Multi-Host Reflector Hub                    | Enabled by default on Port 7           |
| USB4925     | 3-Port USB2.0 Dual Upstream Hub                           | Enabled by default on Port 4           |
| USB4927     | 5-Port USB2.0 Dual Upstream Hub                           | Enabled by default on Port 6           |
| USB7002     | 4-Port USB3.1 Gen1 Hub                                    | Enabled by default on port 6           |
| USB7050     | 4-Port USB3.1 Gen1 Hub with USB power delivery on 3 ports | Enabled by default on port 6           |
| USB7051     | 4-Port USB3.1 Gen1 Hub with USB power delivery on 2 ports | Enabled by default on port 6           |
| USB7052     | 4-Port USB3.1 Gen1 Hub with USB power delivery on 1 port  | Enabled by default on port 6           |
| USB7056     | 6-Port USB3.1 Gen1 Hub with USB power delivery on 1 port  | Enabled by default on port 8           |
| USB7202     | 4-Port USB3.1 Gen2 Hub                                    | Enabled by default on port 6           |
| USB7250     | 4-Port USB3.1 Gen2 Hub with USB power delivery on 3 ports | Enabled by default on port 6           |
| USB7251     | 4-Port USB3.1 Gen2 Hub with USB power delivery on 2 ports | Enabled by default on port 6           |
| USB7252     | 4-Port USB3.1 Gen2 Hub with USB power delivery on 1 port  | Enabled by default on port 6           |
| USB7256     | 6-Port USB3.1 Gen2 Hub with USB power delivery on 1 port  | Enabled by default on port 8           |
| USB7206     | 6-Port USB3.1 Gen2 Hub                                    | Enabled by default on port 8           |
| USB7216     | 6-Port USB3.1 Gen2 Hub                                    | Enabled by default on port 8           |

# 1.1 Supported I2S Bridge Features

In basic operation, I2S Bridging interface enumerates as a USB device, which complies with *Audio Device Class Spec v1.0*.

Default audio features supported by the device are:

- 48 kHz
- 6 bits/sample
- Stereo Audio
- ADAU1961 audio codec

The I2S bridge can also be configured by OTP for different audio features and settings, or even a different codec.

#### 1.1.1 CONFIGURABLE FEATURES OF I2S BRIDGE

# TABLE 2: CONFIGURABLE FEATURES OF I2S BRIDGE

| Parameter                                        | Supported Values                                                                                                                                                                                                              |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sampling Frequency (fs)                          | 8 kHz, 11.025 kHz, 12 kHz, 16 kHz, 22.05 kHz, 24 kHz, 32 kHz, 44.1 kHz, 48 kHz                                                                                                                                                |
| MCLK Frequency (Multiple of Sampling frequency)  | From 1*fs to 1024*fs.  MCLK can be any arbitrary multiple of fs up to 1024 times fs. However, because the I2S LRCLK signal is derived from the MCLK source, it is recommended that only even-integer-multiples of fs be used. |
| Audio Sample size                                | 16-bits/sample, 24-bits/sample, 32-bits/sample                                                                                                                                                                                |
| I2S Audio Interface Format                       | I2S mode, Left Justified mode, Right Justified mode                                                                                                                                                                           |
| I2C Master Control interface Frequency           | 100 kHz and 400 kHz                                                                                                                                                                                                           |
| Audio channels                                   | Mono mode and Stereo mode                                                                                                                                                                                                     |
| Enabling and disabling the I2S Bridge interfaces | Audio Out only (Speaker Interface) Audio IN only (Mic Interface) Audio IN and Audio Out (Line Interface) Jack Detection Interface                                                                                             |
| Jack Detection                                   | Audio jack insertion-detection can be enabled or disabled                                                                                                                                                                     |

# 1.2 Implementation of an alternative codec

ADAU1960/1961 is the default example used with the I2S Bridge, but other codecs can also be used. The following checklist can be used to determine if a codec is compatible with the I2S Bridge. In order to be compatible with the I2S Bridge, a codec must meet all of the following criteria.

#### 1.2.1 I2S BRIDGE CODEC COMPATIBILITY CHECKLIST

- 1. The codec supports I2S Slave mode.
- 2. The codec supports configuration via I2C (Slave mode).
- 3. The codec does not require an external MCLK signal, or the I2S Bridge is capable of supplying the CLK frequency that the codec requires.
- 4. The codec can accept a LCRLK sampling frequency that the I2S Bridge can provide.
- 5. The codec can accept a sample width that the I2S Bridge can support.
- 6. The codec has one or two audio channels, but not more than two.

FIGURE 1: IDENTIFYING CODEC COMPATABILITY



# 1.2.2 CODEC IMPLEMENTATION STEPS

Once a codec has been identified as compatible, actions must be taken (by means of register access through OTP) to configure both the codec and the I2S Bridge. Table 3 identifies configuration steps typical for several examples that might be required if changing to a different codec.

TABLE 3: AUDIO PARAMETERS CONFIGURATION

|        | To Change<br>Audio<br>Sampling<br>Frequency                                                                                                                                                                                                                                                                                  | To Change Audio<br>Codec Device                                                                                                                                                                                   | To Change Audio<br>Sample Resolution<br>(Bits/Sample)                                                                                                                                                                                                                                                                                                                        | To Change<br>Number of<br>Audio<br>Channel -<br>Stereo/Mono                                                                                                                                                                                                                                                                                | To Disable<br>Speaker/Mic<br>Interface                                     |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| Step 1 | Modifying the USB Audio Descriptors to advertise the new sampling frequency.                                                                                                                                                                                                                                                 | Modifying the Codec Initialization                                                                                                                                                                                | Modifying the USB<br>Audio Descriptors to<br>advertise the new<br>Sample Resolution                                                                                                                                                                                                                                                                                          | Modifying the USB Audio Descriptors to advertise the number of Audio channels supported                                                                                                                                                                                                                                                    | Modify Register configuration to choose Speaker/Mic interface.             |
| Step 2 | Modifying the<br>MCLK Fre-<br>quency (MCLK<br>signal given to<br>the codec has a<br>frequency which<br>is basically N<br>times the Sam-<br>pling frequency.)                                                                                                                                                                 | Modifying the MCLK Frequency, as per operating require- ments of the new codec. (MCLK signal given to the codec has a frequency which is basically N times the Sampling frequency. Value N differs between codecs | Modifying the 12S Baud Rate according to the new bits/sam- ple value.                                                                                                                                                                                                                                                                                                        | Modify the I2S<br>registers to work<br>in Configuring<br>Mono Audio<br>Mode.                                                                                                                                                                                                                                                               | Modifying the Codec Initial-ization sequence to be identified by the user. |
| Step 3 | Clearing the ON and Active bits is required before the Reference Oscillator module registers can be modified. (IN/ OUT direction FIFOs accumulate the Audio samples, have High and Low threshold levels which are used for maintaining synchronization with the Host.The threshold levels depend on the Sampling frequency.) | Configure the CODEC Access Information.                                                                                                                                                                           | Clearing the ON and Active bits is required before the Reference Oscillator module registers can be modified. (IN/OUT direction FIFOs accumulate the Audio samples, have High and Low threshold levels which is used for maintaining synchronization with the Host. The threshold level depends on the Bits/Sample.  Also, the FIFO element Width changes with Sample Size.) | Clearing the ON and Active bits is required before the Reference Oscillator module registers can be modified. (IN/OUT direction FIFOs accumulate the Audio samples, have High and Low threshold levels which is used for maintaining synchronization with the Host. The threshold level depends on Number of Channel in the Audio stream.) |                                                                            |

# TABLE 3: AUDIO PARAMETERS CONFIGURATION (CONTINUED)

| Step 4 | Modifying the     | Match other require- | Modifying the Codec | Modifying the     | _ |  |
|--------|-------------------|----------------------|---------------------|-------------------|---|--|
|        | Codec Initializa- | ments of codec. For  | Initialization      | Codec Initializa- |   |  |
|        | tion sequence to  | example, I2S mode/   | sequence to support | tion sequence to  |   |  |
|        | support the new   | Left Justified/Right | the new Bit resolu- | support Mono      |   |  |
|        | Sampling fre-     | Justified modes      | tion.               | mode.             |   |  |
|        | quency.           |                      |                     |                   |   |  |

## 1.2.3 MODIFYING THE USB AUDIO DESCRIPTORS

## TABLE 4: USB DESCRIPTOR REGISTER DEFINITIONS FOR AUDIO OUT INTERFACE

| Register<br>Address | Parameter Name     | Size | Description                                                                 | Supported<br>Values                                         |
|---------------------|--------------------|------|-----------------------------------------------------------------------------|-------------------------------------------------------------|
| 0xBFD240BA          | Spkr_NrChannels    | 1    | The number of channels in the audio data stream.                            | Mono - 0x01<br>Stereo - 0x02                                |
| 0xBFD240BB          | Spkr_SubFrameSize  | 1    | The number of bytes occupied by one audio subframe (Sample).                | 0x02, 0x03, 0x04                                            |
| 0xBFD240BC          | Spkr_BitResolution | 1    | The number of effective bits from the available bits in the audio subframe. | 16, 24, 32                                                  |
| 0xBFD240BE          | Spkr_SamFreq       | 3    | Sampling frequency in Hertz for this asynchronous data endpoint. (48 kHz)   | 8, 16, 32, 44.1, 48<br>kHz (these are stan-<br>dard values) |
| 0xBFD240C5          | Spkr_MaxPacketSize | 2    | Maximum packet size for this endpoint.                                      | 0 to 1023 bytes                                             |

# TABLE 5: USB DESCRIPTOR REGISTER DEFINITIONS FOR AUDIO IN INTERFACE

| Register<br>Address | Parameter Name    | Size | Description                                                                 | Supported<br>Values                                        |
|---------------------|-------------------|------|-----------------------------------------------------------------------------|------------------------------------------------------------|
| 0xBFD240EE          | Mic_NrChannels    | 1    | The number of channels in the audio data stream.                            | Mono - 0x01<br>Stereo - 0x02                               |
| 0xBFD240EF          | Mic_SubFrameSize  | 1    | The number of bytes occupied by one audio subframe (Sample).                | 0x02, 0x03, 0x04                                           |
| 0xBFD240F0          | Mic_BitResolution | 1    | The number of effective bits from the available bits in the audio subframe. | 16, 24, 32                                                 |
| 0xBFD240F2          | Mic_SamFreq       | 3    | Sampling frequency in Hertz for this asynchronous data endpoint. (48 kHz)   | 8,16, 32, 44.1, 48<br>kHz (these are stan-<br>dard values) |
| 0xBFD240F9          | Mic_MaxPacketSize | 2    | Maximum packet size for this endpoint.                                      | 0 to 1023 bytes                                            |

#### 1.2.3.1 Sampling Frequency Customization in USB descriptor

When customizing the Sampling frequency, the following fields may require modification:

#### 1) Spkr SamFreq

This field is 24 bits in length, containing the hexadecimal value of the sampling frequency.

#### 2) Mic SamFreq

This field is 24 bits in length, containing the hexadecimal value of the sampling frequency.

#### 3) Spkr MaxPacketSize

This field requires modification because the amount of data received per second varies with the Sampling frequency variation. Refer to MaxPacketSize Calculation.

#### 4) Mic MaxPacketSize

This field requires modification because the amount of data received per second varies with the Sampling frequency variation. Refer to MaxPacketSize Calculation.

#### 1.2.3.2 Audio Sample Resolution Customization in USB descriptor

For customizing the Audio Sample Resolution, the following fields may require modification:

- 1) Spkr\_SubFrameSize: The sample length in Number of Bytes
- 2) Spkr BitResolution: The effective sample length in Number of Bits
- 3) Mic\_SubFrameSize: The sample length in Number of Bytes
- 4) Mic BitResolution: The effective sample length in Number of Bits

Additionally,

#### 1) Spkr MaxPacketSize

This field requires modification if the Sample length changes the Packet size. Refer to MaxPacketSize Calculation.

#### 2) Mic MaxPacketSize

This field requires modification if the Sample length changes the Packet size. Refer to MaxPacketSize Calculation.

#### 1.2.3.3 MaxPacketSize Calculation

Amount of Data received per millisecond = (Sampling Frequency \* Number of Bytes per Sample \* Number of Channels in the Audio stream) /1000

The USB Audio packet interval is 1 packet/ms as per the Audio endpoint descriptor Interval field.

For a 48 kHz, 16-bit Stereo Audio, the amount of Data received per ms = (48000 \* 2 \* 2)/1000 = 192 bytes/ms.

For a 44.1 kHz, 16-bit Stereo Audio, the amount of Data received per ms = 177 bytes/ms.

For the ISOC OUT direction, the audio stream (to the speaker), packet size does not vary. This is to maintain audio synchronization with the Host.

For the ISOC IN direction, the audio stream (from the microphone), packet size varies by few samples in order to maintain the synchronisation with the host. The maximum packet size of the ISOC IN endpoint can be derived from ISOC IN Endpoint Packet Size Calculations.

#### 1.2.4 MODIFYING THE MCLK FREQUENCY

MCLK is used by the I2S module to derive SCLK and LRCLK by frequency division. Some codecs also use the MCLK from the I2S Master as an internal clock for performing operations.

In general, MCLK signal expected by the codec will have a frequency that is some multiple of 256 times the sampling frequency. For example:

- 1) 256 times Sampling frequency
- 2) 512 times Sampling frequency

and so on.

# 1.2.4.1 Deriving MCLK

To derive the MCLK frequency from the source clock, the Reference Oscillator Control module is used.

MCLK frequency = Source clock frequency / (2 \* Division Factor(D))

The clock division factor (D) is divided into:

- 1) Integer divider (N)
- 2) Fractional divider (F)

The Reference Oscillator Control module has two registers:

- 1) Table 6 for configuring the Integer Division value
- 2) Table 7 for configuring the Fractional Division value

REFOCON Register contains the ON and Active Status and control bits, which protects the REFOCON Register and REFOTRIM Register from being modified unintentionally.

Note: Clearing the ON and Active bits is required before the Reference Oscillator module registers can be modi-

fied.

#### TABLE 6: REFOCON REGISTER

Address: 0xBF80A030

| Bit Position | Field                  | Permission | Description                                                                                                                                                                                               |
|--------------|------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31           | Reserved_31            | RO         | When writing to this register, this bit must be 0.                                                                                                                                                        |
| 30:16        | Integer Division value | RW         | 0 to 0x7FFF is allowed. The value entered here is Multiplied by 2 and taken for division.                                                                                                                 |
| 15           | ON                     | RW         | 1 = Reference Oscillator Module is enabled<br>0 = Reference Oscillator Module is disabled                                                                                                                 |
| 14           | Reserved               | RW         | When writing to this register, this bit must be 0.                                                                                                                                                        |
| 13           | Reserved               | RW         | When writing to this register, this bit must be 0.                                                                                                                                                        |
| 12           | Reserved               | RW         | When writing to this register, this bit must be 0.                                                                                                                                                        |
| 11           | Reserved               | RW         | When writing to this register, this bit must be 0.                                                                                                                                                        |
| 10           | Reserved               | RO         | When writing to this register, this bit must be 0.                                                                                                                                                        |
| 9            | Reserved               | RW         | When writing to this register, this bit must be 0.                                                                                                                                                        |
| 8            | Active                 | RW         | Reference Clock Request Status bit 1 = Reference clock request is active (User should not update this REFOCON register) 0 = Reference clock request is not active (User can update this REFOCON register) |
| 7:4          | Reserved               | RO         | When writing to this register, this bit must be 0.                                                                                                                                                        |

TABLE 6: REFOCON REGISTER

Address: 0xBF80A030

| Bit Position | Field        | Permission | Description                                                                                                                                                                             |
|--------------|--------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0          | Source_Clock | RW         | Reference Clock Source Select bits. Select one of various clock sources to be used as the reference clock. 0100 - 1111 =Reserved  0011 = osc_clk[4] - 240Mhz USB Clock/2 (Usually POSC) |
|              |              |            | 0010 = osc_clk[3] - 120Mhz USB Clock/4<br>(Usually POSC)<br>0001 = osc_clk[2] - 96Mhz USB Clock/5                                                                                       |
|              |              |            | 0000 = osc_clk[1] - 60Mhz System Clock                                                                                                                                                  |

# TABLE 7: REFOTRIM REGISTER

Address: 0xBF80A034

| Bit Position | Field                                               | Permission | Description                                                                                      |
|--------------|-----------------------------------------------------|------------|--------------------------------------------------------------------------------------------------|
| 31:20        | Value equivalent to fractional divisor. (=4096 * F) | RW         | Trim bits - Provides fractional additive to Integer division value for 1/2 period of REFO clock: |
|              |                                                     |            | 0000_0000_0000 = 0/4096 (0.0) divisor added to Integer division value                            |
|              |                                                     |            | 0000_0000_0001 = 1/4096 (0.0002441) divisor added to Integer division value                      |
|              |                                                     |            | 1000_0000_0000 = 2048/4096 (0.500000) divisor added to Integer division value                    |
|              |                                                     |            | 1111_1111_1110 = 4094/4096 (0.9995117) divisor added to Integer division value                   |
|              |                                                     |            | 1111_1111_1111 = 4095/4096 (0.9997559) divisor added to Integer division value                   |
| 19:0         | Reserved                                            | RO         | When writing to this register, these bits must be 0.                                             |

#### 1.2.5 MODIFYING THE FIFO THRESHOLD VALUES

USB Audio interface has 2 endpoints: Isochoronous IN direction and Isochoronous OUT direction.

- Data received on the ISOC Out endpoint is stored in the I2S\_OUT\_FIFO and transferred through the I2S bus to the codec.
- Data received from the I2S bus is stored in the I2S\_IN\_FIFO and transferred through the ISOC IN endpoint to the host.

Size of basic element in the FIFO is either 16 or 32 bits and it is configurable through the Table 13 field FIFO Element mode. Verifying this field is necessary when the Audio Sample Resolution is modified.

## 1.2.5.1 Threshold Setting for ISOC\_OUT\_FIFO

The host will send the same amount of data on every frame. For example, 48 kHZ of data based on the host clock. The codec sampling clock is asynchronous to the host clock. This will cause the amount of data in the OUT FIFO to vary. If the amount of data in the FIFO exceeds the high threshold, then the sampling clock is decreased. If the data is between the high and low thresholds, the sampling clock does not change. If the data falls below the low threshold, the sampling clock is increased.

ISOC Packet interval = 1 ms

Number of Samples in 1 packet = ((Sampling Frequency) /1000)

ISOC\_OUT\_FIFO contains 512 elements, refer to Table 13 for settings.

Number of Packets FIFO can hold = 512 / (Number of Samples in 1 packet)

It is desirable to operate with data filled up to 50% of the FIFO size. Until then, transmission through I2S will not start. The Out-start level of the FIFO can be configured in OUT\_START\_THRESHOLD parameter of Table 15 register.

OUT\_START\_THRESHOLD = (Number of Packets FIFO can hold / 2) \* (Number of Samples in 1 packet)

Maximum drift considered for the USB Packet arrival interval is 1 ms. To monitor this drift, the FIFO is marked with high and low thresholds.

OUT\_FIFO\_LOW\_THRESHOLD = (OUT\_START\_THRESHOLD - Number of Samples in 1 packet)
OUT\_FIFO\_HIGH\_THRESHOLD = (OUT\_START\_THRESHOLD + Number of Samples in 1 packet)

Note: Refer to Table 14 and Table 15 for configuring the threshold values.

## 1.2.5.2 Threshold Setting for ISOC\_IN\_FIFO

The data from the codec is fed into ISOC\_IN\_FIFO. Because the sampling clock is asynchronous to the host clock, the amount of data captured in every USB frame will vary. This is a problem left to the host to deal with. The input FIFO has two markers, a low threshold (THRESHOLD\_LOW\_VAL) and a high threshold (THRESHOLD\_HIGH\_VAL). There are three registers to determine how much data to be sent back in each frame. If the amount of data in the FIFO exceeds the high threshold, then HI\_PKT\_SIZE worth of data is sent. If the data is between the high and low thresholds, the normal MID\_PKT\_SIZE amount of data is sent. If the data is below the low threshold, LO\_PKT\_SIZE worth of data is sent.

ISOC Packet interval = 1 ms

Number of Samples recorded in 1 ms = ((Sampling Frequency) /1000)

ISOC\_IN\_FIFO contains 512 elements, refer to Table 13 for settings.

Number of Packets FIFO can hold = 512 / (Number of Samples in 1 ms)

It is desirable to operate with data filled up to 50% of the FIFO size. Until then, transmission through USB ISOC endpoint will not start. The IN-start level of the FIFO can be configured in IN\_START\_THRESHOLD parameter of Table 16 register

IN\_START\_THRESHOLD = (Number of Packets FIFO can hold / 2) \* (Number of Samples per millisecond)

Maximum drift considered for the design is 1 ms. To monitor this drift, FIFO is marked with high and low thresholds.

IN\_FIFO\_HIGH\_THRESHOLD = (IN\_START\_THRESHOLD - Number of Samples per millisecond)
IN\_FIFO\_HIGH\_THRESHOLD = (IN\_START\_THRESHOLD + Number of Samples per millisecond)

**Note:** Refer to Table 16 and Table 17 for configuring the threshold values.

#### 1.2.5.3 ISOC IN Endpoint Packet Size Calculations

Normal packet size of the ISOC In endpoint, when the data is between the high and low threshold levels is MID-SIZE PACKET.

MIDSIZE PACKET = ((Number of samples per millisecond) \* (Number of Audio channels) \* (Bytes per sample)).

Adjust for drift by adding or subtracting the number of samples recorded in interval of a micro frame,

HIGH\_SIZE\_PACKET = ((MID\_SIZE\_PACKET) + (((Number of samples per 125 uS) \* (Number of Audio channels) \* (Bytes per sample)))

#### 1.2.6 MODIFYING THE 12S BAUD RATE

MCLK is used as the source clock for deriving the I2S SCLK and I2S LRCLK in the I2S Master mode.

SCLK frequency = ((Sampling frequency) \* (Bits per Sample) \* (Number of channels in the Audio))

Refer to Table 21 for configuring the Division factor.

#### 1.2.7 MODIFYING THE CODEC INITIALIZATION

The communication between the audio codec and the UDC is established over two protocols,

- 1) I2S interface through which the Audio data is transferred.
- 2) I2C interface for executing the Initialization and Control operations.

#### 1.2.7.1 Modifying the codec Initialization

The external codec chip is configured through the I2C interface during the initialization phase. The initialization procedure is a sequence of Register configurations identified from the codec data sheet.

The codec Initialization buffer provides memory for storing the data of maximum 75 I2C transactions. Each such I2C transaction can carry up to 11 bytes of data excluding the Slave address.

The organisation of the codec Initialization buffer is mentioned in Table 8. The Byte 0 field indicates the number of the data bytes going to be present in that I2C transaction.

By default, device firmware will contain a list of transactions in the CODEC Initialization Buffer. The values of registers and the order that they are written are not the same for all devices and may change in different firmware releases. In developing a list of transactions for the CODEC Initialization Buffer, it is advisable to observe the default initialization sequence on the I2C bus with an I2C analyzer. This will reveal the default CODEC Initialization Buffer contents. If any of the default transactions are not desired, then that transaction is removed by writing over that transaction in the buffer. The best practice is to always create a complete transaction list that is the same length or longer than the default list.

TABLE 8: CODEC INITIALIZATION BUFFER

Base-Address: 0xBFD23C00

| Address Offset | BYTE 0 - (Maximum up to 11) | BYTE 1 to BYTE 11                                     |  |
|----------------|-----------------------------|-------------------------------------------------------|--|
| 0x00           | Length of Transaction 1     | Register Address in the codec + Data to be configured |  |
| 0x0C           | Length of Transaction 2     | Register Address in the codec + Data to be configured |  |
| 0x18           | Length of Transaction 3     | Register Address in the codec + Data to be configured |  |
| :              | Length of Transaction 4     | Register Address in the codec + Data to be configured |  |
| ÷              | Length of Transaction 5     | Register Address in the codec + Data to be configured |  |
| :              | Length of Transaction 6     | Register Address in the codec + Data to be configured |  |
| :              | Length of Transaction 7     | Register Address in the codec + Data to be configured |  |
|                |                             |                                                       |  |
| 0x378          | Length of Transaction 75    | Register Address in the codec + Data to be configured |  |

# 1.2.7.2 CODEC Access Information

The codec information buffer contains:

- The pointers to the codec volume and MUTE registers, which are accessed when volume change and mute operations are done from the host.
- The volume range and volume resolution information, which are sent to the host upon Get\_Max, Get\_Min, Get\_Resolution requests.

TABLE 9: CODEC INFORMATION BUFFER

Base-Address: 0xBFD23780

| Field                                                      | Address<br>Offset | Size in Bytes | Value                                                                                                             |
|------------------------------------------------------------|-------------------|---------------|-------------------------------------------------------------------------------------------------------------------|
| Speaker Left Channel Volume<br>Control - Register Address  | 0                 | 4             | Codec Register Address of Left Channel<br>Speaker Volume control                                                  |
| Speaker Right Channel Volume<br>Control - Register Address | 4                 | 4             | Codec Register Address of Left Channel Speaker Volume control                                                     |
| Speaker Left Channel Volume<br>Mute - Register Address     | 8                 | 4             | Codec Register Address of Left Channel Speaker MUTE control                                                       |
| Speaker Right Channel Volume<br>Mute - Register Address    | 0x0c              | 4             | Codec Register Address of Left Channel Speaker MUTE control                                                       |
| Speaker Volume dB Resolution Value                         | 0x10              | 4             | Minimum change that can be produced in the Volume, expressed in dB. (IEEE754 representation for hex value)        |
| Reserved                                                   | 0x14              | 8             | NA                                                                                                                |
| I2C control Interface - Clock frequency to be used         | 0x1C              | 2             | Value:<br>1) 0x0A0D for 400 kHz<br>2) for 100 kHz                                                                 |
| Least volume that can be produced by the Speaker           | 0x1E              | 2             | Minimum volume supported by the codec in dB                                                                       |
| Maximum volume that can be produced by the Speaker         | 0x20              | 2             | Maximum volume supported by the codec in dB                                                                       |
| Register Value equivalent of 0dB volume                    | 0x22              | 2             | codec Volume Register value to be configured in order to get the 0dB volume in speaker                            |
| Initial Left Channel volume to be set                      | 0x24              | 2             | Initial volume level for the left channel in dB                                                                   |
| Initial Right Channel volume to be set                     | 0x26              | 2             | Initial volume level for the right channel in dB                                                                  |
| RESERVED2                                                  | 0x28              | 2             | NA                                                                                                                |
| I2C Slave Address of the codec                             | 0x2C              | 1             | 7-bit hardware slave address of codec                                                                             |
| Initialization sequence ount                               | 0x2D              | 1             | Specifies the number of transactions that are present in the "codec Initialization Buffer" (a hexadecimal number) |
| Codec Register Address Width                               | 0x2E              | 1             | 1 - Byte<br>2 - Word (2 bytes)<br>4- double word (4 bytes)                                                        |
| Codec Register value field Width                           | 0x2F              | 1             | 1 - Byte<br>2 - Word (2 bytes)<br>4- double word (4 bytes)                                                        |
| Codec Volume Register Bit Size                             | 0x30              | 1             | Number of bits in the (Left/Right) volume control register used as Volume field                                   |

# TABLE 9: CODEC INFORMATION BUFFER

Base-Address: 0xBFD23780

| Field                                                                                                       | Address<br>Offset | Size in Bytes | Value                                                                 |
|-------------------------------------------------------------------------------------------------------------|-------------------|---------------|-----------------------------------------------------------------------|
| Codec MUTE Register Bit Value                                                                               | 0x31              | 1             | 0 - LOGIC HIGH indicates MUTE<br>(or)<br>1- LOGIC LOW Indicates MUTES |
| Start bit of the Left channel volume field in the Left Channel Volume Control register of codec             | 0x32              | 1             | Start Bit value                                                       |
| Start bit of the Right channel vol-<br>ume field in the Right Channel Vol-<br>ume Control register of codec | 0x33              | 1             | Start Bit value                                                       |
| Start bit of the Left channel MUTE field in the Left Channel MUTE Control register of codec                 | 0x34              | 1             | Start Bit value                                                       |
| Start bit of the Right channel MUTE field in the Right Channel MUTE Control register of codec               | 0x34              | 1             | Start Bit value                                                       |
| ADAU1961                                                                                                    | 0x35              | 1             | 1 - The codec is ADAU1961<br>0 - A different codec is used            |

## 1.2.7.3 Volume Control Parameters

Codecs generally have registers for volume control operation.

Table 10 explains the example of AK4642EN codec for which Register value vs Volume in dB relation is mentioned.

TABLE 10: VOLUME CONTROL PARAMETERS FOR AK4642EN

| DVL/R7-0 | Gain in (dB) | Parameters required in Codec Access information buffer        |
|----------|--------------|---------------------------------------------------------------|
| 00H      | +12.0 dB     | Maximum volume that can be produced by the Speaker            |
| 01H      | +11.5 dB     | -                                                             |
| 02H      | +11.0 dB     | _                                                             |
| :        | :            | _                                                             |
| 18H      | 0 dB         | Register Value equivalent of 0 dB volume                      |
| :        | :            | _                                                             |
| FDH      | -114.5 dB    | _                                                             |
| FEH      | +115.0 dB    | Minimum achievable volume that can be produced by the Speaker |

The following can be inferred from Table 10:

- 1. Volume increases with decrease in Register Value (Indirectly proportional). By default, such codecs are not supported by Microchip I2S Bridges. This requires an **OTP PATCH** for implementing this requirement. Codecs in which register value and Volume are directly proportional will be supported by the default firmware.
- 2. The relationship between the register values and volume is linear. Only codecs with linear volume-to-Register value relationship are be supported by the default firmware. A non-linear relationship requires an OTP patch.
- 3. The volume resolution is 0.5 dB.

# 1.2.8 MISCELLANEOUS SETTINGS

#### 1.2.8.1 Enabling and Disabling I2S Bridge Interfaces

I2S Bridge allows control of additional settings:

TABLE 11: Enable/Disable I2S Address: 0xBFD23412; Size: 1 Byte

| Setting                    | Value          |
|----------------------------|----------------|
| USB - I2S Bridge disable   | 0x00           |
| Only Audio IN Mode         | 0x01           |
| Only Audio Out Mode        | 0x02           |
| Both Audio IN and Out Mode | 0x03 (Default) |

## TABLE 12: ENABLING/DISABLE THE HID INTERFACE FOR MIKE\_DETECT

Address: 0xBFD23413; Size: 1 Byte

| Setting                              | Value          |
|--------------------------------------|----------------|
| MIKE-Detection HID Interface disable | 0x00           |
| Mute/Unmute Audio IN Mode            | 0x01           |
| Mute/Unmute Audio Out Mode           | 0x02           |
| Mute/Unmute Audio IN and Out Mode    | 0x03 (Default) |

#### 1.2.8.2 Modifying the I2S Modes

#### 1.2.8.3 Mode I2S

In I2S mode, the transmitter drives the MSB of the audio data on the first falling edge of SCK after an LRC transition. The receiver samples the MSB on the second rising edge of SCK. The left channel data transmits while LRC is low, and the right channel transmits while LRC is high. A frame transmits left channel first then right channel.

To be I2S-compliant, the configuration bits in SPIxCON2 must be set as follows:

AUDMOD = 00, FRMPOL = 0, CKP = 1.

These values cause SDO and LRC transitions to occur on the falling edge of SCK and sampling of SDI to occur on the rising edge of SCK. It also starts a frame with LRC falling edge transition. The Register configuration field is present in Table 22 register.

#### 1.2.8.4 Mode Left Justified

In Left Justified mode, the transmitter drives the MSB of the audio data on the SCK edge that is coincident with an LRC transition. The receiver samples the MSB on the next SCK edge. Codecs using justified protocols usually default to transmitting data on the rising edge of SCK and receiving data on the falling edge of SCK. Another convention is that LRC is high for the left channel and low for the right channel which is opposite of I2S. But they maintain left channel followed by right channel (in a frame).

To configure for the left justified standard convention, set the following bits in SPXIxCON as follows:

AUDMOD = 01, FRMPOL = 1, CKP = 0.

These fields are present in Table 22 register.

## 1.2.8.5 Mode Right Justified

In Right Justified mode, the transmitted drives the MSB of the audio data on the n<sup>th</sup> transmit edge of SCK, such that the LSB is available on the receive edge of SCK, preceding a transition of LRC. When set to transmit (DISSDO = 0), this device drives the unused bit slots (preceding the audio) with logic level 0. When set to receive (DISSDI = 0), this device ignores the unused bit slot. Right Justified mode configured as follows:

AUDIOD = 10, FRMPOL = 1, CKP= 0.

These fields are present in Table 22 register.

# 1.2.8.6 Configuring Mono Audio Mode

The Audio Protocol function can transmit mono audio data on both the left and right channels. When AUDMONO = 1, the shift register uses each FIFO location twice. This gives each channel the same mono stream of audio data. When AUDMONO = 0, the shift register uses each FIFO location once. This gives each channel a unique stream of data for stereo audio. Receive data is not affected by AUDMONO.

This bit is present in Table 22 register.

# 1.2.9 CONFIGURATION REGISTERS

# **TABLE 13: SPIXCON REGISTER**

Address: 0xBF80A040

| Field                                                                                                 | Permission                                                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| frmen                                                                                                 | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| frmsync                                                                                               | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| frmpol                                                                                                | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| mssen                                                                                                 | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| frmsypw                                                                                               | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| frmcnt                                                                                                | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| mclken                                                                                                | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| reserved_22_18                                                                                        | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| spife                                                                                                 | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| enhbuf                                                                                                | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| on                                                                                                    | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| frz                                                                                                   | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| sidl                                                                                                  | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| dissdo                                                                                                | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| FIFO Element mode                                                                                     | RW -<br>NOTE: To avoid<br>changing Reserved<br>bits, use the SetBit<br>and ClearBit features<br>of MPLAB Connect | 1 1 => 32-bit FIFO element, with Audio Sample effective size = 24 bits, Number of bits per channel = 32 (Refer SubFrameSize in USB Audio descriptor) 1 0 => 32-bit FIFO element, with Audio Sample effective size = 32 bits, Number of bits per channel = 32 (Refer SubFrameSize in USB Audio descriptor) 0 1 => 16-bit FIFO element, with Audio Sample effective size = 16 bits, Number of bits per channel = 32 (Refer SubFrameSize in USB Audio descriptor) 0 0 => 16-bit FIFO element, with Audio Sample effective size = 16 bits, Number of bits per channel = 16 (Refer SubFrameSize in USB |
|                                                                                                       |                                                                                                                  | Audio descriptor)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| smp                                                                                                   | Reserved                                                                                                         | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| smp<br>cke                                                                                            | Reserved<br>Reserved                                                                                             | Strictly do not modify Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| •                                                                                                     | Reserved<br>Reserved                                                                                             | Strictly do not modify Strictly do not modify Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| cke                                                                                                   | Reserved                                                                                                         | Strictly do not modify Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| cke<br>ssen                                                                                           | Reserved<br>Reserved                                                                                             | Strictly do not modify Strictly do not modify Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| cke<br>ssen<br>ckp                                                                                    | Reserved Reserved                                                                                                | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| cke<br>ssen<br>ckp<br>msten                                                                           | Reserved Reserved Reserved Reserved                                                                              | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| cke<br>ssen<br>ckp<br>msten<br>dissdi                                                                 | Reserved Reserved Reserved Reserved Reserved                                                                     | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| cke ssen ckp msten dissdi stxisel                                                                     | Reserved Reserved Reserved Reserved Reserved Reserved                                                            | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                           |
| cke ssen ckp msten dissdi stxisel srxisel                                                             | Reserved Reserved Reserved Reserved Reserved Reserved Reserved Reserved                                          | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                           |
| cke ssen ckp msten dissdi stxisel srxisel fifo_full                                                   | Reserved Reserved Reserved Reserved Reserved Reserved Reserved Reserved Reserved                                 | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                           |
| cke ssen ckp msten dissdi stxisel srxisel fifo_full fifo_threshold_high                               | Reserved Reserved Reserved Reserved Reserved Reserved Reserved Reserved Reserved RO                              | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                           |
| cke ssen ckp msten dissdi stxisel srxisel fifo_full fifo_threshold_high fifo_threshold_low            | Reserved Reserved Reserved Reserved Reserved Reserved Reserved Reserved RO RO                                    | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                                           |
| cke ssen ckp msten dissdi stxisel srxisel fifo_full fifo_threshold_high fifo_threshold_low fifo_empty | Reserved Reserved Reserved Reserved Reserved Reserved Reserved Reserved RO RO RO                                 | Strictly do not modify                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                       | frmen frmsync frmpol mssen frmsypw frmcnt mclken reserved_22_18 spife enhbuf on frz sidl dissdo                  | frmen Reserved frmsync Reserved frmpol Reserved mssen Reserved frmsypw Reserved frmcnt Reserved mclken Reserved reserved_22_18 Reserved enhbuf Reserved on Reserved frz Reserved sidl Reserved frz Reserved FIFO Element mode  Reserved RW - NOTE: To avoid changing Reserved bits, use the SetBit and ClearBit features                                                                                                                                                                                                                                                                          |

TABLE 14: OUT\_FIFO\_THRESHOLD\_CTL

Address: 0xBF80A000

| Bit Position | Field               | Permission | Description            |
|--------------|---------------------|------------|------------------------|
| 31           | out_enable          | RW         | Strictly do not modify |
| 30           | out_started         | RW         | Strictly do not modify |
| 29:13        | reserved_29_13      | RO         | Strictly do not modify |
| 12           | out_swap            | RW         | Strictly do not modify |
| 11           | mcu_access_enable   | RW         | Strictly do not modify |
| 10           | dma_access_enable   | RW         | Strictly do not modify |
| 9            | enable              | RW         | Strictly do not modify |
| 8:0          | out_threshold_start | RW         | OUT_THRESHOLD_START    |

TABLE 15: OUT\_FIFO\_START\_CTL

Address: 0xBF80A004

| Bit Position | Field               | Permission | Description            |
|--------------|---------------------|------------|------------------------|
| 31           | out_enable          | RW         | Strictly do not modify |
| 30           | out_started         | RW         | Strictly do not modify |
| 29:13        | reserved_29_13      | RO         | Strictly do not modify |
| 12           | out_swap            | RW         | Strictly do not modify |
| 11           | mcu_access_enable   | RW         | Strictly do not modify |
| 10           | dma_access_enable   | RW         | Strictly do not modify |
| 9            | enable              | RW         | Strictly do not modify |
| 8:0          | out_threshold_start | RW         | OUT_THRESHOLD_START    |

TABLE 16: IN\_FIFO\_START\_CTL

Address: 0xBF80A004C

| Bit Position | Field              | Permission | Description            |
|--------------|--------------------|------------|------------------------|
| 31           | in_enable          | RW         | Strictly do not modify |
| 30           | in_started         | RW         | Strictly do not modify |
| 29:13        | reserved_29_13     | RO         | Strictly do not modify |
| 12           | in_swap            | RW         | Strictly do not modify |
| 11           | mcu_access_enable  | RW         | Strictly do not modify |
| 10           | dma_access_enable  | RW         | Strictly do not modify |
| 9            | enable             | RW         | Strictly do not modify |
| 8:0          | in_threshold_start | RW         | IN_THRESHOLD_START     |

# TABLE 17: IN\_FIFO\_THRESHOLD\_CTL

Address: 0xBF80A008

| Bit Position | Field               | Permission | Description            |
|--------------|---------------------|------------|------------------------|
| 31           | fifo_enable         | RO         | _                      |
| 30           | fifo_threshold_high | RO         | _                      |
| 29           | fifo_threshold_high | RO         | _                      |
| 28           | fifo_empty          | RO         | _                      |
| 27:19        | threshold_high_val  | RW         | IN_FIFO_HIGH_THRESHOLD |
| 18:10        | threshold_low_val   | RW         | IN_FIFO_LOW_THRESHOLD  |
| 9:0          | occupied            | RO         | _                      |

# TABLE 18: IN\_ENDPOINT\_HIGHPACKET\_SIZE

Address: 0xBF80A010

| Bit Position | Field          | Permission | Description      |
|--------------|----------------|------------|------------------|
| 31:10        | reserved_31_10 | RO         | Write 0s         |
| 9:0          | hi_pkt_size    | RW         | HIGH_PACKET_SIZE |

# TABLE 19: IN\_ENDPOINT\_MIDPACKET\_SIZE

Address: 0xBF80A014

| Bit Position | Field          | Permission | Description     |
|--------------|----------------|------------|-----------------|
| 31:10        | reserved_31_10 | RO         | Write 0s        |
| 9:0          | mid_pkt_size   | RW         | MID_PACKET_SIZE |

# TABLE 20: IN\_ENDPOINT\_LOWPACKET\_SIZE

Address: 0xBF80A014

| Bit Position | Field          | Permission | Description     |
|--------------|----------------|------------|-----------------|
| 31:10        | reserved_31_10 | RO         | Write 0s        |
| 9:0          | low_pkt_size   | RW         | LOW_PACKET_SIZE |

# TABLE 21: I2S\_BAUDRATE\_GENERATOR

Address: 0xBF80A070

| Bit Position | Field          | Permission | Description                                                             |
|--------------|----------------|------------|-------------------------------------------------------------------------|
| 31:10        | reserved_31_13 | RO         | Reserved Write 0s                                                       |
| 9:0          | BRG            | RW         | BRG value is such that,<br>Baudrate = (MCLK Frequency) / (2* (BRG + 1)) |

TABLE 22: SPICON2 Address: 0xBF80A080

| Bit Position | Field          | Permission | Description                                                                                                     |
|--------------|----------------|------------|-----------------------------------------------------------------------------------------------------------------|
| 31:16        | Reserved_31_16 | RO         | Strictly do not modify                                                                                          |
| 15           | spisgnext      | RW         | Strictly do not modify                                                                                          |
| 14:13        | Reserved_14_13 | RW         | Strictly do not modify                                                                                          |
| 12           | frmerren       | RW         | Strictly do not modify                                                                                          |
| 11           | spiroven       | RO         | Strictly do not modify                                                                                          |
| 10           | spituren       | RW         | Strictly do not modify                                                                                          |
| 9            | ignrov         | RW         | Strictly do not modify                                                                                          |
| 8            | igntur         | RW         | Strictly do not modify                                                                                          |
| 7            | auden          | RW         | Strictly do not modify                                                                                          |
| 6:4          | Reserved_6_4   | RO         | Strictly do not modify                                                                                          |
| 3            | audmono        | RW         | 1 = Audio Data is Mono (Each data word is transmitted on both left and right channels) 0 = Audio Data is Stereo |
| 2            | Reserved_2     | RO         | Strictly do not modify                                                                                          |
| 1:0          | audmod         | RW         | Audio Protocol mode 11 = PCM/DSP mode 10 = Right Justified mode 01 = Left Justified mode 00 = I2S mode          |

# 1.3 Sample Codec Configuration - Following the Guidelines

By default, the I2S Bridge is configured to operate with the ADAU1961 codec as shown in Table 23. Table 24 shows how to configure the I2S Bridge for an alternative codec, the AK4642EN.

TABLE 23: CODEC INITIALIZATION SEQUENCE FOR AK4642 CODEC

| Address | Byte - 0 (Length of the I2C transaction) | Byte 1 (Register Address in the AKM Codec) | Byte 2 (Register<br>Configuration value) |
|---------|------------------------------------------|--------------------------------------------|------------------------------------------|
| 0x00    | 2                                        | 0x5                                        | 0x23                                     |
| 0x0C    | 2                                        | 0x0F                                       | 0x1                                      |
| 0x18    | 2                                        | 0x0E                                       | 0x1                                      |
| 0x24    | 2                                        | 0x9                                        | 0x91                                     |
| 0x30    | 2                                        | 0x0C                                       | 0x91                                     |
| 0x3c    | 2                                        | 0x0A                                       | 0x18                                     |
| 0x48    | 2                                        | 0x0D                                       | 0x18                                     |
| 0x54    | 2                                        | 0x0                                        | 0x6D                                     |
| 0x60    | 2                                        | 0x1                                        | 0x39                                     |
| 0x6c    | 2                                        | 0x1                                        | 0x79                                     |
| 0x78    | 2                                        | 0x2                                        | 0x14                                     |
| 0x84    | 2                                        | 0x4                                        | 0x3                                      |
| 0x90    | 2                                        | 0x10                                       | 0x27                                     |

TABLE 24: CODEC INFORMATION BUFFER (FOR AK4642EN)

| Field                                                          | Address Offset | Value   | Description                                                                                                                         |
|----------------------------------------------------------------|----------------|---------|-------------------------------------------------------------------------------------------------------------------------------------|
| Speaker Left channel vol-<br>ume control - Register<br>Address | 0              | 0xA     | AK4642_REG_LDAC_VOL                                                                                                                 |
| Speaker Right channel<br>volume control - Register<br>Address  | 4              | 0x0D    | AK4642_REG_RDAC_VOL                                                                                                                 |
| Speaker Left Channel<br>Mute - Register Address                | 8              | 0x0E    | AK4642_REG_MODE_CTRL3                                                                                                               |
| Speaker Right Channel<br>Mute - Register Address               | 0x0c           | 0x0E    | AK4642_REG_MODE_CTRL3                                                                                                               |
| Speaker Volume dB resolution value                             | 0x10           | 0.5 dB  | Resolution of the volume is 0.5 db (Use IEEE754 representation for hex value https://www.h-schmidt.net/FloatConverter/IEEE754.html) |
| Reserved                                                       | 0x14           | NA      | Reserved                                                                                                                            |
| I2C control Interface -<br>Clock frequency to be<br>used       | 0x1C           | 0x0A0D  | 400 kHz I2C frequency                                                                                                               |
| Least volume that can be produced by the Speaker               | 0x1E           | -115 dB | Least achievable volume is -115 dB                                                                                                  |
| Maximum volume that can be produced by the Speaker             | 0x20           | 12 dB   | 0 dB volume corresponds to value 12 in the volume control register                                                                  |
| Register Value equivalent of 0 dB volume                       | 0x22           | 12 dB   | 0 dB volume corresponds to value 12 in the volume control register                                                                  |
| Initial Left Channel vol-<br>ume to be set                     | 0x24           | 0x60    | -9 dB is the initial volume                                                                                                         |

TABLE 24: CODEC INFORMATION BUFFER (FOR AK4642EN)

| Field                                                                                                           | Address Offset | Value | Description                                                                                                                                    |
|-----------------------------------------------------------------------------------------------------------------|----------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Initial Right Channel vol-<br>ume to be set                                                                     | 0x26           | 0x60  | -9 dB is the initial volume                                                                                                                    |
| RESERVED2                                                                                                       | 0x28           | NA    | reserved                                                                                                                                       |
| I2C Slave Address of the external codec (7bit address)                                                          | 0x2C           | 0x13  | Slave address of AKM codec                                                                                                                     |
| Initialization sequence count                                                                                   | 0x2D           | 13    | Number of I2C transaction required to initialize the AKM codec                                                                                 |
| Codec Register Address<br>Width                                                                                 | 0x2E           | 1     | Codec register width is 1 byte                                                                                                                 |
| Codec Register Value<br>Field Width                                                                             | 0x2F           | 1     | Codec register address size is 1 byte                                                                                                          |
| Codec Volume Register<br>Bit Size                                                                               | 0x30           | 8     | Speaker volume is 8-bit register value<br>Range 0-255                                                                                          |
| Codec MUTE Register<br>Bit Value                                                                                | 0x31           | 1     | <ul><li>0 - If the Bit is Set to Logic High Mute is implemented.</li><li>1- If the Bit is set to Logic low then mute is implemented.</li></ul> |
| Start bit of the Left chan-<br>nel volume field in the<br>Left Channel Volume<br>Control register of codec      | 0x32           | 0     | Starts in Bit 0                                                                                                                                |
| Start bit of the Right<br>channel volume field in<br>the Right Channel Vol-<br>ume Control register of<br>codec | 0x33           | 0     | Starts in Bit 0                                                                                                                                |
| Start bit of the Left chan-<br>nel MUTE field in the Left<br>Channel MUTE Control<br>register of codec          | 0x34           | 5     | Mute position is Bit 5                                                                                                                         |
| Start bit of the Right<br>channel MUTE field in the<br>Right Channel MUTE<br>Control register of codec          | 0x35           | 5     | Mute position is Bit 5                                                                                                                         |
| Is the codec - ADAU<br>1961                                                                                     | 0x36           | 0     | 0 - Different codec chip                                                                                                                       |

**Note:** In AK4642, Volume decreases with increase in Register Value, which is not supported by USB49xx. It requires a firmware OTP patch to fix the volume control operation, which is not included in this document.

# 1.4 Sample Configuration for Audio Sampling Frequency Change

Table 25 shows examples of changing the sampling frequency to 8 kHz.

TABLE 25: CHANGING THE SAMPLING FREQUENCY TO 8 KHZ

| Parameter                    | Address                              | Size in<br>Bytes | Value                  | What it means                 | Description                                                            |  |  |
|------------------------------|--------------------------------------|------------------|------------------------|-------------------------------|------------------------------------------------------------------------|--|--|
|                              | USB Audio Descriptor related changes |                  |                        |                               |                                                                        |  |  |
| tSamFreq (I2S IN)            | 0xBFD240F2                           | 3                | 40 1F 00               | 8 kHz                         | Sampling frequency IN direction                                        |  |  |
| tSamFreq (I2S OUT)           | 0xBFD240BE                           | 3                | 40 1F 00               | 8 kHz                         | Sampling frequency IN direction                                        |  |  |
| Max packet size IN direction | 0xBFD240F9                           | 2                | 0x28 0x00              | 40 bytes                      | Endpoint descriptor's, Maximum packet size                             |  |  |
| Max packet size IN direction | 0xBFD240C5                           | 2                | 0x28 0x00              | 40 bytes                      | Endpoint descriptor's, Maximum packet size                             |  |  |
|                              | Register setting                     | gs for I2S       | N direction to op      | erate in 8 kHz                | !                                                                      |  |  |
| IN Start threshold           | 0xBF80A002                           | 4                | 0x00 0x07 0x00<br>0xc0 | 256<br>Samples                | Bits 0-8 Start threshold value                                         |  |  |
| IN High threshold            | 0xBF80A008                           | 4                | 0x00 0xE0 0x43<br>0x08 | 264<br>Samples                | Bits 19-27 High threshold value                                        |  |  |
| IN Low threshold             |                                      |                  |                        | 248<br>Samples                | Bits 10-18 Low threshold value                                         |  |  |
| IN Mid Packet size           | 0xBF80A014                           | 4                | 0x20                   | 32 bytes                      | _                                                                      |  |  |
| IN High Packet size          | 0xBF80A010                           | 4                | 0x24                   | 36 bytes                      | _                                                                      |  |  |
| IN Low Packet size           | 0xBF80A018                           | 4                | 0x1C                   | 28 bytes                      | _                                                                      |  |  |
|                              | Register settings                    | s for I2S O      | UT direction to o      | perate in 8 kH                | lz                                                                     |  |  |
| Out Start threshold          | 0xBF80A004                           | 4                | 0x00 0x07<br>0x00 0x00 | 256<br>Samples                | Bits 0-8 Start threshold value                                         |  |  |
| Out High threshold           | 0xBF80A000                           | 4                | 0x00 0xE0<br>0x43 0x08 | 248<br>Samples                | Bits 19-27 High threshold value                                        |  |  |
| Out Low threshold            |                                      |                  |                        | 264<br>Samples                | Bits 10-18 Low threshold value                                         |  |  |
|                              | Frequency rela                       | ited regist      | er settings for 8 k    | Hz operation                  |                                                                        |  |  |
| REFOCONN                     | 0xBF80A030                           | 4                | 0x03 0x10<br>0x09 0x00 | ON and<br>Active Bit<br>clear | Step 1 => To make the register write enable                            |  |  |
| REFOCONN                     | 0xBF80A030                           | 4                | 0x03 0x10<br>0x3A 0x00 | _                             | Configure the Integer Division value                                   |  |  |
| REFOTRIM                     | 0xBF80A034                           | 4                | 0x00 0x00<br>0x00 0x98 | _                             | Configure the Fractional division value                                |  |  |
| REFOCONN                     | 0xBF80A030                           | 4                | 0x03 0x91<br>0x3A 0x00 | _                             | Make the register settings active. (Register is write protected again) |  |  |
| SPIXBRG                      | 0xBF80A070                           | 1                | 0x03                   | _                             | Baud rate configuration register                                       |  |  |

**Note:** In this example, coded changes related to 8 kHz sampling frequency are not included.

# 1.5 Summary of Unsupported Features

- 1) The I2S Bridge supports only USB Audio Class 1.0. USB Audio class 2.0 is not supported.
- 2) The codec must have an I2C slave interface for control. Other control interfaces (such as SPI) are not supported.
- 3) Volume control of MIC Audio IN is not supported.

# APPENDIX A: APPLICATION NOTE REVISION HISTORY

# TABLE A-1: REVISION HISTORY

| Revision Level & Date  | Section/Figure/Entry | Correction       |
|------------------------|----------------------|------------------|
| DS00003135A (07-03-19) | All                  | Initial release. |

NOTES:

# THE MICROCHIP WEBSITE

Microchip provides online support via our WWW site at <a href="www.microchip.com">www.microchip.com</a>. This website is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the website contains the following information:

- **Product Support** Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

## **CUSTOMER CHANGE NOTIFICATION SERVICE**

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip website at <a href="www.microchip.com">www.microchip.com</a>. Under "Support", click on "Customer Change Notification" and follow the registration instructions.

## **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- · Distributor or Representative
- · Local Sales Office
- · Field Application Engineer (FAE)
- · Technical Support

Customers should contact their distributor, representative or Field Application Engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the website at: http://microchip.com/support

#### Note the following details of the code protection feature on Microchip devices:

- · Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not
  mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

#### **Trademarks**

The Microchip name and logo, the Microchip logo, Adaptec, AnyRate, AVR, AVR logo, AVR Freaks, BesTime, BitCloud, chipKIT, chipKIT logo, CryptoMemory, CryptoRF, dsPIC, FlashFlex, flexPWR, HELDO, IGLOO, JukeBlox, KeeLoq, Kleer, LANCheck, LinkMD, maXStylus, maXTouch, MediaLB, megaAVR, Microsemi, Microsemi logo, MOST, MOST logo, MPLAB, OptoLyzer, PackeTime, PIC, picoPower, PICSTART, PIC32 logo, PolarFire, Prochip Designer, QTouch, SAM-BA, SenGenuity, SpyNIC, SST, SST Logo, SuperFlash, Symmetricom, SyncServer, Tachyon, TempTrackr, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries

APT, ClockWorks, The Embedded Control Solutions Company, EtherSynch, FlashTec, Hyper Speed Control, HyperLight Load, IntelliMOS, Libero, motorBench, mTouch, Powermite 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet-Wire, SmartFusion, SyncWorld, Temux, TimeCesium, TimeHub, TimePictra, TimeProvider, Vite, WinPath, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, Anyln, AnyOut, BlueSky, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, INICnet, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, memBrain, Mindi, MilVi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, SAM-ICE, Serial Quad I/O, SMART-I.S., SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

The Adaptec logo, Frequency on Demand, Silicon Storage Technology, and Symmcom are registered trademarks of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2019, Microchip Technology Incorporated, All Rights Reserved.

ISBN: 978-1-5224-4750-4

For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality.



# Worldwide Sales and Service

#### **AMERICAS**

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199

Tel: 480-792-7200 Fax: 480-792-7277 Technical Support:

http://www.microchip.com/ support

Web Address:

www.microchip.com

Atlanta Duluth, GA

Tel: 678-957-9614 Fax: 678-957-1455

**Austin, TX** Tel: 512-257-3370

**Boston** 

Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL

Tel: 630-285-0071 Fax: 630-285-0075

Dallas

Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

**Detroit** Novi, MI

Tel: 248-848-4000

Houston, TX Tel: 281-894-5983

Indianapolis

Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453 Tel: 317-536-2380

Los Angeles

Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608 Tel: 951-273-7800

**Raleigh, NC** Tel: 919-844-7510

New York, NY Tel: 631-435-6000

**San Jose, CA** Tel: 408-735-9110 Tel: 408-436-4270

**Canada - Toronto** Tel: 905-695-1980 Fax: 905-695-2078

#### ASIA/PACIFIC

Australia - Sydney Tel: 61-2-9868-6733

**China - Beijing** Tel: 86-10-8569-7000

**China - Chengdu** Tel: 86-28-8665-5511

China - Chongqing Tel: 86-23-8980-9588

**China - Dongguan** Tel: 86-769-8702-9880

**China - Guangzhou** Tel: 86-20-8755-8029

**China - Hangzhou** Tel: 86-571-8792-8115

China - Hong Kong SAR Tel: 852-2943-5100

China - Nanjing Tel: 86-25-8473-2460

China - Qingdao Tel: 86-532-8502-7355

**China - Shanghai** Tel: 86-21-3326-8000

**China - Shenyang** Tel: 86-24-2334-2829

China - Shenzhen

Tel: 86-755-8864-2200

**China - Suzhou** Tel: 86-186-6233-1526

**China - Wuhan** Tel: 86-27-5980-5300

**China - Xian** Tel: 86-29-8833-7252

China - Xiamen
Tel: 86-592-2388138

**China - Zhuhai** Tel: 86-756-3210040

#### ASIA/PACIFIC

India - Bangalore Tel: 91-80-3090-4444

India - New Delhi Tel: 91-11-4160-8631

India - Pune Tel: 91-20-4121-0141

**Japan - Osaka** Tel: 81-6-6152-7160

**Japan - Tokyo** Tel: 81-3-6880- 3770

Korea - Daegu

Tel: 82-53-744-4301 **Korea - Seoul** Tel: 82-2-554-7200

Malaysia - Kuala Lumpur Tel: 60-3-7651-7906

Malaysia - Penang Tel: 60-4-227-8870

Philippines - Manila Tel: 63-2-634-9065

**Singapore** Tel: 65-6334-8870

**Taiwan - Hsin Chu** Tel: 886-3-577-8366

Taiwan - Kaohsiung Tel: 886-7-213-7830

**Taiwan - Taipei** Tel: 886-2-2508-8600

Thailand - Bangkok Tel: 66-2-694-1351

Vietnam - Ho Chi Minh Tel: 84-28-5448-2100

#### **EUROPE**

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393

**Denmark - Copenhagen** Tel: 45-4450-2828 Fax: 45-4485-2829

Finland - Espoo Tel: 358-9-4520-820

France - Paris
Tel: 33-1-69-53-63-20
Fax: 33-1-69-30-90-79

**Germany - Garching** Tel: 49-8931-9700

**Germany - Haan** Tel: 49-2129-3766400

Germany - Heilbronn Tel: 49-7131-72400

**Germany - Karlsruhe** Tel: 49-721-625370

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

Germany - Rosenheim Tel: 49-8031-354-560

Israel - Ra'anana Tel: 972-9-744-7705

Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781

Italy - Padova Tel: 39-049-7625286

**Netherlands - Drunen** Tel: 31-416-690399 Fax: 31-416-690340

Norway - Trondheim Tel: 47-7288-4388

**Poland - Warsaw** Tel: 48-22-3325737

Romania - Bucharest Tel: 40-21-407-87-50

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

**Sweden - Gothenberg** Tel: 46-31-704-60-40

Sweden - Stockholm Tel: 46-8-5090-4654

**UK - Wokingham** Tel: 44-118-921-5800 Fax: 44-118-921-5820