Synchronizing Multiple Parallel Devices Using the Internal PLL

Stephen Maggiotto

ABSTRACT

The Texas Instruments family of audio converters can be used in various multichip configurations in order to realize multichannel processing using the time-division multiplexing (TDM) feature. Using a multichip solution sometimes requires synchronization of channels such that all of the devices operating in parallel operate in lock-step with each other to prevent phase shift errors between channels. The mechanisms and programming of the TLV320ADC3101 and TLV320ADC3100 audio ADCs are discussed in this application report.

1 Introduction

Each application for multichannel support may have different requirements having to do with selection of master clocks and synchronization. This application report specifically addresses the usage of the on-chip PLL of the ADC310x audio ADC to generate the audio serial interface clocks from a master clock (MCLK) reference, as well as the programming and sequencing of instructions such that all of the parallel devices are instruction locked. The method and programming instructions used in this application report were tested using three TLV320ADC3101 evaluation modules (EVM) and its companion USB motherboard. Verification of this method and programming was performed using an Audio Precision test instrument by measuring the phase difference between each channel. The configuration in this application report uses three devices in parallel. This is an arbitrary choice and can be expanded to as many devices as needed by the application.
2 Clock Configuration Block Diagram

Figure 1 shows that Device #1 is the master of the audio serial interface bus, while devices 2 and 3 are slaves. Device #1 takes in a master clock as input which is used as reference by the internal PLL, which in turn produces the bit clock (BCLK) and word clock (WCLK) that are used by the other devices as the audio serial interface clocks. The configuration of the audio serial interface clocks in the master device has to be done so the bit clock provided to the slave devices is fast enough to accomplish the processing requirements for each part.

NOTE: Devices #2 and #3 use BCLK as the clock source, therefore MCLK can be left disconnected or tied to logic level zero.

Figure 1. Multiple TLV320ADC310x Device Configuration
3 Conceptual Programming Sequence

The sequence of programming parallel devices depends on the PLL running and getting stable as the first step, followed by the clock configuration of the slave devices. After this, the programming of all the devices according to their required processing should be done. Then, clocks are released simultaneously by the master to all the slave devices, followed by the setting up of the TDM channels and the enabling of the respective DOUT pins. This method ensures that all of the devices’ instruction counters are in lock-step with each other. Section 5 of this application report contains the Detailed Programming Sequence description. Figure 2 is the instruction sequence flow diagram.

Figure 2. Instruction Sequence Flow Diagram
4 Other Important Considerations

The serial interface frame rate, defined by WCLK, has to be equal to the ADC sample rate or the user may experience repeat or missing samples. Setting up the same ADC miniDSP processing and associated clocks across all the devices is critical to capture waveforms with no phase difference in a multichip configuration. Regardless of the source for the master clock reference, MCLK must have a frequency that, after dividing by certain variables, as shown in the following text, is equal to the sampling rate of the audio serial interface.

\[
\frac{\text{BCLK frequency}}{\text{WCLK frequency}} \text{ must be an integer.}
\]

ADC output sample rate = \( \frac{\text{ADC_CLKIN frequency}}{N_{\text{ADC}} \times M_{\text{ADC}} \times AOSR} \) = WCLK frequency

Where:
-ADC_CLKIN refers to the internal ADC system clock, as referenced in Figure 28 of the TLV320ADC3101 datasheet.
-NADC = Divider for the ADC MAC engine clock
-MADC = Divider for the ADC modulator clock
-AOSR = ADC over-sampling ratio

When the PLL is powered on, a start-up delay of approximately 10 milliseconds occurs after the power-up command of the PLL and before the clocks are available to the TLV320ADC3101. This delay ensures stable operation of the PLL and clock-divider logic. If the I2C programming sequence is faster than the mentioned delay time, then it is possible that the sequencing of events will not occur as expected after the PLL clock is available. This may lead to unexpected results, therefore, the user must ensure that the programming sequence is longer than this time delay, or in the event that it is not, add a delay such that the enabling of the NADC divider for Device #1 occurs after the PLL clock is available.

5 Detailed Programming Sequence

The following set of instructions follow the I2C format which has the first byte being the device address, followed by the register address byte and then the data byte. The I2C device address is a 7-bit value followed by a Read/Write bit which forms the address byte. Because all of the following listed commands are writes, the eighth bit is always logic level 0. As an example, the 7-bit device address for Device #1 is 0x18. When the eighth bit is added to it, in this case it is a logic level 0, the address byte becomes 0x30. If the user chooses to do a Read for Device #1, the address byte becomes 0x31. Because the ADC3101 is limited in the programmability of its I2C address (I2C_ADR1, I2C_ADR0), an I2C Expander device is needed if more than four devices were required to operate in parallel. here

Write Address Byte for Device #1 = 0x30 (7-bit Device Address is 0x18)
Write Address Byte for Device #2 = 0x32 (7-bit Device Address is 0x19)
Write Address Byte for Device #3 = 0x34 (7-bit Device Address is 0x1A)
### Software Reset

#### Device 1, Master Mode, PLL input frequency is 10 MHz
- WCLK Input Frequency is 16 kHz
- Configure PLL to produce 81.92 MHz

#### Clock Settings For Devices 2 & 3
- The CODECs receive: MCLK through BCLK at = 4.096 MHz,
- BCLK = 4.096 MHz, WCLK = 16 kHz
- Select Page 0
- Divide-By for NADC = 1; Divide-By for MADC = 2; Enabled (multi-byte write)
- AOSR = 128 (default)
- Source of MCLK is from BCLK

#### User Defined ADC and Processing Settings
- Not covered here as they are application specific.

#### Enable NADC Divider of Device #1
- Divide-By for NADC = 20; ENABLED

---

Before proceeding with the next set of instructions, the user must wait approximately 100 ms to allow all of the parallel devices time to propagate the master clock throughout their logic cones (i.e., clock dividers, mini-DSP, clock-gating logic, etc.).

Insert Delay
### Synchronizing Multiple Parallel Devices Using the Internal PLL

#### Cautionary Note

The preceding programming sequence is intended to work with the built-in filter modes because they output data from the miniDSP to the serial interface near the end of the instruction sequence. In other words, the device programmed to be in the last time slot starts transmitting serial data before the DSP output happens such that each device transmits the same sample in the same frame (i.e., in terms of time index).

#### References

2. Texas Instruments, *TLV320ADC3101 Low-Power Stereo ADC With Embedded miniDSP for Wireless Handsets and Portable Audio* data sheet
3. Texas Instruments, *TLV320ADC3101-K* user's guide
### Revision History

NOTE: Page numbers for previous revisions may differ from page numbers in the current version.

<table>
<thead>
<tr>
<th>Changes from Original (November 2011) to A Revision</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>• Added TLV320ADC3100 device to document ............</td>
<td>1</td>
</tr>
<tr>
<td>• Changed second sentence of Introduction section for clarity</td>
<td>1</td>
</tr>
<tr>
<td>• Changed Clock Configuration Block Diagram section description</td>
<td>2</td>
</tr>
<tr>
<td>• Changed Conceptual Programming Sequence section for clarity</td>
<td>3</td>
</tr>
<tr>
<td>• Changed Other Important Considerations section for clarity</td>
<td>4</td>
</tr>
<tr>
<td>• Changed User Defined DSP Processing Settings to User Defined ADC and Processing Settings in Detailed Programming Sequence section code</td>
<td>4</td>
</tr>
<tr>
<td>• Added SBAS906 to References section</td>
<td>6</td>
</tr>
</tbody>
</table>

---

![Texas Instruments Logo](https://www.ti.com/assets/images/logos/ti-black.png)

www.ti.com  Revision History

SLAA508A—November 2011—Revised January 2019

Submit Documentation Feedback

Copyright © 2011–2019, Texas Instruments Incorporated
IMPORTANT NOTICE AND DISCLAIMER

TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES “AS IS” AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, or other requirements. These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources.

TI's products are provided subject to TI's Terms of Sale (www.ti.com/legal/termsofsale.html) or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products.

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265
Copyright © 2019, Texas Instruments Incorporated