XMOS USB Audio Hardware Platforms¶
A range of hardware platforms for evaluating USB Audio on XMOS devices.
Specific details for each platform/board are out of scope of this library documentation however, the features of the most popular platform are described below with the view of providing a worked example.
Please also see application note AN00246.
xCORE.AI Multichannel Audio Board¶
The XMOS xCORE.ai Multichannel Audio board (XK-AUDIO-316-MC) is a complete hardware and reference software platform targeted at up to 32-channel USB audio applications, such as DJ decks and mixers and other musical instrument interfaces. The board can also be used to prototype products with smaller feature sets or HiFi style products.
The Multichannel Audio Platform hardware is based around the XU316-1024-TQ128-C24 multicore microcontroller; an dual-tile xCORE.ai device with an integrated High Speed USB 2.0 PHY and 16 logical cores delivering up to 3200MIPS of deterministic and responsive processing power.
Exploiting the flexible programmability of the xCORE.ai architecture, the Multi-channel Audio Platform supports either USB or network audio source, streaming 8 analogue input and 8 analogue output audio channels simultaneously - at up to 192kHz.
The reference board has an associated firmware application that uses lib_xua to implemented a USB Audio Device. Full details of this application can be found later in this document.
Analogue Input & Output¶
A total of eight single-ended analog input channels are provided via 3.5mm stereo jacks. These inputs feed into a pair of quad-channel PCM1865 ADCs from Texas Instruments.
A total of eight single-ended analog output channels are provided. These a fed from a for PCM5122 stereo DAC’s from Texas instruments.
ADC’s and DAC’s are configured via an I2C bus.
The four digital I2S/TDM input and output channels are mapped to the xCORE input/outputs through a header array. These jumpers allow channel selection when the ADC/DAC is used in TDM mode
Digital Input & Output¶
Optical and coaxial digital audio transmitters are used to provide digital audio input output in formats such as IEC60958 consumer mode (S/PDIF) and ADAT. The output data streams from the xCORE are re-clocked using the external master clock to synchronise the data into the audio clock domain. This is achieved using simple external D-type flip-flops.
MIDI¶
MIDI I/O is provided on the board via standard 5-pin DIN connectors. The signals are buffered using 5V line drivers and are then connected to 1-bit ports on the xCORE, via a 5V to 3.3V buffer.
Audio Clocking¶
In order to accommodate a multitude of clocking options a flexible clocking scheme is provided for the audio subsystem.
Three methods of generating an audio master clock are provided on the board:
A Cirrus Logic CS2100-CP PLL device. The CS2100 features both a clock generator and clock multiplier/jitter reduced clock frequency synthesizer (clean up) and can generate a low jitter audio clock based on a synchronisation signal provided by the xCORE
A Skyworks Si5351B PLL device. The Si5351 is an I2C configurable clock generator that is ideally suited for replacing crystals, crystal oscillators, VCXOs, phase-locked loops (PLLs), and fanout buffers.
xCORE.ai devices are equipped with a secondary (or ‘application’) PLL which can be used to generate fixed audio clocks or recover external clocks using lib_sw_pll.
Selection between these methods is done via writing to bits 6 and 7 of PORT 8D on tile[0].
Either the locally generated clock (from the PL611) or the recovered low jitter clock (from the CS2100) may be selected to clock the audio stages; the xcore.ai, the ADC/DAC and Digital output stages. Selection is controlled via an additional I/O, bit 5 of PORT 8C, see Control I/O.
Control I/O¶
4 bits of PORT 8C are used to control external hardware on the board. This is described in PORT 8C functionality.
Bit(s) |
Functionality |
0 |
1 |
|---|---|---|---|
[0:3] |
Unused |
||
4 |
Enable 3v3 power for digital (inverted) |
Enabled |
Disabled |
5 |
Enable 3v3 power for analogue |
Disabled |
Enabled |
6 |
PLL Select |
CS2100 |
Si5351B |
7 |
Master clock direction |
Output |
Input |
Note
To use the xCORE application PLL bit 7 should be set to 0. To use one of the external PLL’s bit 7 should be set to 1.
Power¶
The board is capable of acting as a USB2.0 self or bus powered device. If bus powered, board takes power from USB DEVICE connector (micro-B receptacle).
If self powered, board takes power from EXTERNAL POWER input (micro-B receptacle).
A Power Source Select (marked PWR SRC) is used to select between bus and self-powered configuration.
Debug¶
For convenience the board includes an on-board xTAG4 for debugging via JTAG/xSCOPE. This is accessed via the USB (micro-B) receptacle marked DEBUG.