# A<sup>2</sup>B MODULE AND EVM KIT USER MANUAL

For Revision 2 and 3 hardware

Rev 2.7

27-Sep-20



http://clk.works/

Copyright 2020 Clockworks Signal Processing LLC

Products covered:

AB0001 A<sup>2</sup>B to I<sup>2</sup>S module

AB0002 EVM for A<sup>2</sup>B module (Slave config)

AB0002M EVM for A<sup>2</sup>B module (Master config)

# 1. TABLE OF CONTENTS

| 1 | Intro | roduction                                                          |    |
|---|-------|--------------------------------------------------------------------|----|
|   | 1.1   | Module EVM                                                         | 4  |
|   | 1.1.1 | 1 IO7                                                              | 4  |
|   | 1.2   | Software support                                                   | 5  |
| 2 | Get   | tting started with the EVM                                         | 6  |
|   | 2.1   | Connection steps- Slave EVM configuation                           | 6  |
|   | 2.2   | Connection steps – Master EVM configuration                        | 8  |
|   | 2.3   | Pushbutton switches                                                | 9  |
|   | 2.4   | Use                                                                |    |
|   | 2.4.  | .1 Analog out                                                      |    |
| 3 | EVN   | M design information                                               |    |
|   | 3.1   | Power input                                                        |    |
|   | 3.2   | Features for modifying the EVM                                     | 11 |
|   | 3.2.3 | .1 Testpoints                                                      | 11 |
|   | 3.2.  | .2 NT components                                                   | 12 |
|   | 3.2.  | .3 Microphone input                                                |    |
|   | 3.3   | J6 external control connector                                      |    |
|   | 3.4   | J <sub>3</sub> I <sup>2</sup> S connector                          | 13 |
| 4 | Use   | e of the EVM without an A²B module                                 | 13 |
|   | 4.1   | Add components                                                     | 14 |
|   | 4.2   | Temporarily wire in an oscillator for use withoUT A <sup>2</sup> B | 14 |
|   | 4.3   | USBi connection                                                    | 15 |
| 5 | Мос   | dule information                                                   | 16 |
|   | 5.1   | Connector                                                          | 16 |
|   | 5.2   | Module mechanical information                                      |    |
|   | 5.3   | Interface detail                                                   | 19 |
|   | 5.3.3 | .1 IOVdd                                                           | 20 |
|   | 5.3.3 | .2 Vxx                                                             |    |
|   | 5.3.3 | .3 SCL, SDA                                                        |    |

| 6 |    | Conf  | igur     | ation example with Sigma Studio (EVM Slave mode)                                  |
|---|----|-------|----------|-----------------------------------------------------------------------------------|
|   |    | 6.1.1 |          | I²S setup28                                                                       |
|   | 6. | .2    | Acce     | essing the LED and switches from Sigma Studio                                     |
|   |    | 6.2.1 | L        | The hard way                                                                      |
|   |    | 6.2.2 | 2        | The easy way                                                                      |
| 7 |    | Conf  | iguri    | ing a master mode EVM                                                             |
|   |    | 7.1.1 |          | Things that might go wrong                                                        |
| 8 |    | SHA   | RC A     | udio Module (SAM) as A²B master                                                   |
|   | 8. | .1    | lf yo    | ou don't have the A²B software package                                            |
|   | 8. | .2    | Usin     | ng the ADI A <sup>2</sup> B tools with SAM – hardware and software setup          |
|   |    | 8.2.1 | -        | Hardware setup SUmmary                                                            |
|   |    | 8.2.2 | <u>)</u> | Software setup Summary 41                                                         |
|   | 8. | .3    | Basi     | c SAM example with A2B EVM setup in Sigma Studio42                                |
|   |    | 8.3.1 |          | SigmaStudio schematic                                                             |
|   |    | 8.3.2 | <u>!</u> | SAM SC589 bypass program                                                          |
|   |    | 8.3.3 |          | Controlling from Sigma Studio                                                     |
|   | 8. | .4    | Crea     | ate a program that sets up the A2B operation the same as SigmaStudio schematic 47 |
|   |    | 8.4.1 | L        | Export from SigmaStudio 47                                                        |
|   |    | 8.4.2 | 2        | And next                                                                          |

## 1 INTRODUCTION

The Clockworks A<sup>2</sup>B module is intended to allow developers to quickly integrate Analog Device's A<sup>2</sup>B capability in to a prototyping environment. For OEMs it provides a quick time to market solution without need to design and debug the A<sup>2</sup>B portion.

The module can operate as either an A<sup>2</sup>B master or slave. In either case it is intended to be locally powered, i.e. it does not support drawing power from an A<sup>2</sup>B bus with phantom power. The module does however provide power to downstream A<sup>2</sup>B slave nodes using A<sup>2</sup>B's phantom power feature.

The module itself is a small 2 layer PCB with two 12 pin 2.54 mm (0.1") connectors on the bottom for easy mating to other hardware.



#### Figure 1 A<sup>2</sup>B module

#### 1.1 MODULE EVM

For system developers there is a need to provide A<sup>2</sup>B slave devices that can stand in for other hardware, or to monitor audio streams that are being sent between other devices in the system. The EVM also provides a known good reference for operating the module and a design that can be copied if needed.

The EVM uses the Analog Device's (ADI) ADAU1761 Sigma DSP part, so the EVM can perform local processing on the audio input and output, which is a common practice in many A<sup>2</sup>B applications.

The standard EVM does not act as an A<sup>2</sup>B master. While Clockworks directly supports the ADI EVAL-AD2428WD1BZ and SHARC Audio Module as the A<sup>2</sup>B master for the provided examples, any A<sup>2</sup>B master can be used with EVM. Access to ADI's A<sup>2</sup>B tool set is needed to configure other masters to be used.

If your application requires an A<sup>2</sup>B master there is a separate orderable part number.

For master mode use an Analog Devices USBi (or equivalent) will be needed to use the SigmaStudio A<sup>2</sup>B development environment. The USBi is not needed for the slave mode EVM (but is probably needed for whatever master you are using, you just don't need a second one).

It is possible to convert a slave mode EVM in to a master mode EVM and vice versa, but it involves adding or removing parts as described in this manual.

#### 1.1.1 IO7

The original EVM design supported prior generation A<sup>2</sup>B chips, and they required IO7 to be grounded during power on to place the A<sup>2</sup>B chip in slave mode. The newer parts, including the AD2428(W) used

on the Clockworks A<sup>2</sup>B module, rely on I<sup>2</sup>C commands to place the chip in Master mode, or upstream A<sup>2</sup>B activity to place the chip in slave mode.

Slave mode EVMs (rev 2) still have IO7 grounded, but there is a trace point where the copper can be cut.



## Figure 2 Cut NT1 to let IO7 float or be used for other things

On EVM Master mode boards ordered from Clockworks this trace is already cut and the pin is left floating.

## 1.2 SOFTWARE SUPPORT

At present all A<sup>2</sup>B software is supplied by ADI directly. Normally this software package includes both an add on for Sigma Studio that allows an A<sup>2</sup>B network to be described graphically, and a library with a standard API that can be used by the (host) processor that is connected to the A<sup>2</sup>B master (first) device.

The A<sup>2</sup>B API information can be found in the ADI document "AD2421/AD2422/AD2425 Automotive Audio Bus A<sup>2</sup>B Transceiver Programming Reference" document 82-100128-01, Rev 1.1 or as updated to the latest version. This guide, along with the A2B transceiver manual, is also needed to understand the register settings that are exposed in the A<sup>2</sup>B add-on for Sigma Studio.

Functionally the Clockworks module and EVM combination in slave mode operate the same as the ADI WBZ eval board, except that the Clockworks system is locally powered.<sup>1</sup>

Clockworks supplies SigmaStudio examples for the ADI SHARC Audio Module that allows audio to be routed between the EVM and the SHARC host.

When using ADI's tools for A<sup>2</sup>B configuration and operation remember to set the A<sup>2</sup>B device type for the module (EVM) to AD2428W.

Please see section 6 for an example with the A<sup>2</sup>B add-on for Sigma Studio.

<sup>&</sup>lt;sup>1</sup> The Clockworks EVM setup matches the original ADI 2425WBZ design. The newer ADI 2428WBZ design adds two microphones and has a few other minor I/O changes. From the perspective of configuring the hardware in the ADI Sigma Studio for A<sup>2</sup>B tool they are all very similar.

## 2 GETTING STARTED WITH THE EVM

The setup steps are pretty similar between the two version (master or slave) of the EVM board.

The EVM board and the modules are ESD sensitive and must be handled following good ESD practices with a proper and safe grounding of the work area and anyone handling the boards.

The EVM kit ships with a 9V DC power supply that has universal input. The North America version uses the two blade plug, where as the international version of the kit has multiple adapters that mate with the supply.

If using the international version of the kit please attach the correct AC mains adapter to the supply.

The AC adapter supplies 500 mA at 9 VDC (center positive) via standard 2.1mm barrel connector. Alternately the board can be power from a bench supply providing 5 – 9V DC by connecting wires to the Phoenix block connector.

See Figure 2 and Figure 3 for the location on the hardware for the items discussed in the next section.

#### 2.1 CONNECTION STEPS- SLAVE EVM CONFIGUATION

The EVM is shipped with an A<sup>2</sup>B module installed. The A<sup>2</sup>B module is configured for IO<sub>Vdd</sub> of 3.3V

- Set SW1 (power) to the off position (slide button at board edge).
- Attach the 9 VDC supply to input jack J1 and plug the supply in to the AC mains.
   DO NOT CONNECT A 12V SUPPLY YOU WILL RELEASE THE SPECIAL SMOKE!
- Connect an audio source to J8 (Line in) if planning on using the EVM for stereo audio acquisition
- Connect headphones or amplified speakers to the Headphone out jack J4. Alternately amplified speakers or other line level device can be connected to J5 (Line out) if you change the default software for the ADAU1761.
- Connect an A<sup>2</sup>B cable to lower module jack ("From Master") to the A<sub>2</sub>B master or A<sub>2</sub>B slave located electrically closer to the A<sub>2</sub>B master.



Figure 3 EVM external connectors



#### Figure 4 EVM Components

At this point the EVM can be powered up by switching SW1 to the "ON" position. The power indicator on the EVM and on the  $A^2B$  module should be light.

Once the A<sup>2</sup>B host is operational and the A<sup>2</sup>B network established – which with the default software also includes programming the ADAU1761, the User LED (D<sub>2</sub>) will light.

If the user LED fails to light or the board is not operational for passing audio check that the download on initialization check box is enabled if using the Sigma Studio A<sup>2</sup>B tools. If developing application programmatically verify the ADAU1761 code is being correctly processed and downloaded.

As with the ADI A<sup>2</sup>B EVM boards this board includes an EEPROM. By default that EEPROM is not programmed. Some A<sup>2</sup>B software example may expect certain contents in the EEPROM.

#### 2.2 CONNECTION STEPS – MASTER EVM CONFIGURATION

The steps are basically the same as the hardware is almost the same. The EVM that's been built to support master mode will have a MASTER sticker on it. The software settings are different, so please read the software section to make sure you understand the differences in the way the boards are configured.

We'll illustrate the connections using one Master EVM and one Slave EVM board.



## Figure 5 Setting up a master mode EVM

Follow the directions for the slave mode board as described in the prior section. Then plug in the USBi. A shrouded header is used and the USBi has a keyed 10 pin IDC connector.

An A<sup>2</sup>B cable is used to connect the master mode EVM's downstream port (B) to the upstream port (A) on the slave node EMV. If you have more nodes to connect they would connect to the downstream (B) port of the slave node.

Once the hardware is connected you can power up the boards, the order that they are powered up in does not matter. Please see the software section for information about configuring the boards.

## 2.3 PUSHBUTTON SWITCHES

The EVM includes two pushbutton switches that connect to the A<sup>2</sup>B module. Specific software must be used to define interactions with the switches. A small capacitor is used to aid in the debounce of the switch but software should verify a clean switch closure and release.

SW2 is connected to the DRX1 signal, which is also GPIO 6 on the AD2428 device.

SW3 is connected to the IRQ pin, which can also be used as GPIO o on the AD2428 device.

#### 2.4 USE

There are two ways to evaluate A<sup>2</sup>B bus operation. One is with the Analog Devices A<sup>2</sup>B add-on for Sigma Studio with a supported ADI A<sup>2</sup>B bus master and the other is using the ADI developed API on your host processor.

Please see section 6 for an example with the A2B add-on for Sigma Studio. Guidance for direct software development is included with the ADI API documentation.

#### 2.4.1 ANALOG OUT

The Analog Devices default DSP program uses the headphone output jack. To use the line out jack the default program must be modified to route in the I2S input to the DAC and enable both the headphone and line out jack in the chip register setup.

2200F capacitors are used on the headphone output for AC coupling. With 32 ohm headphones Fc is 22 Hz; 16 ohm headphones Fc is 45 Hz.<sup>2</sup>

For the line out 10 uF capacitors are used, with typical 10 kohm input impedances of an amplifier Fc is 1.5 Hz.

#### 3 EVM DESIGN INFORMATION

When the EVM is purchased a design package is provided by email or an emailed link to download the information.

The package includes the following information:

- PDF of schematic. Part information is embedded in the PDF, click on a part symbol to see detailed information on the part.
- 3D PDF of the board. Note that Acrobat Reader security will ask if you trust the document. You must click yes. You then may need to click in the blank field to make it display. Some versions of Reader have a bug and will not display unless the document is saved locally. You can enable display of various board features and components using the standard 3D Acrobat features.
- Zip with Gerbers.
- Altium project files
- BOM as an Excel spreadsheet
- .STEP file for the A<sup>2</sup>B module

<sup>&</sup>lt;sup>2</sup> So yes, if you have low impedance headphones and want a good experience you probably want an external buffer amplifier if you wanted to do some sort of critical listening.

#### 3.1 POWER INPUT

The EVM design include a diode on the DC input to prevent damage from a reverse connected input supply. This diode also reduces the input voltage by about 0.7V; on the board/schematic this is rounded off to call the supply an "8V" supply; the actual voltage is about 8.3V.

The AD2428 maximum supply voltage is 9V and this small extra drop prevents operating the AD2428 on the module near it's limit. The module design includes a Schottky diode as suggested by ADI's design guide for a local powered A2B module, meaning there is another 0.4V or so drop on the A<sup>2</sup>B module and this the actual voltage to the AD2428 on the module is about 8V.

The only possible impact from the lower supply voltage is if A<sup>2</sup>B phantom power feature is used to power multiple downstream slave nodes; each node has a 0.4V drop. For more details please see the full AD2428 datasheet for a discussion on phantom power of slave nodes.

The EVM board design includes a fuse. Under normal use the fuse will never blow as the A<sup>2</sup>B is protected from catastrophic failure for a range of open and short to power conditions. While developing a system it is certainly possible to make an error (for example modifying the module in some way) that would overload the supply, so the fuse serves as a little protection against doing too much damage. Looked at this way, if the fuse blows you made a big oops and it will be time to buy a new board.

The PCB is a four layer board, the internal planes carry GND and +3.3V. The power input and 8V power are carried by traces.

The EVM does not use the IOVDD module output. The A<sup>2</sup>B module must be jumpered for 3.3V IO when used with the EVM.

## 3.2 FEATURES FOR MODIFYING THE EVM

There may be cases where a change to the default wiring is needed. There are a couple of provisions in the design to attempt to simplify making modifications. Please note that Clockworks can not support modified boards nor take any responsibility for your modifications making you late for dinner or something worse like burning down the building.

## 3.2.1 TESTPOINTS

Testpoints are available on some of the signals to facilitate probing or modifying the board. Please see the schematic for their (electrical) location.

The unused analog I/O pins of the ADAU1761 are also brought out to a test point; please see the ADAU1761 datasheet for how to use them as no circuitry is provided on the EVM.

In addition to signals a few GND test points are provided. These are connected to the internal ground plane of the PCB. There is a single ground plane in this design.

## 3.2.2 NT COMPONENTS

NT (Net Tie) components are o6o3 footprints with copper trace between them. By cutting the traces the two net pieces can be isolated and connected to different places. They are available on the ADAU1761's l<sup>2</sup>S signals and the 3 address bits for the EEPROM.

NT7, located on the SDA pin of the EEPROM, would normally not be used for any purpose.

NT1, connected to the IO7 pin of the module, must be grounded to have the AD2428 operate in A<sup>2</sup>B slave mode. If the trace is cut and the pin pulled high then the module will operate as a master and you must provide an external host to control the AD2428 over I<sup>2</sup>C. If this is changed the I<sup>2</sup>S clocking must also be changed to match the needs of the AD2428 and the programming of it in master mode.

## 3.2.3 MICROPHONE INPUT

The EVM provides test point holes for the microphone pins of the ADAU1761. Please see the ADAU1761 datasheet for suggested circuit configurations for using these inputs.



Figure 6 ADAU1761 microphone input signal breakout

# 3.3 J6 EXTERNAL CONTROL CONNECTOR

This 6 pin connector is a TE MTA-100 series part, 640456-6. It follows the same pinout as used on some other Clockworks products. Pin assignments are as follows:

| 1 | GND    |
|---|--------|
| 2 | SDA    |
| 3 | GND    |
| 4 | SCL    |
| 5 | 3.3V   |
| 6 | RESETn |

The RESETn is normally defined as an active low signal that is driven by open collector logic where the default driving source includes a pullup. On the EVM board and the A2B module there is no reset capability, the parts have built in brown-out and reset. Therefor this signal serves no purpose for the normal EVM use.

If using the I<sup>2</sup>C bus keep in mind that the AD2428 device on the A<sup>2</sup>B module is normally the I<sup>2</sup>C master.

## 3.4 J3 I2S CONNECTOR

This 12 pin dual row connector (2.54mm/0.1" spacing) provides access to the I<sup>2</sup>S signals. It is not installed on the EVM so users can insert whatever connector may be needed.

| 2      | BCLK             |
|--------|------------------|
| 4      | SYNC             |
| 6      | DACDATA (DTX0)   |
| 8      | DTX1             |
| 10     | ADCDAT (DRX1)    |
| 12     | DRX1 (IO6 - SW2) |
| 1,, 11 | GND (odd pins)   |

# 4 USE OF THE EVM WITHOUT AN A<sup>2</sup>B MODULE

The EVM Board can be used without an A<sup>2</sup>B module for ADAU1761 development using ADI's Sigma Studio tools. The ADAU1761 receives its clock on the MCLK pin, it will not operate without that signal. The default software expects a 12.288 MHz clock which corresponds to 256 Fs for an Fs of 48 kHz.

There are two ways to provide this signal. One is to connect a 3.3V clock input to pin A3 of the module connector (CLK on the schematic).

The other is to install a 12.288 MHz oscillator at Xo1 (Kyocera 3225 series or similar) along with R9 (33 ohm o8o5 footprint) and C17 (0.1 uF o8o5 footprint). If those parts are installed a module in slave mode can not be used as the module must be the device supplying the I<sup>2</sup>S clocks for an A<sup>2</sup>B slave device. This would, with an external control processor or the USBi, allows the EVM to be the A<sup>2</sup>B master.

The EVM master mode board comes with this oscillator installed, therefor the A2B module most only be run as a master (I2S slave) to prevent signal conflicts

Other oscillator frequencies can be used, the ADAU1761 datasheet provides more detail. Using the suggested 12.288 MHz value keeps the settings the same between an A<sup>2</sup>B application and non A<sup>2</sup>B application use.

When ordered from the factory as the Master mode version of the EVM, a 12.288 MHz oscillator is used for all current hardware revisions (older revisions may have been supplied with 24.576 MHz oscillators). The choice of MCLK will affect the ADAU1761 setup, MCLK is not used by the A<sup>2</sup>B module.

#### 4.1 ADD COMPONENTS

Three SMD components, an oscillator, resistor (series terminating so typically 33 ohms) and a decoupling cap can be solder to the EVM board as a permanent change. This may be desirable if hacking the EVM to operate as an A2B master (which requires an external processor to act as the controller).



# Figure 7 Location of optional components on EVM for local clocking (installed on EVM master version)

If the module is operated in master mode (see notes regarding use of NT7) then this oscillator would provide the master clock. The operation of the bit clock and frame syncs must be decided and the ADAU1761 and AD2428 programming matched with the specifics of the I<sup>2</sup>S signals in this scenario.

## 4.2 TEMPORARILY WIRE IN AN OSCILLATOR FOR USE WITHOUT A<sup>2</sup>B

The control header (J6) can be used to supply power to an oscillator who's output is plugged in to the A<sup>2</sup>B header as a way to use the EVM as a SigmaDSP development environment without making a permanent change to the board.

Figure 8 shows two examples of how an oscillator (12.288 MHz) can be connected. J6 on the EVM is used to supply power and the clock output is wired to a pin. The mating connector is an MTA-100 series part, TE part number 3-640440-6 is for 22 AWG wire.

Heat shrink tubing helps maintain mechanical robustness and offers some protection against accidental shorts.



Figure 8 Oscillator options example for using EVM without A<sup>2</sup>B. Can style on left, SMD style on right (under shrink wrap).

The clock output (yellow wire) is connected to pin A<sub>2</sub> of the header.



Figure 9 Oscillator connection example

## 4.3 USBI CONNECTION

For use in master mode, or to develop software for the ADAU1761 Analog Device's Sigma Studio tools are used. An emulator (ADI calls it *USBi*) is required for downloading and interacting with the ADAU1761. For more information please see:

http://www.analog.com/en/design-center/evaluation-hardware-and-software/evaluation-boardskits/eval-adusb2ebz.html#eb-documentation

## 5 MODULE INFORMATION

All module functions are determined by the AD2428W device, please refer to that device's datasheet and technical reference manual for detailed operating information.

## 5.1 CONNECTOR

Pinout – A Connector, J1 on PCB label.

| Pin   | Name  | Notes                                                                                 |
|-------|-------|---------------------------------------------------------------------------------------|
| 1     | IOVDD | Jumper selects between AD2428 internal regulator voltages, default is 3.3V (vs. 1.8V) |
| 2     | GND   |                                                                                       |
| 3     | ADR2  | AD2428 ADR2/IO2 line with 10K pulldown                                                |
| 4     | ADR1  | AD2428 ADR1/IO1 line with 10K pulldown                                                |
| 5     | IRQ   | AD2428 IRQ/IO0 line                                                                   |
| 6     | GND   |                                                                                       |
| 7     | SDA   | I2C data                                                                              |
| 8     | SCL   | I2C clock                                                                             |
| 9     | GND   |                                                                                       |
| 10,11 | Vxx   | Power 5-8V suggested range, 4V min, 9V max.                                           |
| 12    | GND   |                                                                                       |

Pinout – B Connector, J2 on PCB label.

| Pin | Name | Notes                                             |
|-----|------|---------------------------------------------------|
| 1   | GND  |                                                   |
| 2   | BCLK | AD2428 bit clock (output from module as a slave)  |
| 3   | GND  |                                                   |
| 4   | SYNC | AD2428 frame sync (output from module as a slave) |
| 5   | GND  |                                                   |
| 6   | DTX0 | AD2428 DTX0 with 10K pulldown (output)            |
| 7   | DTX1 | AD2428 DTX1 with 10K pulldown (output)            |
| 8   | GND  |                                                   |
| 9   | DRX0 | AD2428 DRX0                                       |
| 10  | DRX1 | AD2428 DRX1                                       |
| 11  | GND  |                                                   |
| 12  | 107  | AD2428 IO7/PDMCLK pin <sup>3</sup>                |

<sup>&</sup>lt;sup>3</sup> Original rev 1 modules were built with AD2425W and this pin needed to be grounded to indicate a slave device. There is a jumper on the EVM that can be cut to remove the ground connection on this pin if needed (the EVM is however only capable of being an A<sup>2</sup>B slave)

## 5.2 MODULE MECHANICAL INFORMATION

Top View.



#### Figure 10 A<sup>2</sup>B module dimensions

The board is slightly asymmetrical relative to the mounting holes, which are 4mm from the back edge and 3mm from the front (A<sup>2</sup>B connector) edge.

All electrical components are on the top side of the board. The two 12 pin connectors are located on the bottom side of the board.

Component heights are nominally as follows for the figure shown below. Component substitutions during assembly may sometimes be required; this may alter these values.



#### Figure 11 A<sup>2</sup>B module side view cut-away

Board thickness 1.6 mm(.062").

Plastic on bottom connectors thickness 2.29mm (.090").

Pin length 6.1mm (.24").

DuraClik connector height 6.4mm (.252").

C24 (bulk 100 uF cap) height 7.7mm (.303")

## 5.3 INTERFACE DETAIL

The following two schematic sections from the A<sup>2</sup>B module are provided to aid in understanding the A<sup>2</sup>B module interface.



## Figure 12 Module A connector wiring<sup>4</sup>

C42 is required by the ADI design rules and should be kept in mind for the load capacitance on the external supply.

The other connector carries the I<sup>2</sup>S signals. Analog Devices suggests series termination and a small 27

<sup>&</sup>lt;sup>4</sup> RefDes for Rev 2 module PCB shown unless noted otherwise.

pF capacitor to reduce EMI issues and the module implements those suggestions.



#### Figure 13 Module B connector wiring. On AD2428W IO7 can also be PDMCLK out pin.<sup>5</sup>

The remainder of the module schematic corresponds to the ADI recommended design for locally powered nodes, as that guidance is subject to change please see the ADI documentation for further details.

Unused module pins may be left floating except for the I<sup>2</sup>C pins. (see 5.3.3).

## 5.3.1 IOVDD

This pin is normally an output from the module. It can be configured for 3.3V or  $1.9V^6$  operation.

If neither voltage selection jumper is installed then IOVdd can be set externally, however all of the AD2428 rules about supply sequencing must be strictly adhered to.

The I<sup>2</sup>C bus must match the IOVdd, i.e. the pullup resistor's connection to the supply.

<sup>&</sup>lt;sup>5</sup> RefDes for Rev 2 module PCB shown unless noted otherwise.

<sup>&</sup>lt;sup>6</sup> The datasheet for the AD2428W specified the range of voltage from that supply as 1.7 to 1.98 with 1.9 being the typical value. In a few places though it's referred to as the 1.8V supply.



Figure 14 Rev 2 PCB IOVdd connections. 1V9 is connected to the AD2428W VOUT1, pin 32. 3V3 is connected to the AD2428W VOUT2, pin 29.



Figure 15 Rev 3 PCB IOVdd connections. 1V9 is connected to the AD2428W VOUT1, pin 32. 3V3 is connected to the AD2428W VOUT2, pin 29. (different RefDes #s)



Figure 16 Rev 2: IOVdd jumper resistors. 3.3V is the factory default

## 5.3.2 VXX

It is AD2428 datasheet shows that this pin should not exceed 9V, though the Schottky diode in the module input supply connection does mean that 9.3V is closer to the absolute maximum limit of the

module. The minimum voltage is 4.2V for the module to operate, however no phantom power can be supplied at that voltage.

## 5.3.3 SCL, SDA

As stated on the AD2428 datasheet, these two pins should be grounded if not used by system this board plugs in to.

If I<sup>2</sup>C is used then the main board must provide the I<sup>2</sup>C pullups and correctly match the IOVdd.

# 6 CONFIGURATION EXAMPLE WITH SIGMA STUDIO (EVM SLAVE MODE)

This section outlines the steps for using the Clockworks EVM with the Analog Devices A<sup>2</sup>B add-on for Sigma Studio. ADI includes tutorial examples with the software add-on and this section shows how to use the example ...\Schematics\BF\A2BSchematics\adi\_a2b\_3NodeSampleDemoConfig.dspproj

You can also create a new example on a blank sheet Sigma Studio sheet following the procedures in the ADI documentation. When first starting out it may be easier to edit a provided example for your host (and save it as a new file!) than to get all of the settings in place.

This section assumes the use of one of the standard ADI A<sup>2</sup>B EVM boards as the A<sup>2</sup>B master. If using the SC<sub>5</sub>8<sub>9</sub> based SHARC Audio Module please also see the next section as that board is currently not covered by the ADI A<sup>2</sup>B package. While the concepts are the same as working with the ADI EVMs there are a few differences that must be considered.



## Figure 17 Sigma Studio 3 node example

Figure 6 shows one of the ADI default example with the (ADI WDZ board) ADAU1452 master and WBZ and WCZ slaves. The Clockworks EVM replaces the WBZ slave in this example. To do that change the chip type on the 2<sup>nd</sup> node to AD2428 as shown by the red arrow.

If you don't have the WCZ microphone board you can delete it from the example.

In this example the master node must be programmed, which is enabled by selecting its properties and checking the *Program during discovery* box. The path to the XML file with theADAU1452 must be valid and if just trying the system for the first time should be the default pass through program.

| Audio Host ADAU1452 Properties                                                                |
|-----------------------------------------------------------------------------------------------|
| Block Register Read/Write                                                                     |
| Peripheral register programming file xml\adi_a2b_master_ADAU1452.xml                          |
| Program during discovery     Edit     Program                                                 |
| SigmaDSP project file (optional) chematics\adi_a2b_master_ADAU1452.dspproj<br>Open Update XML |
| Generic Register Read/Write                                                                   |
| Addr Width Address Data Width Data                                                            |
| Register 1 - 0x00 1 - 0x00 Read Write                                                         |
| Results                                                                                       |
|                                                                                               |
|                                                                                               |
|                                                                                               |
|                                                                                               |
|                                                                                               |
|                                                                                               |
|                                                                                               |
| J                                                                                             |

# Figure 18 WDZ Master node properties

The Clockwork's EVM board ADAU1761 must likewise be programmed, and the default program used with the WBZ board can be used, as shown in Figure 8. As with the master node the *Program during discovery* box must be checked.

| Codec 0 : ADAU1761 Properties                                                   |
|---------------------------------------------------------------------------------|
| Block Register Read/Write                                                       |
| Peripheral register programming file .vxml\adi_a2b_slave_ADAU1761.xml           |
| Program during discovery     Edit     Program                                   |
| SigmaDSP project file (optional)                                                |
| Generic Register Read/Write<br>Addr Width Address Data Width Data<br>Register 1 |
| Results                                                                         |
|                                                                                 |
|                                                                                 |
|                                                                                 |
|                                                                                 |
|                                                                                 |

## Figure 19 ADAU1761 programming on Clockworks EVM board (as a slave node)

It should not be necessary to change the AD2428 properties, the I<sup>2</sup>C setup screen (properties home page) is shown in Figure 9.

| A2B Slav    | e Node1 WBZ Pro    | operties           |                         |                           | X                               |
|-------------|--------------------|--------------------|-------------------------|---------------------------|---------------------------------|
| General Vie | W Register View    | Stream View        |                         |                           | <b>5</b>                        |
| Slave       | Config             |                    |                         |                           |                                 |
| I2C Int     | erface Frequency   | 400 kHz 👻          |                         |                           |                                 |
| Super       | Frame Rate         | 48.0 kHz 👻         |                         |                           |                                 |
| Node i      | Response Cycles    | 0x78               |                         |                           |                                 |
| Spread      | Spectrum Settings  | I                  |                         |                           |                                 |
| Mode        | No Spread          | <b>~</b>           | Frequency               | 4x                        | •                               |
| Depth       | Low                | 🔘 High             |                         |                           |                                 |
| Config an   | d Control Slot Cor | fig   Audio Config | Rate and CikOut   Inter | rupt Config   Pin Config  |                                 |
| Master Add  | ress Dxt           | 8                  | Bus Address             | 0x69<br>ation from EEPROM | ( <sup>1</sup> / <sub>X</sub> ) |

# Figure 20 AD2428 Properties for Clockworks EVM based on defaults for ADI WBZ board.

Once all of the settings are checked hit the Link Compile Download button and after a few seconds the A<sup>2</sup>B nodes should turn green to indicate the networks has been discovered, as shown in the figure on the next page.



This particular ADI example takes the audio from the  $2^{nd}$  slave node (a WCZ mic board) and plays it out the headphone jack of the  $1^{st}$  slave node (the Clockworks EVM here, a WBZ board in the original example). The line in to the  $1^{st}$  slave node is sent to the headphone out of the A2B master.

## 6.1.1 I<sup>2</sup>S SETUP

If using the ADI provided example all of the settings are correct for the AD2428 to exchange audio with the ADAU1761 when it runs the corresponding default program. If inserting a A<sup>2</sup>B transceiver block and peripheral block (in stead of copying) all of the settings need to match that used for the SigmaDSP's I<sup>2</sup>S interface. Failure modes include no audio, very badly distorted audio, or full scale modulated noise.

Figure 21 and Figure 22 show the two relevant settings for use with the default ADAU1761 program.

| AD242x Slave - A2B EVM 0     | Properties               |                         |                     |
|------------------------------|--------------------------|-------------------------|---------------------|
| General View Register View   | Stream View              |                         | <b>5</b>            |
| -I2S                         |                          |                         |                     |
| TDM Mode                     | TDM2 🔻                   | Early Sync              | Enabled             |
| TDM Channel Size             | 32-bit 🔹                 | Rx Interleave           | Disabled            |
|                              |                          | Tx Interleave           | Disabled            |
| Sync Mode                    | 50 % Duty Cycle          | Tx0                     | Enabled             |
| Sync Polarity                | Falling Edge             | Tx1                     | Disabled            |
| DRXn Sampling BCLK           | Falling Edge             | Rx0                     | Enabled             |
| DTXn Change BCLK             | Rising Edge              | Rx1                     | Disabled            |
| Sync Offset 0                |                          | Clock Sustain           | Enabled             |
|                              |                          |                         |                     |
| PDM Date                     |                          | Lieb Dees Dibes         | Displied            |
|                              |                          | High Fass Filter        | Disabled            |
| PDM0 Slots 1-Slot -          | Rising Edge              | PDM0                    | Disabled            |
| PDM1 Slots 1-Slot -          | Rising Edge              | PDM1                    | Disabled            |
| PDM Data Out On              | Bus Only 💌               | Alt. Clock on IO7       | Inv. on BCLK        |
| Config and Control Slot Conf | fig Audio Config Rate an | d ClkOut   Interrupt Co | nfig Pin Config 🕢 🕨 |
| Apply change to other not    | les                      |                         |                     |
|                              |                          |                         |                     |
| Master Address Dx6           | B                        | us Address Oxe          | 59 😲                |
| A-Side Cable Length (m) 4.0  |                          | ] Use Configuration fr  | om EEPROM           |
|                              |                          |                         |                     |

Figure 21 Audio Config tab settings for ADAU1761 default EVM program

If any of the edge or Sync setting are wrong highly distorted audio will result. These settings correspond in part with the I2SCFG register (0x42), which should have a value of 0x91 if the bits have been set properly.

| AD242x Slave Clkwrks EVM Pro    | operties                                 |                       |
|---------------------------------|------------------------------------------|-----------------------|
| General View Register View Stre | eam View                                 | <b>5</b>              |
| I2S Rate Settings               |                                          |                       |
| I2S Rate S                      | FF x 1   Reduce/Retransmit               | Disabled              |
| Share Slots(RR)                 | Disabled                                 |                       |
| Reduced Rate Controls           |                                          |                       |
| Strobe Direction Ir             | nput   Strobe in IO7                     | Disabled              |
| Reduce Rate Valid bit(s) in     | LSB                                      | Extra Bit             |
| Sync Offset                     | •                                        |                       |
| Clock Out1                      | Clock Out2                               |                       |
| Enable Clock Out1               | Enable Clock Out2                        | 2                     |
| Pre Div Factor 1                | Pre Div Factor 2                         | 2 🗸                   |
| Post Div Factor1 2              | <ul> <li>Post Div Factor2</li> </ul>     | 4 🔹                   |
| Clock1 Invert                   | Disabled Clock2 Invert                   | Disabled              |
| Clock1 Output(Hz)               | 4576000 Clock2 Output(Hz)                | 12288000              |
| Config and Control Slot Config  | Audio Config Rate and ClkOut Interrupt C | Config Pin Config 🔹 🕨 |
| Apply change to other nodes     |                                          |                       |
| Master Address 0x68             | Bus Address                              | 69 😲                  |
| A-Side Cable Length (m) 4.0     | Use Configuration                        | from EEPROM           |
| L                               |                                          |                       |

Figure 22 Rate and ClkOut tab settings for ADAU1761 default EVM program (slave node)

#### 6.2 ACCESSING THE LED AND SWITCHES FROM SIGMA STUDIO

GPIO can be accessed from the AD2428 block in Sigma Studio by right clicking on the block associated with the EVM board. There are two ways to do this, one at a low level of direct register access, like what a program would do, and the other via the more convenient "General View," though that second method only helps for output, i.e. turning the LED on and off.

## 6.2.1 THE HARD WAY

Select Register View and the IO tab. For details of the registers and their bit maps please see the AD242x Programmers Reference Manual.

| General View       Register View       Stream View         Pin IO and Interrupt Registers       Register       Register Value         CLK1CFG       (0x59)       0x00         CLK2CFG       (0x5A)       0xC1         GPIODAT       (0x4A)       0x10         GPIODATSET       (0x4B)       0x10         GPIODATCLR       (0x4D)       0x10         GPIODEN       (0x4E)       0x41         ØPIOIN       (0x4F)       0x40         PINTEN       (0x50)       0x00         PINTINV       (0x51)       0x00         PINCFG       (0x52)       0x00 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin IO and Interrupt Register       Register Address       Register Value         CLK1CFG       (0x59)       0x00         CLK2CFG       (0x5A)       0xC1         GPIODAT       (0x4A)       0x10         GPIODATSET       (0x4B)       0x10         GPIODATCLR       (0x4C)       0x10         GPIODEN       (0x4E)       0x41         ØPIOIN       (0x4F)       0x40         PINTEN       (0x50)       0x00         PINTINV       (0x51)       0x00         PINCFG       (0x52)       0x00                                                     |
| RegisterRegister AddressRegister ValueCLK1CFG(0x59)0x00CLK2CFG(0x5A)0xC1GPIODAT(0x4A)0x10GPIODATSET(0x4B)0x10GPIODATCLR(0x4C)0x10GPIODEN(0x4D)0x10GPIOIEN(0x4F)0x41VGPIOIN(0x50)0x00PINTEN(0x50)0x00PINTEN(0x52)0x00                                                                                                                                                                                                                                                                                                                             |
| CLK1CFG       (0x59)       0x00         CLK2CFG       (0x5A)       0xC1         GPIODAT       (0x4A)       0x10         GPIODATSET       (0x4E)       0x10         GPIODATCLR       (0x4D)       0x10         GPIODEN       (0x4E)       0x41         ØPIOIN       (0x4F)       0x40         PINTEN       (0x50)       0x00         PINTINV       (0x51)       0x00         PINCFG       (0x52)       0x00                                                                                                                                       |
| CLK2CFG       (0x5A)       0xC1         GPIODAT       (0x4A)       0x10         GPIODATSET       (0x4B)       0x10         GPIODATCLR       (0x4C)       0x10         GPIODEN       (0x4E)       0x41         ØFIOIN       (0x4F)       0x40         PINTEN       (0x50)       0x00         PINTINV       (0x51)       0x00         PINCFG       (0x52)       0x00                                                                                                                                                                               |
| GPIODAT       (0x4A)       0x10         GPIODATSET       (0x4E)       0x10         GPIODATCLR       (0x4C)       0x10         GPIOOEN       (0x4D)       0x10         GPIOIEN       (0x4F)       0x41         ØPIOIN       (0x4F)       0x40         PINTEN       (0x50)       0x00         PINTINV       (0x51)       0x00                                                                                                                                                                                                                      |
| GPIODATSET       (0x4B)       0x10         GPIODATCLR       (0x4C)       0x10         GPIOOEN       (0x4D)       0x10         GPIOIEN       (0x4E)       0x41         GPIOIN       (0x4F)       0x40         PINTEN       (0x50)       0x00         PINTINV       (0x51)       0x00         PINCFG       (0x52)       0x00                                                                                                                                                                                                                       |
| GPIODATCLR         (0x4C)         0x10           GPIOOEN         (0x4D)         0x10           GPIOIEN         (0x4E)         0x41           GPIOIN         (0x4F)         0x40           PINTEN         (0x50)         0x00           PINTINV         (0x51)         0x00           PINCFG         (0x52)         0x00                                                                                                                                                                                                                          |
| □       GPIOOEN       (0x4D)       0x10         □       GPIOIEN       (0x4E)       0x41         ☑       GPIOIN       (0x4F)       0x40         □       PINTEN       (0x50)       0x00         □       PINTINV       (0x51)       0x00         □       PINCFG       (0x52)       0x00                                                                                                                                                                                                                                                             |
| GPIOIEN         (0x4E)         0x41           GPIOIN         (0x4F)         0x40           PINTEN         (0x50)         0x00           PINTINV         (0x51)         0x00           PINCFG         (0x52)         0x00                                                                                                                                                                                                                                                                                                                         |
| GPIOIN         (0x4F)         (0x40)           PINTEN         (0x50)         0x00           PINTINV         (0x51)         0x00           PINCFG         (0x52)         0x00                                                                                                                                                                                                                                                                                                                                                                     |
| PINTEN         (0x50)         0x00           PINTINV         (0x51)         0x00           PINCFG         (0x52)         0x00                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PINTINV (0x51) 0x00<br>PINCFG (0x52) 0x00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PINCFG (0x52) 0x00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Select 4//                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Config and Control   Slot Config   I2C, I2S/PDM   Interrupt and Error   10   PRBS   Status   1     >                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Select All Register Groups Read Write Edit Auto-Fill Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Reaisters 🔍 🏚                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Master Address 0x68 Bus Address 0x69                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| A-Side Cable Length (m) 4.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Figure 23 IO tab in SigmaStudio

Top operate the LED first write ox10 to the GPIOOEN register (0x4D). Then place ox10 in the GPIODATSET or GPIODATCLR register and write that to turn the LED on and off. The LED is connected (through the EVM to A2B module connector) to DTX1/IO4 pin of the AD2428.

To read the switches for write ox41 to GPIOIEN register (ox4E). SW2 is connected to DRX1/IO6 (bit map ox4)oand SW3 to IRQ/IOo (bit map oxo1). Select GPIOIN and hit the Read button to see the switch values.

## 6.2.2 THE EASY WAY

This will allow turning the EVM's LED on and off, which might be useful to confirm the node you've selected is the one you think it is. On the General View that select the Pin Config dialog and set GPIO4 to be an output. High turns the LED on, Low shuts it off.

| <b>/</b> 8 A | D242x Slave Clkw    | vrks EVM Properties                                                     |          |
|--------------|---------------------|-------------------------------------------------------------------------|----------|
| Ge           | eneral View Registe | er View Stream View                                                     | <u></u>  |
|              | General Purpose Ir  | Input/Output                                                            |          |
|              | GPI00               | INPUT - Interrupt Disable Rising Edge                                   | ]        |
|              | GPI01               | DISABLE 👻                                                               |          |
|              | GPIO2               | CLKOUT -                                                                |          |
|              | GPIO3               | DTX0                                                                    |          |
|              | GPIO4               | OUTPUT - High                                                           |          |
|              | GPI05               | DRX0 -                                                                  |          |
|              | GPI06               | INPUT - Interrupt Disable Rising Edge                                   | ]        |
|              | GPI07               | DISABLE -                                                               |          |
|              | Pin Config          |                                                                         |          |
|              | IRQ Edge            | Rising Edge Sustain PLL on                                              | <b>v</b> |
|              | IRQ Tristate        | Disable                                                                 |          |
|              | Digital Pin Driv    | ive Strength Low                                                        |          |
|              | Slot Config Audio C | Config Rate and ClkOut Interrupt Config Pin Config GPIOD ID other nodes | 4.2      |
| Ма           | aster Address       | Dx68 Bus Address Dx69                                                   | ¥,       |
| A-9          | Side Cable Length ( | (m) 4.0 💌 🔲 Use Configuration from EEPRON                               | 1        |

Figure 24 EVM User LED (GPIO 4) control

# CONFIGURING A MASTER MODE EVM

Start with the supplied example (EVM\_mstr\_EVM\_slave\_WCZ.dsproj) or create a new project and add the host, AD2428, and ADAU1761 blocks as shown. If creating from scratch make sure you use the AD242x Master node for the first one.



## Figure 25 EVM master mode with EVM slave mode example (with WCZ node)

For the slave node follow the directions in the prior section, the remainder of this section will just look at the master node setup.

The AD2428W and the ADAU1761 are both controlled over I<sup>2</sup>C from the host running SigmaStudio. When a *Link Compile Download* is performed the AD2428W is initialized and the ADAU1761 program is also loaded as the *Program during discovery* is enabled in the ADAU1761 properties:

| M ADAU1761 Properties            |                                                     |
|----------------------------------|-----------------------------------------------------|
| Plack Decide Read Mar            |                                                     |
| Block Register Read/White        |                                                     |
| Peripheral programming file      | CSP_EVM_a2b_master_ADAU1761.xml                     |
| Program during discovery         | Edit Program                                        |
| SigmaDSP project file (optional) | CSP_EVM_a2b_master_ADAU1761.dspproj Open Update XML |
| Generic Register Read/Write      |                                                     |
| Addr Width Address               | Data Width Data                                     |
| Register 1 V 0x00                | 1 V 0x00 Read Write                                 |
| Results                          |                                                     |

## Figure 26 Master node 1761 file setup

The master node has slightly different properties than the slave node.

| eneral Vie | W Register View     | Stream View      |                                     |                |
|------------|---------------------|------------------|-------------------------------------|----------------|
| Master     | Config              |                  | Calculate Response Cycles           |                |
| I2C Ea     | rly Ack             | Disabled         | Node Response Cycles                | 0x77           |
| Data C     | )ut on Bus Monitor  | Disabled         | M - 4 📩 x N                         | Auto-Calculate |
|            |                     |                  | M - Master Node Repor               | ise Cycles     |
|            |                     |                  | N - Slave Node Index                |                |
|            |                     |                  | 📝 Update Slave Node Res             | p cycles       |
| - Up/Do    | own Stream Settings |                  |                                     |                |
| Upstre     | am Enable           | Disabled         | Downstream Enable                   | Enabled        |
| Upstre     | am Slot Size        | 24-bit 👻         | Downstream Slot Size                | 24-bit 👻       |
| Upstre     | am Compression      | Disabled         | Downstream Compressio               | Disabled       |
| Slot Ra    | ate                 |                  |                                     |                |
| Reduc      | ed Rate on Bus      | Disabled         | Sys Rate Divide                     | 1 •            |
| Spread     | Spectrum Settings   |                  |                                     |                |
| Mode       | No Spread           | •                | Frequency                           | 4x ▼           |
| Depth      | Output Low          | 🔘 High           |                                     |                |
| Config an  | d Control Audio C   | onfig Rate and C | IkOut   Interrupt Config   Pin Conf | ig GPIOD ID    |
| Apply      | change to other no  | des              |                                     |                |
| aster Add  | ress Ox68           | •                | Bus Address                         |                |

#### Figure 27 Master node properties

In the provided example the I<sup>2</sup>S lines between the AD2428 and the ADAU1761 are operated in TDM2 mode (more commonly called stereo). The ADAU1761 only has one I<sup>2</sup>S in and one I<sup>2</sup>S out line. On the EVM master node the ADAU1761 generates the I<sup>2</sup>S BLCK and SYNC signals; the opposite is true on an EVM slave node.

For the AD2428 this can be set directly in its properties:

| A2B Master Node Clockworks EVM Properties      |                                        |
|------------------------------------------------|----------------------------------------|
| General View Register View Stream View         | <u></u>                                |
| - I2S                                          |                                        |
| TDM Mode TDM2                                  |                                        |
| TDM Channel Size 32-bit                        | Rx Interleave Disabled                 |
|                                                | Tx Interleave Disabled                 |
| Sync Mode 50 % Duty Cycle                      | Tx0 Enabled                            |
| Sync Polarity Falling Edge                     | U Tx1 Disabled                         |
| DRXn Sampling BCLK Rising Edge                 | Rx0 Enabled                            |
| DTXn Change BCLK Rising Edge                   | Rx1 Disabled                           |
| Tx Offset                                      | Tri-state Before Tx Disabled           |
| Rx Offset 0                                    | Tri-state After Tx Disabled            |
| PDM                                            |                                        |
| PDM Rate SFF -                                 | High Pass Filter Disabled              |
| PDM0 Slots 1-Slot - Rising Edge                | L PDM0 Disabled                        |
| PDM1 Slots 1-Slot - Rising Edge                | PDM1 Disabled                          |
| PDM Data Out On Bus Only                       | ✓ Alt. Clock on IO7                    |
| Config and Control Audio Config Rate and ClkOu | t Interrupt Config Pin Config GPIOD ID |
| Apply change to other nodes                    |                                        |
|                                                |                                        |
| Master Address 0x68 -                          | Bue Address Dr69                       |
| Master Address accort                          |                                        |
|                                                |                                        |
|                                                |                                        |

## Figure 28 Master node settings for TDM2 over I<sup>2</sup>S

To set up the ADAU1761 the SigmaStudio schematic for a separate project most be updated. Do not mix up the master nodes ADAU1761 SigmaStudio schematic with the slave node's, the need to operate differently due to the different I<sup>2</sup>S clocking.

The provided master node ADAU1761 example is copied from one that ADI uses in their examples. Don't worry if the example(s) you have look different. You will want to edit these or create new ones to match your processing configuration.

The ability to create test tones is useful when debugging why nothing seems to be working the way you wanted.



## Figure 29 Master node ADAU1761 example (CSP\_EVM\_a2b\_master\_ADAU1761.dspproj)

The ADAU1761 is set up with the correct divider for the 12.288 MHz MCLK, which is 256 times Fs (Fs = 48 kHz).

On the master node the AD2428 uses the BCLK as an input, along with the FSYNC (or FLCK). For correct AD2428 the frame sync is the important clock, it multiples that clock up by 1024 to create the A<sup>2</sup>B network clock.

The bit clock on the master node is only used for clocking I<sup>2</sup>S data in and out of theAD2428.

| Codec Setup Record Input Signal Path                                                                                             | Playback Output Signal Path    | Digital Setup DSP Re                                                                                         |
|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------|
| Clock Control<br>Clock Source<br>Direct from MCLK<br>PLL Clock<br>Input Master Clock<br>Frequency 256 x fs<br>Core Clock Enabled |                                | Jack Control<br>Jack Input Debounce<br>Jack Detect Mic In<br>Jack Detect Of<br>Jack Detect Or<br>Digital Mic |
| PLL Control PLL Type   PLL Type Input Clock Divider X = 1                                                                        | Fractional                     | lator                                                                                                        |
| N (Numerator) 0                                                                                                                  | MCLK Input                     | 0 MHz<br>0 MHz                                                                                               |
| R (PLL Integer Setting) 4                                                                                                        | Load                           | Parameters                                                                                                   |
| <ul><li>Disable</li><li>Enable</li></ul>                                                                                         | Verify PLL Sta<br>PLL Lock Bit | tus                                                                                                          |
|                                                                                                                                  | Locked                         | Verify                                                                                                       |

# Figure 30 Master node ADAU1761 clock setup

For complete details on the ADAU1761 setup please see the datasheet and user guide. For the I<sup>2</sup>S interface setting it to Master mode is the key setting.

| Serial Ports                 | atin ji nayuaok output oighai Patr | Dor Register         | Converters              |                    | Serial Port Pad            |
|------------------------------|------------------------------------|----------------------|-------------------------|--------------------|----------------------------|
| Control 0                    | Control1                           |                      | Control 0               | Control 1          | Pull up - Pull down Config |
|                              |                                    |                      |                         |                    |                            |
|                              | # Bit Clk Cycles                   | /Frame 64 🔻          | On-Chip DAC First Pair  | •                  | ADC_SDATA                  |
|                              | ADC Chan pos                       | in TDM Left First    | DAC Oversampling 128x   |                    | None 👻                     |
| LRCLK Mode 50% Duty Cycle    |                                    |                      |                         |                    |                            |
|                              | DAC Chan pos                       | in TDM Left First    | ADC Oversampling 128x   |                    |                            |
| Book polarity Failing Edge   | MSB p                              | osition MSB First    | Sample rate 48 kHz (fs) | On-Chip ADC        | DAC SDATA                  |
| LRCLK polarity Falling Edge  |                                    |                      |                         | First Pair 👻       |                            |
| Chan/Frame Stereo 👻          | Data Delay LRC                     | .Kedge 1 🔻           |                         |                    | None 👻                     |
| CDATA Made                   |                                    |                      |                         |                    |                            |
| SDATA MODE Mastel            |                                    |                      |                         |                    |                            |
| ADC                          |                                    | DAC                  |                         |                    |                            |
| Control 0                    | ADC Left Chan ADC I                | Right Chan Control 0 | DAC Left C              | han DAC Right Chan | LRCLK                      |
| Inv In Polarity Normal       | 1 E 👎 6 E                          | -6 Mono Mode         | Stereo 👻 📮 🧮            | -6 = 📮 _6          | None 👻                     |
| High Pass Filter Off         | -16                                | -16                  |                         | -16 -16            |                            |
| Die Mie eelewee              | -26                                | -26 Inv In Polarity  | y Normal                | -2626              |                            |
| Dig Mic por swap             | -36 -                              | -36                  |                         | -3636              |                            |
| Dig Mic chan swap Normal     | -46                                | -46                  |                         | -4646              | BCLK                       |
| Dig Mic In Select Mic In Off | -56                                | -56                  |                         | -5656              | None 👻                     |
| ADC Easter Both On           | -66 -                              | -66                  |                         | -6666              |                            |
| AUC Enable Courton V         | -/6                                | -76 DAC de-enph      | Disabled                | -/0 -76            |                            |
|                              | - 00                               | -86 DAC Enable       | Both On 👻               | -9686              |                            |
|                              |                                    | -30                  |                         |                    |                            |
|                              |                                    | <u> </u>             |                         |                    |                            |

Figure 31 ADAU1761 serial port setting on EVM master node

Once the ADAU1761 has been set up the way you want you need to create the XML file that is used to program the ADAU1761 at boot up. Full details are in the SigmaStudio guide(s), but the summary is

- *Link Compile Download* (hardware doesn't need to be active)
- Copy the Capture window left side contents to the right side (hit the << button on the right if it's not visible)
- Save the right side window to an XML file
- Return to the A<sup>2</sup>B schematic and set the master node ADAU1761 to use the XML file

If you haven't already, use the Streams configuration to route audio data between the nodes in your system.

| 🖳 A2B Stream Configuration          |               |          |            |
|-------------------------------------|---------------|----------|------------|
| Stream Definition Stream Assignment |               | Ĺ        | ] []       |
| Auto Slot Calculate 🔲 View By Name  | <- Str        | eam Dest | ination -> |
| Stream Name                         | Stream Source | Master   | Slave<br>0 |
| Stream_ADC                          | Slave 0 🔻     |          |            |
| Stream_DAC                          | Master 💌      |          |            |
|                                     |               | A        | pply       |

## Figure 32 Simple stereo stream routing for two EVM example

At this point the A<sup>2</sup>B schematic is ready to run. If you're using the canned example you would have skipped all of the above. Hit the *Link Compile Download* and the two AD2428 nodes should turn green. If you get an error message then check that power is on to all of the boards and they are cabled correctly. If you made new diagrams then recheck your work.

## 7.1.1 THINGS THAT MIGHT GO WRONG

If there is a bug in your ADAU1761 schematic for the master node then it probably won't create the I<sup>2</sup>S clock(s), and the master node AD2428 will be unhappy. You may want to run your ADAU1761 schematic first and probe the I<sup>2</sup>S signal to make sure you set up I<sup>2</sup>S correctly.

Once the A<sup>2</sup>B schematic is running you can open the ADAU1761 schematic and dynamically change its controls and have them reflected in the running hardware. If opening the ADAU1761 schematic for the first time you should hit the *Link Compile Connect* button.

You can also work with a slave node's ADAU1761 in a similar manner to adjust its settings on the fly.

Very occasionally the USBi and/or SigmaStudio may get a little lost and not make your changes, or sometimes report it can't find the USBi. A power cycle of the A2B master and unplugging the USBi

from the host PC usually clears that up, sometime restarting SigmaStudio is needed too. This does not happen very often (we see it maybe once in a 100 runs where we're changing things).

It's also been noticed that if the A<sup>2</sup>B application is running and the host PC goes to sleep it can sometimes shut down the A<sup>2</sup>B target. Exit from SigmaStudio if you want to leave things going for extended periods.

# 8 SHARC AUDIO MODULE (SAM) AS A<sup>2</sup>B MASTER

The SC<sub>5</sub>89 based SAM is a low cost development board from Analog Devices. At the time of writing of this manual revision there is not a lot of information available from ADI to simplify use of A<sup>2</sup>B with the SC<sub>5</sub>89.

While the procedures described in ADI provided A<sup>2</sup>B software package documents theoretically explain the process of using SC<sub>5</sub>89 with A<sup>2</sup>B, in real life it can be a bit, hmmm, let's all it obtuse. This situation will hopefully change when ADI releases the A<sup>2</sup>B based amplifier board.

The diagrams and software described in this section are available from Clockworks, if you don't find them on the support site please contact us.

Your first stop should be the ADI Wiki to gather up the latest things that they have made available.

https://wiki.analog.com/resources/tools-software/sharc-audio-module

# 8.1 IF YOU DON'T HAVE THE A<sup>2</sup>B SOFTWARE PACKAGE...

you won't be able to actually develop A<sup>2</sup>B based applications. You can however run the precooked A<sup>2</sup>B network configurations that ADI has made available for SAM, as well as the ones that Clockworks has created.

These precooked configurations can be used with your own custom SC<sub>5</sub>89 software that you develop, you are restricted in that you can't change the topology, sample rates, routing, etc.

When the SAM Bare Metal package runs it simply loads a predefined sequence of I<sup>2</sup>C commands in to the master A<sup>2</sup>B node located on the SAM. This sets up all of the topology as well as programming other I<sup>2</sup>C devices like the commonly used ADAU1761 SigmaDSP or I<sup>2</sup>C devices likes the SSM3582 Class D amplifier chip used on the quad channel SAM FIN.

Once the A<sup>2</sup>B network is running the SAM software simply reads/writes data from/to the I<sup>2</sup>S port connected to the AD2425W A<sup>2</sup>B transceiver chip. For applications that don't need the sophisticated fault and error detection that A<sup>2</sup>B offers, this may be more than adequate.

If the hardware configuration might change – which after all is the whole point of the flexibility offered by  $A^2B$  – you will need the tools<sup>7</sup>.

#### 8.2 USING THE ADI A<sup>2</sup>B TOOLS WITH SAM – HARDWARE AND SOFTWARE SETUP

The steps are as follows for a basic SAM plus Clockworks A<sup>2</sup>B EVM setup. Audio is just exchanged between the two boards in this example.

## 8.2.1 HARDWARE SETUP SUMMARY

Details of the hardware and boards can be found in their respective user manuals. Three USB ports are needed, keep that in mind if your laptop is USB challenged. The tools run on Windows 7 and later.

- Connect the ICE1000 to the SAM JTAG port and your PC
- Connect the USBi to the SAM USBi port (careful, it's just a header, so verify where pin 1 is) and your PC.
- Connect a UART to USB adapter to the UART header on SAM. Normal baud rate is 115,200.
- Connect audio sources to the SAM Line in jack and the A<sup>2</sup>B EVM line in jacks.
- Connect amplified speakers to the SAM line out jack.
- Connect headphones or amplified speakers to the A<sup>2</sup>B EVM headphone out jack.

<sup>&</sup>lt;sup>7</sup> Or hire developers that use the tools to provide that piece of your product's software.



#### Figure 33 SAM and A2B EVM hardware setup

Do not connect 12V to the Clockworks A<sup>2</sup>B EVM board as the power is connected directly to the AD2428W on the A<sup>2</sup>B module and if you put more than 9V on the AD2428W chip's supply pin all of the magic smoke will be released.

## 8.2.2 SOFTWARE SETUP SUMMARY

There are a number of tools that are used in the process of creating A<sup>2</sup>B based applications. This manual is not the place to learn about them.<sup>8</sup>

- CCES. When used with ICE1000 and SAM the free version can be used.
- SigmaStudio
- A2B add on for SigmaStudio (including API)
- Terminal emulator for the UART connection
- SAM Bare Metal Framework
- A pre-cooked SC589 bypass program or one created from the wizard (requires editing)

<sup>&</sup>lt;sup>8</sup> Are we lazy? Err, maybe. Seriously though the tools are always getting updated and if the details were copied in to here we would be forever updating this document, which would seriously cut in to the time available for sampling more IPAs.

## 8.3 BASIC SAM EXAMPLE WITH A2B EVM SETUP IN SIGMA STUDIO

This example exchanges audio between the two boards shown in the setup of Figure 33.

## 8.3.1 SIGMASTUDIO SCHEMATIC

Open the file SAM-EVM. dspproj in SigmaStudio<sup>9</sup> or create the equivalent on a new blank sheet.<sup>10</sup>



#### Figure 34 SAM with A2B EVM schematic

If starting from a blank schematic add the USBi connection on the Hardware Configuration tab. For SAM it looks like Figure 35.



Figure 35 Sigma Studio Hardware Configuration tab for use with SAM and USBi

<sup>&</sup>lt;sup>9</sup> A<sup>2</sup>B extensions must have been previously installed.

<sup>&</sup>lt;sup>10</sup> If starting from scratch please see the information about A<sup>2</sup>B chip setup in Section 6.1.1.

The Stream capability of the later chips makes it easier to set up and manage audio data than using the manual configuration of the first generation chips. These next steps explain the process; the provided example already has this set up this way.

Right click on the Target processor block and select Stream Config:



Select the + button on the A<sub>2</sub>B Stream Configuration dialog and add two streams with 2 channels each:

| • | 🖳 A2B Stream Configuration          |               |          |            |                 |  |
|---|-------------------------------------|---------------|----------|------------|-----------------|--|
|   | Stream Definition Stream Assignment |               |          |            |                 |  |
|   |                                     |               |          | + - /      | 1               |  |
|   | Stream ID                           | Stream Name   | Fs (kHz) | Data Width | No.<br>Channels |  |
|   | 0                                   | SAM_stereo_in | 48       | 24         | 2               |  |
|   | 1                                   | EVM_Stereo_In | 48       | 24         | 2               |  |
|   |                                     |               |          |            |                 |  |
| L |                                     |               |          |            |                 |  |

Then select the stream assignment tab:

| A2B Stream Configuration            |                          | -                      | - 0 X                     |
|-------------------------------------|--------------------------|------------------------|---------------------------|
| Stream Definition Stream Assignment |                          |                        | 66                        |
| Auto Slot Calculate View By N       | ame                      | <- Stre                | am Destination ->         |
| Stream Name                         | Stream Source            | A2B Master<br>Node SAM | AD242x Slave<br>- A2B EVM |
| SAM_stereo_in                       | A2B Master Node SAM 🔻    |                        | <ul><li>✓</li></ul>       |
| EVM_Stereo_In                       | AD242x Slave - A2B EVM 💌 | V                      |                           |
|                                     |                          |                        | Apply                     |

Make sure Auto Slot Calculate is selected, and View by Name<sup>11</sup> is usually more informative then viewing by ID. In this example we're swapping audio between the two nodes.

Next set up the programs that get run on the two ADAu1761 in the system (one on SAM, one on EVM). They run different programs. The process of creating the .xml files from SigmaStudio is covered in

<sup>&</sup>lt;sup>11</sup> If the names of the AD24xx nodes are changed it's been noticed that this dialog can be a little slow to refresh the names. Clicking on a Stream Source seems to sync it back up.

the SigmaStudio documentation as well as in the A<sup>2</sup>B specific documents in the A<sup>2</sup>B add-on for SigmaStudio. The latter document also explains running and debugging ADAU1761 programs from within this setup.

| SAM ADAU1761 Properties                                                                                                                              | x                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| Block Register Read/Write                                                                                                                            |                                                  |
| Peripheral programming file                                                                                                                          | xml\ADAU1761_8ch_i2s_master.xml                  |
| Program during discovery                                                                                                                             | Edit Program                                     |
| SigmaDSP project file (optional)                                                                                                                     |                                                  |
|                                                                                                                                                      | Open Update XML                                  |
|                                                                                                                                                      |                                                  |
|                                                                                                                                                      |                                                  |
| Codec 0 : ADAU1761 Properties                                                                                                                        |                                                  |
| Codec 0 : ADAU1761 Properties<br>Block Register Read/Write                                                                                           |                                                  |
| Codec 0 : ADAU1761 Properties<br>Block Register Read/Write<br>Peripheral programming file                                                            | .\xml\adi_a2b_slave_ADAU1761 xml                 |
| Codec 0 : ADAU1761 Properties<br>Block Register Read/Write<br>Peripheral programming file<br><i>Program during discovery</i>                         | .\vml\adi_a2b_slave_ADAU1761.vml                 |
| Codec 0 : ADAU1761 Properties Block Register Read/Write Peripheral programming file <i>Program during discovery</i> SigmaDSP project file (optional) | .\xml\adi_a2b_slave_ADAU1761 xml<br>Edit Program |

If building an example from scratch check the I2S related settings for the EVM as described in Section 6.1.1.

Before doing the Compile Download & Run you must first load a pass through program on the SC589.

## 8.3.2 SAM SC589 BYPASS PROGRAM

There are some ADI provided examples that can be used for this step, or the SAM Wizard can be used to generate a basic pass through program.

To edit the bare metal framework program, open up common/audio\_system\_config.h and make these changes<sup>12</sup>:



<sup>&</sup>lt;sup>12</sup> Thanks go to Dan Ledger at <u>https://www.pathcollaborative.com/</u> for these code snippets.



If importing an existing project in to a CCES workspace verify that the Debug configuration is set up correctly<sup>13</sup>.

| Z Debug Configurations                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                           |                                                                                                                                                                                                             |                                                 | ×                                                                               |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------------|
| Create, manage, and run configurations<br>Select a debug session to launch and a program to load                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                           |                                                                                                                                                                                                             |                                                 | Ť                                                                               |
| Image: SAM_ICE1000         Image: SAM_ICE10000         Image: SAM_ICE10000 <t< td=""><td colspan="4">Name: SAM_ICE1000  Session • Automatic Breakpoint Target Options Custom Board Support Multiprocessor Group  "2 Session configuration Target: Emulation Debug Target Platform: ADSP-SC589 via ICE-1000 Processor: ADSP-SC589 The data data</td></t<> | Name: SAM_ICE1000  Session • Automatic Breakpoint Target Options Custom Board Support Multiprocessor Group  "2 Session configuration Target: Emulation Debug Target Platform: ADSP-SC589 via ICE-1000 Processor: ADSP-SC589 The data data |                                                                                                                                                                                                             |                                                 |                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Program                                                                                                                                                                                                                                   | Options<br>g Devic Reset, Run after load<br>Demc Check si-revision, Run after load<br>re 1]<br>Demc Reset, Check si-revision, Run after load<br>re 2]<br>Demc Reset, Check si-revision, Run after load<br>T | Silicon revision<br>not available<br>1.0<br>1.0 | Add<br>Edit<br>Remove<br>Remove All<br>Move Up<br>Move Down<br>Restore Defaults |
| Filter matched 6 of 6 items                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                           |                                                                                                                                                                                                             | Revert                                          | Apply                                                                           |
| (?)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                           |                                                                                                                                                                                                             | Debu                                            | g Close                                                                         |

After you select Debug the code will be compiled (if needed) and if running with the stock CCES behaviors the Debug perspective will open, followed by the code loading on the three SC<sub>5</sub>8<sub>9</sub> cores and then each stopping at the entry breakpoint:

<sup>&</sup>lt;sup>13</sup> We skipped a lot of steps here, see the tutorials on SAM and CCES if this looked like magic to you. The good news is CCES is more or less standard Eclipse. The bad news is CCES is more or less standard Eclipse.



For each core select it and hit the run button, after doing that will all 3 it will look like:



And depending on the code being run the ADI framework startup messages will be displayed:

| 00:00:00.000 | [INFO - ARM] | Baremetal Framework (version 2.0.0) for the ADI SHARC Audio Module $% \left( {\left( {{{\left( {{{{\rm{AD}}}} \right)}_{\rm{AD}}} \right)_{\rm{AD}}} \right)_{\rm{AD}}} \right)$ |
|--------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00:00:00.000 | [INFO - ARM] | System Configuration:                                                                                                                                                            |
| 00:00:00.000 | [INFO - ARM] | Processor cores running at 450.00 MHz                                                                                                                                            |
| 00:00:00.000 | [INFO - ARM] | Audio sample rate set to 48.00 KHz                                                                                                                                               |
| 00:00:00.000 | [INFO - ARM] | Audio block size (per channel) set to 32 samples / frame                                                                                                                         |
| 00:00:00.000 | [INFO - ARM] | Configuring the SRU - ADAU1761 is the I2S master                                                                                                                                 |
| 00:00:00.000 | [INFO - ARM] | Configuring the ADAU1761                                                                                                                                                         |

The SC<sub>5</sub>89 and the USBi both want to be I<sup>2</sup>C bus masters. Therefor the pass through program should not attempt I<sup>2</sup>C transactions as it will lead to something going south.

The system is now ready to have A<sup>2</sup>B operation be controlled from Sigma Studio over the USBi connection.

## 8.3.3 CONTROLLING FROM SIGMA STUDIO

Turn down the output level on your audio output device as a mistake in setting can result in full scale output noise. Set the source output level to around 50%, assuming some sane line level source is being used.

Select the Compile Link Download button in SigmaStudio. All of the AD242x node blocks should turn green. If you get an error message recheck your USBi setup, A<sup>2</sup>B wiring, and that the boards have power.

SigmaStudio should indicate its communications with the SAM board with a few messages/second. If that's happening but you get no audio confirm that the CCES session is still active<sup>14</sup> as if the SC589 isn't running then audio data will not be moved around.

When in doubt power cycle everything and start over. Very occasionally the USBi will go off in to the weeds and need to be unplugged from the PC and plugged back in. When in doubt check Device Manager for the USBi device (in the USB section).<sup>15</sup>

Bring up your audio output device volume. With two audio sources and two audio monitoring devices you should hear both sources. If one or both is highly distorted review the I<sup>2</sup>S settings as discussed in Section 6.1.1. If you hear clipping on loud parts your source is most likely overloading the inputs, turn down the audio source output level.

At this point you've now verified that your A<sup>2</sup>B topology works.

# 8.4 CREATE A PROGRAM THAT SETS UP THE A2B OPERATION THE SAME AS SIGMASTUDIO SCHEMATIC.

At some point in the far future, but before our Sun becomes a red giant, the SAM Project Wizard will have an option to generate a Bare Metal Framework project that allows direct selection of the Clockworks A<sup>2</sup>B EVM board as part of the A<sup>2</sup>B network. Until then though you'll need to slog through the details of all of this.

# 8.4.1 EXPORT FROM SIGMASTUDIO

Right click on the TargetProcessor icon and select the export option and the I<sup>2</sup>C tab. Fill in the target file locations; this can be pretty much anywhere as you'll copy them in to a CCES created Bare Metal Project Wizard created project. Select the Include Peripheral Data checkbox.

The dialog is a little deceiving, it needs a complete path and filename, not just the path (you'll get an access denied or similar message if you just provide a path). Best way to avoid issues is to use the browse button.

<sup>&</sup>lt;sup>14</sup> Actually there's no real easy way to know this as you can quit CCES and the SC<sub>5</sub>89 would still keep running. If the loaded program is printing to the console or flashing LEDS then that would be a clue its running. When in doubt restart. We should note we've never seen the SAM quit – it's more like a "oops I unplugged it for a second without realizing it" type thing.

<sup>&</sup>lt;sup>15</sup> The appearance in device manager is the same if you use the USBi clone available from SushiBits on Tindie. Both ADI's USBi and the clone via Tindie were used when this manual was developed.

| Export A2B Configuration Files                                                                                                                    |    |        | ×   |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------|----|--------|-----|--|
| Bus Config File (BCF) I2C command list                                                                                                            |    |        |     |  |
| File path for I2C Command list .XML file<br>D:\temp\SS\adi_a2b_i2c_commandlist xml                                                                |    | Browse |     |  |
| File path for I2C Command list .H file<br>D:\temp\SS\adi_a2b_i2c_commandlist.h                                                                    |    | Browse |     |  |
| <ul> <li>Include Modified A2B Registers Only</li> <li>Include Peripheral Configuration data</li> <li>Optimize exported file for Memory</li> </ul> |    |        |     |  |
| Export File Version 1.0.0                                                                                                                         | ОК | Canc   | :el |  |

# 8.4.2 AND NEXT...

We're still evaluating what makes the most sense to take the exported file and glom it in to one of the Project Wizard created projects.

The SAM to SAM template is the closest starting point for a stereo audio application.