

# XMOS XVF3800 - Datasheet

Release: 2.0.0 Publication Date: 2023/07/03



# **Table of Contents**

| 1 |            |                                                    | 1             |
|---|------------|----------------------------------------------------|---------------|
|   | 1.1        | 5                                                  | 1             |
|   | 1.2<br>1.3 |                                                    | 1<br>1        |
|   | 1.3<br>1.4 | 5                                                  | 1             |
|   | 1.4        | 5                                                  | 1             |
|   |            |                                                    |               |
| 2 | <b>Pro</b> |                                                    | <b>2</b><br>2 |
|   | 2.1        |                                                    | 2<br>3        |
|   | 2.2        |                                                    | 3             |
|   | 2.4        |                                                    | 3             |
|   | 2.5        |                                                    | 4             |
| 3 | Void       | ce Processing Pipeline                             | 6             |
| Č | 3.1        |                                                    | 6             |
|   | 3.2        |                                                    | 6             |
|   |            |                                                    | 6             |
|   |            |                                                    | 7             |
|   |            |                                                    | 7             |
|   |            | 3.2.4 Post Processor                               | 7             |
|   | 3.3        | Input and Output                                   | 8             |
|   |            | 3.3.1 I <sup>2</sup> S Audio Interface             | 8             |
|   |            |                                                    | 8             |
|   |            | $\mathbf{v}$                                       | 8             |
|   | 3.4        | Key parameters                                     | 9             |
| 4 |            | ice Pinout 10                                      |               |
|   |            | Pin Configuration                                  |               |
|   | 4.2        | Signal Description                                 | 1             |
| 5 |            | ice Interfaces 1                                   |               |
|   | 5.1        | Audio Interfaces                                   |               |
|   |            | 5.1.1 Audio Master Clock (MCLK)                    |               |
|   |            | 5.1.2 PDM Microphone Inputs                        |               |
|   | F 0        | 5.1.3 Audio Interface                              |               |
|   | 5.2<br>5.3 | 5                                                  |               |
|   | 0.3        | System firmware   1     5.3.1   QSPI Boot Mode   1 |               |
|   |            | 5.3.2 Host boot via SPI                            |               |
|   | 5.4        | Device Control Interface                           |               |
|   | 0.4        | 5.4.1 USB Control Interface                        |               |
|   |            | 5.4.2 I <sup>2</sup> C Control Interface           |               |
|   |            | 5.4.3 SPI Control Interface                        |               |
|   | 5.5        | General Purpose Input/Output                       |               |
| 6 | Dev        | ice Operation 20                                   | 0             |
| Ŭ | 6.1        | Electrical and Thermal Characteristics             |               |
|   |            |                                                    |               |
|   | 6.2        | Power Supplies                                     | U             |
|   | 6.2<br>6.3 | Power Supplies 21   Clocks 2                       |               |
|   |            |                                                    | 1             |



|   | 6.6<br>6.7 | 6.5.1Slave Boot Mode6.5.2QSPI Master Boot ModeQSPI Flash SupportDevice Firmware (UA configurations) | 22<br>23 |
|---|------------|-----------------------------------------------------------------------------------------------------|----------|
| 7 | Swit       | tching Characteristics                                                                              | 25       |
|   |            | QSPI Master (External flash for boot image storage)                                                 |          |
|   | 7.2        | I <sup>2</sup> S Slave                                                                              | 25       |
|   | 7.3        | SPI Slave (External processor boot)                                                                 | 26       |
| 8 | Pac        | kage information                                                                                    | 27       |
|   | 8.1        | Package Dimensions                                                                                  | 27       |
|   | 8.2        | Device Markings                                                                                     |          |
|   | 8.3        | Moisture Sensitivity Level                                                                          | 28       |
|   | 8.4        | Hazardous Materials                                                                                 |          |
|   | 8.5        | Order Codes                                                                                         |          |

# 1 Key Features

The VocalFusion<sup>®</sup> XVF3800 is a high-performance voice processor that is optimised for voice communications with the following key features.

## 1.1 Voice Processing

- Four PDM microphone interfaces
- Digital signal processing pipeline
- Full duplex Acoustic Echo Cancellation (AEC)
- · Fast tracking Beamformer with multiple beams
- Dynamic Echo and Noise suppressor
- Automatic Gain Control (AGC)
- Limiter
- Indication of Direction of Arrival (DoA)

### **1.2 Device Interfaces**

- High speed USB2.0 compliant device supporting USB Audio Class (UAC) 2.0
- Reference audio via I<sup>2</sup>S or USB
- USB Endpoint 0 vendor specific device class based control interface
- I<sup>2</sup>C or SPI control interfaces

### 1.3 Firmware Management

- Boot from QSPI Flash
- Default firmware image for power-on operation
- Update image delivered via USB DFU
- Option to boot from a local host processor via SPI

### 1.4 Package

• 7 mm x 7 mm 60 pin QFN package

### **1.5 Power Consumption**

Typical power consumption 400 mW

# 2 Product Overview

## 2.1 Introduction

The XMOS VocalFusion ® XVF3800 is a high-performance voice processor that uses microphone array processing and a sophisticated audio processing pipeline to capture clear, high-quality speech from anywhere in a room. The XVF3800 uses the XMOS xcore.ai processor and supports a range of integrated and accessory voice communication applications.

The XVF3800 is a highly customisable design that combines an XMOS processor and application firmware into a single solution. It offers system designers the flexibility to integrate the XVF3800 into different designs. The xcore.ai processor has a powerful architecture which delivers high performance, real-time audio processing while the XVF3800 firmware is designed to be easily customized, allowing users to modify it as required.

In addition to the audio processing functions, the XVF3800 includes range of standard interfaces that enable it to be connected to a wide variety of devices. It supports a simple, intuitive control interface that enables designers to quickly and easily configure the system and perform common tasks.

The overall system context for the XVF3800 is shown below. In most applications the XVF3800 device will operate in conjunction with an external host processor.



Fig. 2.1: XVF3800 device system context

This datasheet describes the main functional blocks in the XVF3800 and includes a reference configuration for the device. Details of the firmware features and the configuration and customisation options are provided in the XVF3800 User Guide.

#### Important:

The information in this datasheet should be read in conjunction with the **XU316-1024-QF60B** datasheet which contains electrical, design and integration data for the xcore.ai processor.

xcore.ai datasheet: XU316-1024-QF60B

# 2.2 Voice Processing

The XVF3800 voice processor converts and enhances audio captured using four low-cost digital microphones. Processed audio streams are suitable for use in voice communications applications and benefit from a range of configurable audio processing techniques to allow customisation to the use case. The embedded audio processing provides the following features:

- 4 microphone far-field operation.
- Full 360-degree and 180-degree operation depending on microphone geometry.
- 16 kHz voice processing, with optional 16 kHz and 48 kHz interface sampling rates.
- Full duplex, mono, Acoustic Echo Cancellation accommodating highly reverberant environments. (Reference audio for cancellation provided via either an I<sup>2</sup>S or USB interface).
- Configurable bulk delay insertion to account for audio delays ensuring optimal echo cancellation with all audio output paths.
- Multi-beamforming and de-reverberation with coherent addition and suppression of room reflections through energy harvesting.
- Removal of coherent point noise sources using generalized side-lobe cancellation.
- · Stationary and non-stationary dynamic echo and noise suppression.
- Adjustable gain over a 60 dB range with automatic gain control.
- Audio output filtering and range limiter.
- Indication of Direction of Arrival (DoA) for the selected speaker.

## 2.3 Peripheral Interfaces

The XVF3800 voice processor provides the following additional interfaces to increase usability and reduce total system cost:

- 5 General Purpose Output (GPO) pins. These can be configured as simple digital I/O pins, Pulse Width Modulated (PWM) outputs and rate adjustable LED flashers.
- 2 General Purpose Input (GPI) pins. These can be used as simple logic inputs or event capture (edge detection).

These GPO can be controlled and the GPI states read by the host system over the control interface (SPI, I<sup>2</sup>C or USB, depending on the firmware configuration). A range of triggering conditions are supported and the INT\_N output can be used to signal an interrupt to the host system when a GPI is triggered. See the XVF3800 User Guide for further information.

# 2.4 System Firmware

The VocalFusion XVF3800 voice processor can be booted over SPI by a local host processor or from a separate, user-supplied, QSPI Flash memory.

**Note:** The two XVF3800 configurations: one providing  $|^2S/|^2C/SPI$  interface (XVF3800-INT) and one providing a USB interface (XVF3800-UA) are delivered as separate sets of firmware.

# 2.5 System Configurations

The XVF3800 can be configured to operate in a number of system designs and supports a range of interfaces. The main configurations are:

|            |                            | , ,              |                         |  |
|------------|----------------------------|------------------|-------------------------|--|
| Config     | Application                | Audio            | Control                 |  |
| INT-Device | Integrated voice processor | l <sup>2</sup> S | SPI or I <sup>2</sup> C |  |
| UA         | USB Accessory              | USB UAC 2.0      | USB Endpoint 0          |  |

The control interface is optional - the XVF3800 can be configured with optimised audio parameters as the default power-on settings.

Functional block diagrams of the XVF3800 in typical integrated and USB accessory applications are shown in the figures below.



Fig. 2.2: Functional block diagram of XVF3800 in INT-Device configuration



Fig. 2.3: Functional block diagram of XVF3800 in UA configuration



# 3 Voice Processing Pipeline

### 3.1 Overview and Key Features

The XVF3800 integrates a set of advanced Digital Signal Processing (DSP) algorithms that include Acoustic Echo Cancellation (AEC), beamforming, dereverberation, noise suppression and automatic gain control. These advanced DSP algorithms deliver high speech-to-noise ratio, naturally sounding speech and eliminate acoustic echo while maintaining a transparent and low latency communication link.

The key features of the XVF3800 solution are:

- High levels of Acoustic Echo Cancellation and Suppression in conferencing and living room conditions.
- State of the art, robust, and natural double-talk / full-duplex performance.
- High speech clarity level even when users are at several meters distance, without requiring directional microphones.
- Fast adaptive beamforming for tracking multiple near-end users.
- Stationary / diffuse noise suppression.
- Automatic gain control.

# 3.2 Main Functional Blocks

A high level diagram of the solution is shown below.





#### 3.2.1 Microphone Inputs

The XVF3800 captures voice signals through four digital microphones and converts them from Pulse Density Modulation (PDM) to Pulse Code Modulation (PCM). It passes the converted signals to the voice pipeline, along with the far-end signal that is played on the loudspeaker after having passed through a Digital to Analog Converter (DAC) and amplifier.



#### 3.2.2 Acoustic Echo Canceller

The first stage of the processing pipeline is the Acoustic Echo Canceller (AEC) which uses an adaptive filter to remove the echos of the far end signal from the microphone signals. Each of the microphone signals is processed independently and the output of the AEC is feed into the beamformer.

At startup the AEC calibrates the adaptive filters to match the acoustic path between the loudspeaker and the microphones. This requires some far end audio content to provide a signal to the device. If the AEC detects a significant change to the acoustic path during operation, e.g. if the device is moved, it will initiate a re-convergence operation.

#### 3.2.3 Beamformer

The beamformer block processes the AEC signals to select the desired speaker. The beamformer contains a set of adaptive filters that coherently add signals from the four microphones to select sounds from a specific direction. This operation enhances the speech to noise level in a specific direction and simultaneously reduces the effects of point noise sources and reverberation effects.

The XVF3800 implements three beams - one free running beam that scans the environment for new speakers, and two focused beams that can track individual speakers. The final stage of the pipeline automatically selects which beam to use as the output from the device.



Fig. 3.2: Beamformer Operation

It is possible to access information on the selected beams from the XVF3800 control interface. The device provides a Direction of Arrival (DoA) measurement indicating the direction of the selected beam.

#### 3.2.4 Post Processor

Outputs from the beamformer are fed to the post processing stage which further reduces reverberation and suppresses diffuse and point noise sources. This is followed by a gain control block which ensures a consistent output level regardless of the distance of the speaker from the microphone. The final output is passed through a limiter to ensure that any very loud signals do not overload the output.

The output from this pipeline is an enhanced speech signal of the desired near-end speech without echo and reverberation.



## 3.3 Input and Output

The XVF3800 supports two types of audio interface to transport audio to and from the host system; I<sup>2</sup>S or USB. These are mutually exclusive and selected when the firmware image is built.

#### 3.3.1 I<sup>2</sup>S Audio Interface

The XVF3800 supports I<sup>2</sup>S sample rates of 16 kHz or 48 kHz. Both input and output must use the same rate.

The audio pipeline processes data with a sample rate of 16 kHz so, if 48 kHz inputs are used, a Sample Rate Converter block is introduced into the signal path to adapt the rates. The sample rates are set in the firmware and cannot be changed during operation of the device. The bit depth of the samples is fixed at 32 bits.

When used in UA mode (host audio over USB) the XVF3800 has an active I<sup>2</sup>S master output which provides the far end signal to the DAC.

#### 3.3.2 USB Audio Interface

The XVF3800 implements a standard UAC 2.0 audio class in Adaptive Mode which is compatible with USB hosts supporting USB 2.0 and 3.0 interfaces. All major operating systems now support USB Audio Class 2 (UAC 2) devices natively without the requirement to install additional audio drivers.

In the UA configuration the XVF3800 audio sample rate can be either 16 kHz or 48 kHz (fixed at build time) and must be the same as the output rate used for the DAC attached to the  $I^2S$  output. The bit depths of the USB samples can be either 16, 24, or 32 (fixed at build time).

#### 3.3.3 Reference Signal for AEC

The XVF3800 supports a monophonic audio output and uses a single channel to provide the reference signal for the acoustic echo canceller (AEC). A far-end AEC reference signal must be provided on the left (0) channel of the I<sup>2</sup>S or USB input signal. Data on the right channel is ignored.



# 3.4 Key parameters

The key operating parameters of the audio processing pipeline are shown in the table below.

| Parameter                         | Value               | Notes                                          |
|-----------------------------------|---------------------|------------------------------------------------|
|                                   |                     |                                                |
| Microphones                       | 4 off PDM           | eg Infineon IM69D130                           |
| Microphone alignment              | +/- 2 dB            |                                                |
| Geometry                          | Linear or Square    |                                                |
| Frequency range                   | 80 Hz to 8 kHz      |                                                |
| Sampling Rate                     | 16 kHz              |                                                |
| AEC tail length                   | 192 ms              |                                                |
| AEC reference channels            | 1 mono              | Output to DAC                                  |
| Double Talk Detection             | Continous           |                                                |
| Reference delay                   | 0 to 500 ms (fixed) | Align mic & ref signal                         |
| Number of beams                   | 3                   | 2 focused + 1 scanning                         |
| Beamformer angle                  | 360 degrees         |                                                |
| Noise suppression                 | up to 25 dB         | depending on input SNR                         |
| Operating distance                | 0.3 m to 5 m        |                                                |
| Beamformer update time            | 16 ms               |                                                |
| Input delay                       | min 72 ms           | Mic In to I <sup>2</sup> S out                 |
| Output delay                      | typ 50 ms           | If far end processing on device is implemented |
| I <sup>2</sup> S or USB rate      | 16 kHz or 48 kHz    | Firmware options                               |
| I <sup>2</sup> S sample bit depth | 32 bits             |                                                |
| Input USB sample bit depth        | 16, 24 or 32 bits   | Firmware options                               |
| Output USB sample bit depth       | 16, 24 or 32 bits   | Firmware options                               |
| Internal PLL range                | +/- 1000 ppm        | Meets USB Adaptive audio tolerance             |

| Table 3.1: | Pipeline | paramenters |
|------------|----------|-------------|
|------------|----------|-------------|

Additional information on the operation of the audio pipeline and the control interface can be found in the XVF3800 User Guide.

## 4.1 Pin Configuration

The pinout of the XVF3800, including all optional interfaces, is shown in the figure below. Some of the pin descriptions indicate how these pins are allocated on the XMOS XK-VOICE-SQ66 development kit development kit (DVK), but they can be re-configured in the firmware for other uses.



VDDIOT, VDDIOL and VDDIOR must be connected a 3V3 supply. VDDIO18 must be connected to a 1V8 supply, and all VDD pins must be connected to a 0V9 supply. All package paddles (pins 61 through 65) must be connected. It is advised to place a via under each paddle to connect it directly to a PCB supply plane.



# 4.2 Signal Description

The table below lists the functions of all the pins above in the order they appear around the package.

| Pin# | Pin name | Signal name | Description                                              | Comments                                                                                                                                                                                                                                                                                                 | Dir                             | Power       |
|------|----------|-------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------|
| 1    | X0D05    | QSPI_D1     | QSPI Data Line 1<br>and boot selec-<br>tion.             | If pin is tied high via a 4.7k<br>ohm resistor on startup the<br>device will start in SPI slave<br>boot mode. If the pin is left<br>floating or connected to a<br>quad SPI D1 pin on a mem-<br>ory device the device will<br>start in QSPI master mode<br>and attempt to boot from<br>QSPI flash memory. | (I/O)<br>I/O                    | rail<br>IOL |
| 2    | X0D07    | QSPI_D3     | QSPI Data Line 3                                         |                                                                                                                                                                                                                                                                                                          | 1/0                             | IOL         |
| 3    | X0D01    | QSPI_CS_N   | QSPI Boot Flash -<br>Chip Select                         | Pull high externally to the device using a 4.7k ohm resistor                                                                                                                                                                                                                                             | 0                               | IOL         |
| 5    | X0D10    | QSPI_CLK    | QSPI Clock                                               |                                                                                                                                                                                                                                                                                                          | 0                               | IOL         |
| 6    | XODOO    | SPI_CS_N    | Slave SPI boot<br>/ Peripheral SPI<br>Master Chip Select | Pull high externally to the device using a 4.7k ohm re-<br>sistor                                                                                                                                                                                                                                        |                                 | IOL         |
| 7    | X0D11    | SPI_MOSI    | SPI Master Out<br>Slave In                               |                                                                                                                                                                                                                                                                                                          | 1                               | IOL         |
| 8    | VDDIOL   | VDDIOL      | I/O Power Supply<br>(3V3)                                | All VDD pins must be con-<br>nected.                                                                                                                                                                                                                                                                     | PWR                             |             |
| 9    | X1D00    | I2S_DATA0   | I <sup>2</sup> S Data                                    | Reference input in INT-<br>Device configuration /<br>Output in USB and INT-<br>Host configurations                                                                                                                                                                                                       | 1/0                             | IOL         |
| 10   | X1D01    | I2S_LRCK    | I <sup>2</sup> S Left/Right clock                        | 48 kHz or 16 kHz clock de-<br>rived as I2S_BLCK/64.                                                                                                                                                                                                                                                      | 0<br>(mas-<br>ter)/I<br>(slave) | IOL         |
| 11   | X1D09    | P_BUTTON_0  | Button input 0                                           | Active low with 10k pullup<br>on DVK                                                                                                                                                                                                                                                                     | 1                               | IOL         |
| 13   | X1D10    | I2S_BCLK    | I <sup>2</sup> S bit synchroni-<br>sation clock          | Configurable for 16 kHz<br>(1.024 MHz) and 48 kHz<br>(3.072 MHz) sample rates                                                                                                                                                                                                                            | 0<br>(mas-<br>ter)/I<br>(slave) | IOL         |
| 14   | X1D11    | MCLK_INOUT  | Master audio<br>clock                                    | An output copy of the<br>internally generated MCLK.<br>Must be connected to Pin<br>41. On 'extmclk' INT-Device<br>configurations, an input<br>pin accepting an external<br>MCLK.                                                                                                                         | 1/0                             | IOL         |
| 15   | XOUT     | XOUT        | Crystal oscillator<br>output                             | Note that this pin should be<br>left floating when using the<br>CMOS clock input                                                                                                                                                                                                                         | 0                               | IOB         |
| 16   | XIN      | XIN         | Crystal oscillator<br>input                              | Alternatively this can be used as a clock input                                                                                                                                                                                                                                                          | I                               | IOB         |

#### Table 4.1: XVF3800 QF60B Pin Table

continues on next page

| Pin# | Pin name       | Signal name | Description           | Comments                                               | Dir   | Power |
|------|----------------|-------------|-----------------------|--------------------------------------------------------|-------|-------|
|      |                |             |                       |                                                        | (I/O) | rail  |
| 17   | VDDIOB18       | VDDIOB18    | I/O Power Supply      | 1V8 supply must be con-                                | PWR   |       |
| 10   | TO             | TDI         | (1v8)                 | nected.                                                |       |       |
| 18   | TDI            | TDI         | JTAG test data in-    | This pin has a weak internal                           |       | IOB   |
|      |                |             | put                   | pull-up. See note on debug<br>headers.                 |       |       |
| 20   | TDO            | TDO         | JTAG test data        | neauers.                                               | 0     | IOB   |
| 20   | TDO            | TDO         | output                |                                                        |       |       |
| 21   | RST_N          | RST_N       | Device reset          | Active low. This pin has a                             |       | IOB   |
| 21   |                |             | Device reset          | Schmitt trigger input and an                           |       |       |
|      |                |             |                       | internal weak pull up                                  |       |       |
| 22   | PLL_AVDD       | PLL_AVDD    | Analogue power        | Use a filtered version of                              | PWR   |       |
|      |                |             | supply for core       | the core supply as per                                 |       |       |
|      |                |             | and application       | the XU316-1024-QF60B                                   |       |       |
|      |                |             | PLL.                  | datasheet.                                             |       |       |
| 23   | TMS            | TMS         | JTAG test mode        | This pin has a weak internal                           | 1     | IOB   |
|      |                |             | select                | pull-up. See note on debug                             |       |       |
|      |                |             |                       | headers.                                               |       |       |
| 24   | ТСК            | TCK         | JTAG test clock in-   | This pin has a Schmitt trig-                           | 1     | IOB   |
|      |                |             | put                   | ger input and an internal                              |       |       |
|      |                |             |                       | weak pull-down. See note                               |       |       |
| 05   | NO             | NO          | Nia Oscarativa        | on debug headers.                                      |       |       |
| 25   | NC             | NC          | No Connection         | Not connected. This pin                                | NA    | IOB   |
|      |                |             |                       | MUST NOT be connected                                  |       |       |
| 26   | VDDIOB18       | VDDIOB18    | I/O Power Supply      | to any net<br>1V8 supply must be con-                  | PWR   |       |
| 20   | VDDIOBIO       | VDDIOBIO    | (1v8)                 | nected.                                                |       |       |
| 28   | USB_DM         | USB_DM      | USB D- line           | May be left floating if USB is                         | 1/0   |       |
| 20   |                |             |                       | not required                                           |       |       |
| 29   | USB_DP         | USB_DP      | USB D+ line           | May be left floating if USB is                         | 1/0   |       |
|      |                |             |                       | not required                                           |       |       |
| 30   | USB_VDD33A     | USB_VCC33A  | 3.3V power for the    | May be left floating if USB is                         | PWR   |       |
|      |                |             | USB transceiver.      | not required                                           |       |       |
| 31   | USB_VDD18A     | USB_VCC18A  | 1.8V power for the    | May be left floating if USB is                         | PWR   |       |
|      |                |             | USB transceiver.      | not required                                           |       |       |
| 32   | X1D13          | P_BUTTON_1  | Button input 1        | Active low with 10k pullup                             |       | IOR   |
|      | V1D10          |             |                       | on DVK                                                 |       |       |
| 33   | X1D16          | XL_DN1      | XLINK                 | The 4 XL_DNx signals form                              |       | IOR   |
|      |                |             |                       | a single 2-wire xlink con-<br>nection for advanced de- |       |       |
|      |                |             |                       | bug only                                               |       |       |
| 35   | X1D17          | XL_DN0      | XLINK                 | Debug port                                             |       | IOR   |
| 36   | X1D17<br>X1D18 | XL_UP0      | XLINK                 | Debug port                                             | 0     | IOR   |
| 37   | X1D19          | XL_UP1      | XLINK                 | Debug port                                             | 0     | IOR   |
| 38   | VDDIOR         | VDDIOR      | I/O Power Supply      | All VDD pins must be con-                              | PWR   |       |
| ~~   |                |             | (3V3)                 | nected.                                                |       |       |
| 39   | X1D22          | I2S_DATA1   | I <sup>2</sup> S Data | Audio data out to host pro-                            | 1/0   | IOR   |
|      |                |             |                       | cessor in INT-Device config.                           |       |       |
|      |                |             |                       | Optional reference input in                            |       |       |
|      |                |             |                       | INT-Host config                                        |       |       |
| 40   | X0D29          | CODEC       | GPO for driving       | -                                                      | 0     | IOR   |
|      |                | _RST_N      | reset of conected     |                                                        |       |       |
|      |                |             | DAC or digital        |                                                        |       |       |
|      |                |             | amplifier             |                                                        |       | 1     |

| Table | 4.1 – continued from previous | nage |
|-------|-------------------------------|------|
| rabic |                               | page |

continues on next page

| Pin# | Pin name | Signal name | Description                                                         | Comments                                                                                                                                                                                                                                                | Dir   | Power |
|------|----------|-------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|
|      |          |             |                                                                     |                                                                                                                                                                                                                                                         | (I/O) | rail  |
| 41   | X0D35    | MCLK        | Master audio<br>clock input used<br>for generating<br>PDM MIC clock | Audio clock input to tile 0.<br>Connect to MCLK_INOUT<br>(Pin 14)                                                                                                                                                                                       | 1     | IOR   |
| 43   | X0D36    | MIC_CLK     | Microphone clock<br>output                                          | 3.072 MHz output to PDM microphones                                                                                                                                                                                                                     | 0     | IOR   |
| 44   | X0D37    | I2C_SCL     | I <sup>2</sup> C serial clock                                       | I <sup>2</sup> C serial clock line for re-<br>ceiving control command<br>from I <sup>2</sup> C host or controlling<br>DAC (depending on config)                                                                                                         | 1/0   | IOR   |
| 45   | X0D38    | I2C_SDA     | I <sup>2</sup> C serial data                                        | I <sup>2</sup> C serial data line for re-<br>ceiving control command<br>from I <sup>2</sup> C host or controlling<br>DAC (depending on config)                                                                                                          | 1/0   | IOR   |
| 46   | X0D40    | MIC_DATA0   | Microphone input<br>0                                               | Single data rate                                                                                                                                                                                                                                        | I     | IOT   |
| 47   | X0D39    | SPI_MISO    | SPI Master In<br>Slave Out.                                         | Only used when XVF3800<br>is a SPI controlled device.<br>Not used by SPI slave boot.                                                                                                                                                                    | 0     | IOT   |
| 48   | X0D42    | MIC_DATA2   | Microphone input<br>2                                               | Single data rate                                                                                                                                                                                                                                        | 1     | IOT   |
| 50   | X0D41    | MIC_DATA1   | Microphone input                                                    | Single data rate                                                                                                                                                                                                                                        | 1     | IOT   |
| 51   | X0D43    | MIC_DATA3   | Microphone input<br>3                                               | Single data rate                                                                                                                                                                                                                                        | 1     | IOT   |
| 52   | VDDIOT   | VDDIOT      | I/O Power Supply<br>(3V3)                                           | All VDD pins must be con-<br>nected.                                                                                                                                                                                                                    | PWR   |       |
| 53   | X1D34    | I2S_DATA2   | I <sup>2</sup> S Data                                               | Optional third I <sup>2</sup> S data line<br>for forwarding processed<br>far-end in INT-Device con-<br>fig. Connected to aux in-<br>put of DAC on DVK to allow<br>SW configurability. May be<br>used as a GPIO when not<br>assigned to I <sup>2</sup> S | 0     | IOT   |
| 54   | X0D30    | SQ_nLIN     | GPO for selecting<br>topology mode of<br>mics on DVK                |                                                                                                                                                                                                                                                         | 0     | IOT   |
| 55   | X0D31    | INT_N       | GPO for signalling<br>an interrupt to the<br>host                   |                                                                                                                                                                                                                                                         | 0     | IOT   |
| 56   | X0D32    | LED_R       | Red element of tri-<br>colour LED on DVK                            |                                                                                                                                                                                                                                                         | 0     | IOT   |
| 58   | X0D33    | LED_G       | Green element of<br>tri-colour LED on<br>DVK                        |                                                                                                                                                                                                                                                         | 0     | IOT   |
| 59   | X0D04    | QSPI_D0     | QSPI Boot Flash /<br>QSPI Data Line 0                               |                                                                                                                                                                                                                                                         | 1/0   | IOL   |
| 60   | X0D06    | QSPI_D2     | QSPI Data Line 2                                                    |                                                                                                                                                                                                                                                         | 1/0   | IOL   |

| Table 4.1 – continued fror | n previous page |
|----------------------------|-----------------|

continues on next page

| Pin#                                               | Pin name | Signal name | Description                | Comments                                                                                                                                    | Dir<br>(I/O) | Power<br>rail |
|----------------------------------------------------|----------|-------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------|
| 65                                                 | GND      | GND         | Ground                     | All package paddles must<br>be connected. It is advised<br>that vias be placed under<br>paddles to connect directly<br>to PCB supply planes | GND          |               |
| 61,<br>62,<br>63,<br>64                            | VDD      | VDD         | Core power supply<br>(0v9) | All package paddles must<br>be connected. It is advised<br>that vias be placed under<br>paddles to connect directly<br>to PCB supply planes | PWR          |               |
| 4,<br>12,<br>19,<br>27,<br>34,<br>42,<br>49,<br>57 | VDD      | VDD         | Core power supply<br>(0v9) | All VDD pins must be con-<br>nected.                                                                                                        | PWR          |               |

#### Note:

- A. All VDD pins must be connected, excluding the USB\_VDD supplies which can be left floating if USB is not required.
- B. VDDIOT, VDDIOL and VDDIOR must be connected to a 3V3 supply.
- C. VDDIO18 must be connected to a 1V8 supply.
- D. All package paddles must be connected. It is advised to place a via under each paddle to connect directly to a PCB supply plane.
- E. The function of some pins change depending on the firmware configuration loaded during boot.

# 5 Device Interfaces

The XVF3800 supports a range of interfaces which allows the device to be integrated into multiple applications.

### 5.1 Audio Interfaces

#### 5.1.1 Audio Master Clock (MCLK)

The XVF3800 uses a master audio clock (MCLK) to drive the internal pipeline processing.

The MCLK signal can be derived one of two sources.

#### 1 - Internal MCLK

The MCLK signal is generated internally in the XVF3800 using a Phase Locked Loop (PLL) that uses the I<sup>2</sup>S clock or USB frame clock as the timing reference.

| Signal     | Description                                     | Comment                                                                 | Pin | I/O |
|------------|-------------------------------------------------|-------------------------------------------------------------------------|-----|-----|
| MCLK_INOUT | Master audio clock<br>output                    | Output - Connect to pin 41                                              | 14  | 0   |
| MCLK       | Master audio clock                              | Connect to pin 14                                                       | 41  | I   |
| I2S_BCLK   | I <sup>2</sup> S bit synchronisa-<br>tion clock | Configurable for 16 kHz (1.024 MHz) and 48 kHz (3.072 MHz) sample rates | 13  |     |
| I2S_LRCK   | I <sup>2</sup> S Left/Right clock               |                                                                         | 10  |     |

#### Table 5.1: Signal in internal MCLK mode

**Note:** This mode is the only clock mode supported in the UA configurations. The audio output stream provides the reference signal for the internal PLL.

#### 2 - External MCLK

The host system can supply a master clock to the XVF3800. This signal must be synchronised to the I<sup>2</sup>S clock for correct operation. A 12.288 MHz clock frequency is recommended, but this can be modified in the system firmware if required.

| Signal     | Description                   | Comment             | Pin | I/O |
|------------|-------------------------------|---------------------|-----|-----|
| MCLK_INOUT | Master audio clock in-<br>put |                     | 14  | Ι   |
| MCLK       | Master audio clock            | Connected to pin 14 | 41  |     |

Note: The XVF3800 requires 32b clocks per sample on the I<sup>2</sup>S interface.

#### 5.1.2 PDM Microphone Inputs

Four standard PDM MEMS microphones should be connected to the MIC\_DATA[0..3] pins. The XVF3800 outputs a clock at 3.072 MHz on the MIC\_CLK output, which must be fed directly to all microphones. This clock is derived from the MLCK and must be used to clock the microphone PDM output to avoid undefined artefacts in the processed audio stream.

The XVF3800 voice processor has been tested and characterised with microphones in a linear array placed with a 33 mm separation and a square array with a 66 mm spacing. Other spacings with a maximum spacing of 100 mm are possible, but uncharacterised.

These microphones should be connected to the product enclosure in such a way that the acoustic path to each microphone from outside the product is independent. The XVF3800 algorithms are configured as part of the firmware build configuration.

#### 5.1.3 Audio Interface

The XVF3800 supports a flexible set of audio interface types. The specific interfaces of a device is set by the configuration chosen when the firmware image is built.

In INT-Device configurations the XVF3800 operates as an  $I^2S$  slave receiving a reference audio signal from the host and returning processed microphone signals to the host. This bidirectional flow of audio samples must be synchronised to a single set of  $I^2S$  clocks, see the table below:

| Signal    | Description                       | Comment                                           | Pin | I/O |
|-----------|-----------------------------------|---------------------------------------------------|-----|-----|
| MCLK      | Master audio clock                |                                                   | 14  | I/O |
| I2S_BCLK  | I <sup>2</sup> S bit synchronisa- | Configurable for 16 kHz (1.024 MHz) and 48 kHz    | 13  |     |
|           | tion clock                        | (3.072 MHz) sample rates                          |     |     |
| I2S_LRCK  | I <sup>2</sup> S Left/Right clock | 48 kHz or 16 kHz clock derived as I2S_BLCK/64     | 10  |     |
| I2S_DATA0 | I <sup>2</sup> S Data In          | Reference audio data from I <sup>2</sup> S device | 9   |     |
| I2S_DATA1 | I <sup>2</sup> S Data Out         | Audio data out to host processor                  | 39  | 0   |
| I2S_DATA2 | I <sup>2</sup> S Data Out         | Audio data out to DAC                             | 53  | 0   |

Table 5.3: I<sup>2</sup>S signals in INT-Device configurations

The I<sup>2</sup>S audio samples are transmitted serially with a delay of one I2S\_BCLK cycle between the change of I2S\_LRCK phase and the start (MSB) of the audio sample for that channel. This the standard alignment for I<sup>2</sup>S systems.

In UA configurations the audio signals to and from the host system are carried over a USB connection. The XVF3800 operates in USB Adaptive Mode to synchronise with the host. In this configuration the I<sup>2</sup>S interface operates in master mode to supply the far end audio signal to the DAC driving the speaker.

| Signal    | Description                       | Comment                                        | Pin | I/O |
|-----------|-----------------------------------|------------------------------------------------|-----|-----|
| MCLK      | Master audio clock                |                                                | 14  | I/O |
| I2S_BCLK  | I <sup>2</sup> S bit synchronisa- | Configurable for 16 kHz (1.024 MHz) and 48 kHz | 13  | 0   |
|           | tion clock                        | (3.072 MHz) sample rates                       |     |     |
| I2S_LRCK  | I <sup>2</sup> S Left/Right clock | 48 kHz or 16 kHz clock derived as I2S_BLCK/64  | 10  | 0   |
| I2S_DATA0 | I <sup>2</sup> S Data Out         | Audio data out to DAC                          | 9   | 0   |
| I2S_DATA1 | I <sup>2</sup> S Data In          | Optional reference audio data in               | 39  |     |

#### Table 5.4: Audio signals in UA configurations



# 5.2 Integrated USB Interface

The XVF3800 includes an integrated USB 2.0 PHY supporting Audio Class 2.0 running at High Speed (480 Mbps). This interface is used by the USB host to output a far end signal to a DAC and loudspeaker, to receive processed microphone signals from the XVF3800 audio pipeline and to allow the host to control the operation of the device. In this mode the adaptive USB Audio endpoint is used to generate an MCLK synchronised to the USB host output stream rate. This is provided via the MCLK output on the device. In the case of no output stream being available, the MLCK output is set to a nominal 12.288 MHz.

The table below shows the signals required to implement a USB interface using the XVF3800.

| Table | 5.5  | USB | connections |
|-------|------|-----|-------------|
| Tubic | 0.0. | 000 | Connections |

| Name      | Description                                                                      | Pin |
|-----------|----------------------------------------------------------------------------------|-----|
| USB_DP    | Connect to USB connector                                                         | 29  |
| USB_DM    | Connect to USB connector                                                         | 28  |
| USB_VBUS  | Do not connect Self-powered operation is not supported by current device         | 43  |
| _DET      | firmware                                                                         |     |
| USB_VDD18 | 1.8V supply for USB-PHY - May be left floating if the USB interface is not used  | 31  |
| USB_VDD33 | 3.3V supply to the USB-PHY May be left floating if the USB interface is not used | 30  |

## 5.3 System firmware

#### 5.3.1 QSPI Boot Mode

When QSPI boot mode is enabled (default), the XVF3800 enables six QSPI pins and drives the QSPI clock as a QSPI Master.

For further information about the boot sequence refer to the XU316-1024-QF60B datasheet.

#### 5.3.2 Host boot via SPI

The SPI interface can be utilised by a host controller to download the XVF3800 firmware to boot the device. Details of the SPI boot protocol can be found in the XVF3800 User Guide.

To enable the SPI boot from an external host processor, the QSPI\_D1/BOOTSEL should be pulled to VDDIO on power-up. This activates the SPI interface, which operates as a slave to the host processor for the transfer of the boot image, which is clocked in with the least significant bit first in each transferred byte.

This is an alternative to using an attached QSPI flash to automatically transfer boot data on start-up.

The SPI pins are shown in the table below.

| Signal   | Description                | Comment                                                      | Pin | <b>I/O</b> |
|----------|----------------------------|--------------------------------------------------------------|-----|------------|
| SPI_CLK  | SPI Clock                  |                                                              | 5   | I          |
| SPI_CS_N | SPI Chip Select            | Pull high externally to the device using a 4.7k ohm resistor | 6   |            |
| SPI_MOSI | SPI Master Out Slave<br>In |                                                              | 7   |            |
| SPI_MISO | SPI Master In Slave<br>Out | May be left floating if not required                         | 47  | 0          |

Table 5.6: SPI signals



# 5.4 Device Control Interface

The XVF3800 has a control framework that can be used to update device parameters and read data from the audio pipeline and the I/O pins.

Three protocols options are supported - USB, SPI or  $I^2C$ . The protocol is set as a compile time option when the firmware image is built. Only one protocol can be active in a specific configuration, but the same control commands are available via all interface types.

**Warning:** Some commands have no effect on device operation if they are not valid for the configuration in use.

A host control application is provided in the firmware release package that implements the control protocol and provides a user interface for the XVF3800 device.

**Note:** Only one control protocol, USB, SPI or I<sup>2</sup>C can be used in a specific implementation. This choice is set in the firmware and cannot be changed during operation of the device.

#### 5.4.1 USB Control Interface

In the UA configuration of the XVF3800, the control interface is available via the USB Endpoint 0.

#### 5.4.2 I<sup>2</sup>C Control Interface

The I<sup>2</sup>C slave interface is used to control and configure the parameters on the XVF3800.

The interface operates with the following specifications:

- 100 kbps SCL clock speed
- Register read/write
- Up to 60 byte I<sup>2</sup>C read/write

The device I<sup>2</sup>C address is 0x2C, and the pin connections are shown below.

| Signal  | Description                                                                                 | Com-<br>ment | Pin | I/O |
|---------|---------------------------------------------------------------------------------------------|--------------|-----|-----|
| I2C_SCL | I <sup>2</sup> C serial clock line for receiving control command from I <sup>2</sup> C host |              | 44  | 1/0 |
| I2C_SDA | I <sup>2</sup> C serial data line for receiving control command from I <sup>2</sup> C host  |              | 45  | I/0 |

| Table 5.7: I <sup>2</sup> C slave connec | tions |
|------------------------------------------|-------|
|------------------------------------------|-------|

#### 5.4.3 SPI Control Interface

The SPI slave interface can used to control and configure the parameters on the XVF3800.

**Note:** Only one control protocol, SPI or  $I^2C$  can be used in a specific implementation. This choice is set in the firmware and cannot be changed while the device is operating.



For more information on control and configuration of the XVF3800 please refer to the User Guide.

## 5.5 General Purpose Input/Output

Two input and five output pins are provided to allow general-purpose I/O (GPIO) such as LEDs and button controls. Input pins can be individually read by the host using the control interface and configured to detect edge events. The output pins can be individually set, and they have configurable Pulse Width Modulated (PWM) brightness control with blinking sequences.

The INT\_N pin provides a hardware interrupt to the host system to indicate if a GPI has been triggered. The behaviour of this pin, e.g. which GPI, which edge etc, can be configured in via the control interface.

The standard allocation of the GPIO pins in the XK-VOICE-SQ66 development kit is shown in the table below, but these can be adapted in the device firmware for other uses if required for a specific design.

| Name        | Description                                                | Pin | I/O |
|-------------|------------------------------------------------------------|-----|-----|
| P_BUTTON_0  | Input for 'Mute' button                                    | 11  |     |
| P_BUTTON_1  | Input for 'Action' button                                  | 32  |     |
|             |                                                            |     |     |
| CODEC_RST_N | GPO for driving reset of conected DAC or digital amplifier | 40  | 0   |
| SQ_nLIN     | GPO for selecting topology mode of mics                    | 54  | 0   |
| INT_N       | GPO for signalling an interrupt to the host                | 55  | 0   |
| LED_R       | Red element of tri-colour LED                              | 56  | 0   |
| LED_G       | Green element of tri-colour LED                            | 57  | 0   |

#### Table 5.8: GPIO pin table

For more information on configuring these inputs and outputs, please refer to the XVF3800 User Guide.



# 6 Device Operation

### 6.1 Electrical and Thermal Characteristics

For electrical and thermal characteristics, including Absolute Maximum ratings please refer to the XU316-1024-QF60B datasheet XU316-1024-QF60B

# 6.2 Power Supplies

The XVF3800 has the following power supply pins:

| Name      | Description                                                                                                                            | Pin                          |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| VDD       | Digital core power supply. 0.9 V (nominal)                                                                                             | 4 12 19 27 34<br>42 49 57 61 |
|           |                                                                                                                                        | 62 63 64                     |
| V_DDIOL   | Digital I/O power supply. 3.3 V (nominal)                                                                                              | 8                            |
| V_DDIOR   | Digital I/O power supply. 3.3 V (nominal)                                                                                              | 38                           |
| V_DDIOT   | Digital I/O power supply. 3.3 V (nominal)                                                                                              | 52                           |
| VDD IOB18 | Digital I/O power supply. 1.8 V (nominal)                                                                                              | 17 - 26                      |
| PLL_AVDD  | PLL analogue power. This 0.9 V (nominal) PLL supply should be sep-<br>arated from the other supplies at the same voltage by a low pass | 22                           |
|           | filter                                                                                                                                 |                              |
| USB_VDD18 | Digital supply to the USB-PHY. 1.8 V (nominal)                                                                                         | 31                           |
| USB_VDD33 | Analogue supply to the USB-PHY. 3.3 V (nominal)                                                                                        | 30                           |
| VSS       | Device Ground                                                                                                                          | 65 (Paddle)                  |

#### Table 6.1: XVF3800 Power Pins

Note: A: All VDD power pins must be connected.

B: USB\_VDDxx supplies can be left floating if USB is not used.

#### See also:

The XU316-1024-QF60B datasheet contains further information on power supplies and power on sequencing.

# 6.3 Clocks

The XVF3800 device has an on-chip oscillator. To use the oscillator, you need to connect a crystal, two capacitors, and damping and feedback resistors to the device as shown below.

| Signal | Description               | Comment | Pin | I/O |
|--------|---------------------------|---------|-----|-----|
| XIN    | Crystal oscillator input  |         | 16  |     |
| XOUT   | Crystal oscillator output |         | 15  | 0   |







Fig. 6.1: Crystal oscillator or clock input configurations

Alternatively, the XVF3800 can be provided with a 24 MHz, 1V8 clock input on the XIN pin. The clock must be running when the chip comes out of reset.

| Table 6.3: XVF3800 ( | clock signals |
|----------------------|---------------|
|----------------------|---------------|

| Signal | Description           | Comment                              | Pin | <b>I/O</b> |
|--------|-----------------------|--------------------------------------|-----|------------|
| XIN    | Master clock (system) | 24 MHz 1V8 clock signal              | 16  |            |
| XOUT   | N/C                   | Leave floating if clock input on XIN | 15  | 0          |

#### See also:

For further information, and details on the calculation of  $R_f$  and  $R_d$ , please refer to the XU316-1024-QF60B datasheet.

### 6.4 Reset

The XVF3800 device has an on-chip Power-on-Reset (POR). This keeps the chip in reset whilst the supplies are coming up.

See XU316-1024-QF60B datasheet for further information.

#### Table 6.4: Reset Signal

| Signal | Description  | Comment    | Pin I/O |
|--------|--------------|------------|---------|
| RST_N  | Device reset | Active low | 21 I    |

## 6.5 Boot Modes

On start-up and after a reset event, the XVF3800 is booted either using an externally connected QSPI flash memory or by transferring a boot image to the device via SPI from a host processor.

#### 6.5.1 Slave Boot Mode

The boot mode is specified using QSPI\_D1/BOOTSEL. If this pin is tied high via a 4.7k ohm resistor on start-up, the XVF3800 will enable SPI slave boot mode and activate the pins shown below.

| Signal              |   | Description                | Comment                                                      | Pin | I/O |  |
|---------------------|---|----------------------------|--------------------------------------------------------------|-----|-----|--|
| QSPI_CLK<br>SPI_CLK | / | SPI Clock                  |                                                              | 5   | l   |  |
| SPI_CS_N            |   | SPI Chip Select            | Pull high externally to the device using a 4.7k ohm resistor | 6   | I   |  |
| SPI_MOSI            |   | SPI Master Out Slave<br>In |                                                              | 7   | I   |  |
| SPI_MISO            |   | SPI Master In Slave<br>Out |                                                              | 47  | 0   |  |

| Table 6.5: SPI | slave | boot | pins |
|----------------|-------|------|------|
|----------------|-------|------|------|

#### 6.5.2 QSPI Master Boot Mode

If the QSPI\_D1/BOOTSEL pin is connected to a QSPI\_D1 pin on a flash device, the XVF3800 will boot from a local QSPI flash in QSPI master mode. The active pins are shown below.

| Table 6.6: QSPI master peripher | al interface pins |
|---------------------------------|-------------------|
|---------------------------------|-------------------|

| Name                  | Description                                                                                                                                   | Pin | <b>I/O</b> |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|------------|
| QSPI_CS_N             | QSPI Chip Select. This pin should be pulled high externally to the device using a 4.7k ohm resistor                                           | 3   | 1/0        |
| QSPI_D0               | QSPI Data Line 0                                                                                                                              | 59  | 1/0        |
| QSPI_D1 /<br>BOOTSEL  | QSPI Data Line 1 and boot selection. To activate QSPI master boot mode con-<br>nect directly to QSPI Data Line 1 on Quad capable flash device | 1   | 1/0        |
| QSPI_D2               | QSPI Data Line 2                                                                                                                              | 60  | 1/0        |
| QSPI_D3               | QSPI Data Line 3                                                                                                                              | 2   | 1/0        |
| QSPI_CLK /<br>SPI_CLK | QSPI Clock and SPI Clock                                                                                                                      | 5   | I/0        |

A READ command is issued with a 24-bit address 0x000000. The XVF3800 expects each byte to be transferred with the least-significant nibble first. Programmers that write bytes into a QSPI interface using the most significant nibble first may have to reverse the nibbles in each byte of the image stored in the QSPI device. When bulk programming flash devices the Quad Enable bit in the flash setting register should be set.

## 6.6 **QSPI Flash Support**

When a flash memory device is used to store the firmware for the XVF3800, the minimum storage space required is 2 Mbytes.

Flash devices with the following specifications are supported by the XVF3800 (e.g. Winbond W25Q16JWSNIM).

| Device characteristic                     | Description                                                               | Value                                 |
|-------------------------------------------|---------------------------------------------------------------------------|---------------------------------------|
| Page size                                 | Size of flash page in bytes                                               | 256                                   |
| Number of pages                           | Total number of pages                                                     | 8192                                  |
| Address size                              | Number of bytes used to represent the address                             | 3                                     |
| Read ID operation code                    | Operation code to read the device identification (ID) information         | 0x9F                                  |
| Read ID dummy bytes                       | Number of dummy bytes after read command before ID is returned            | 0                                     |
| ID size                                   | Size of ID in bytes                                                       | 3                                     |
| Sector Erase operation code               | Operation code for 4 kB Erase                                             | 0x20                                  |
| Sector information                        | Arrangement of sectors                                                    | Regular (all equally sized -<br>4 kB) |
| Write Enable operation code               | Operation code for write enable                                           | 0x06                                  |
| Write Disable operation code              | Operation code for write disable                                          | 0x04                                  |
| Page Program operation code               | Operation code for page program                                           | 0x02                                  |
| Fast Quad Read operation code             | Operation code for Fast Quad I/O Read                                     | OxEB                                  |
| Fast Quad Read Dummy<br>Bytes             | Number of dummy bytes after setup of fast quad read that data is returned | 1                                     |
| Read Status Register op-<br>eration code  | Operation code for reading status register                                | 0x05                                  |
| Write Status Register op-<br>eration code | Operation code for write to the status register                           | 0x01                                  |
| Write Status Register Busy<br>Mask        | Bit mask for operation in progress (device busy)                          | 0x01                                  |

Table 6.7: Flash device specification supported by XVF3800

# 6.7 Device Firmware (UA configurations)

Device Firmware Upgrade (DFU) over USB is supported for devices that have QSPI flash connected and loaded with a firmware image. The XVF3800 supports the standard USB DFU class.

If the DFU process fails, the boot process falls back to the factory image allowing the user to re-attempt the upgrade. Images loaded via DFU can also be removed allowing the device to revert to the factory image.

The factory image is loaded only after a reboot of the device, either via the DFU host application or by powering the device off and on.

For further information on the operation of the DFU mechanism refer to the User Guide.

For clock, reset and JTAG timing refer to the XU316-1024-QF60B datasheet. XVF3800 specific interface timings are detailed below.

# 7.1 **QSPI Master (External flash for boot image storage)**



Fig. 7.1: QSPI Timing

#### Table 7.1: QSPI timing requirements

| Parameter                              | Symbol      | Min  | Typical | Max | Units |
|----------------------------------------|-------------|------|---------|-----|-------|
| QSPI Clock frequency                   | f(QSPI_CLK) | -    | 12.5    |     | MHz   |
| QSPI_CLK to QSPI Data output delay     | T(DELAY)    | -2.7 | -       | 2.7 | ns    |
| QSPI Data input to QSPI_CLK Setup time | T(SETUP)    | 22   | -       | -   | ns    |
| QSPI Data input to QSPI_CLK hold time  | T(HOLD)     | -11  | -       | -   | ns    |

# 7.2 I<sup>2</sup>S Slave



Fig. 7.2: I2S slave timing



| Parameter                                    | Symbol      | Min | Typi-<br>cal | Max   | Units | Notes |
|----------------------------------------------|-------------|-----|--------------|-------|-------|-------|
| Master clock input frequency                 | f(MCLKin)   | -   | 24.576       | , -   | MHz   | А     |
| I2S Bit Clock frequency input                | f(I2S_BCLK) | -   | 1.024/3      | 3.072 | MHz   |       |
| I2S Data Input (LRCLK) to I2S_BCLK setup     | T(SETUP)    | 0   | -            | -     | ns    | В     |
| time                                         |             |     |              |       |       |       |
| I2S Data Input (LRCLK) to I2S_BCLK hold time | T(HOLD)     | 6   | -            | -     | ns    | В     |
| I2S_BCLK to I2S Data output delay            | T(DELAY)    | 11  | -            | 21.3  | ns    |       |
|                                              |             |     |              |       |       |       |

#### Table 7.2: I<sup>2</sup>S slave timing requirements

#### Note:

A: Configurable input multiplier used to generate appropriate audio sample rates (16 kHz / 48 kHz)

- B: Dependant on audio sample rate (16 kHz/ 48 kHz)
- C: Timing also applies to I<sup>2</sup>S sample clock (I2S\_LRCLK)

# 7.3 SPI Slave (External processor boot)

| Parameter                     | Symbol     | Min | Typical | Max  | Units | Notes |
|-------------------------------|------------|-----|---------|------|-------|-------|
| SPI Clock frequency           | f(SPI_CLK) | -   | 12.5    |      | MHz   |       |
| SPI_CLK to MISO output de-    | T(DELAY)   | 11  | -       | 21.3 | ns    |       |
| lay                           |            |     |         |      |       |       |
| SPI Master Output Slave Input | T(SETUP)   | 0   | -       | -    | ns    |       |
| (MOSI) to SPI_CLK Setup time  |            |     |         |      |       |       |
| SPI Master Output Slave Input | T(HOLD)    | 6   | -       | -    | ns    |       |
| to (MOSI) SPI_CLK hold time   |            |     |         |      |       |       |
|                               |            |     |         |      |       |       |

Note: A: Timing also applies to SPI Chip Select input (SPI\_CS\_N)



# 8 Package information

The XVF3800 is supplied in 60 pin QFN package 0.4 mm pitch with additional paddles underneath for VSS and VDD supplies.

## 8.1 Package Dimensions

The physical dimensions and pin configuration of the XVF3800 device is shown in the figure below:



Fig. 8.1: Package Dimensions

## 8.2 Device Markings

XVF3800 specific device markings are shown below. Only XMOS parts marked with the V16A0VF3 product code are compatible with and licensed to be used with XVF3800 firmware.





Fig. 8.2: XVF3800 Package Marking

## 8.3 Moisture Sensitivity Level

The package moisture sensitivity level rating is MSL-3. devices have a shelf life of 168 hours between removal from the packaging and reflow, provided they are stored below 30 ° C and 60% RH. If devices have exceeded these values or an included moisture indicator card shows excessive levels of moisture, then the parts should be baked as appropriate before use. This is based on information from Joint IPC/JEDEC Standard for Moisture/Reflow Sensitivity Classification for Non-hermetic Solid-State Surface-Mount Devices (J-STD-020 Revision D)

## 8.4 Hazardous Materials

This product complies with the Reduction of Hazardous Substances (RoHS) directive.

For details refer to https://www.xmos.ai/environmental

## 8.5 Order Codes

| Table 8.1: Ordering codes |                      |                                              |  |
|---------------------------|----------------------|----------------------------------------------|--|
| Product code              | Marking **           | Description                                  |  |
| XVF3800-QF60B-C           | V16A0VF3<br>MCYYWWP2 | Commercial Temp range (0 – 70 ° C) - 3.3V IO |  |

Note: \*\* MC - Manufacturer, YY - Year code, WW - Week code



Copyright © 2023, All Rights Reserved.

XMOS Ltd. is the owner or licensee of this design, code, or Information (collectively, the "Information") and is providing it to you "AS IS" with no warranty of any kind, express or implied and shall have no liability in relation to its use. XMOS Ltd makes no representation that the Information, or any particular implementation thereof, is or will be free from any claims of infringement and again, shall have no liability in relation to any such claims.

XMOS, XCORE, VocalFusion and the XMOS logo are registered trademarks of XMOS Ltd. in the United Kingdom and other countries and may not be used without written permission. Company and product names mentioned in this document are the trademarks or registered trademarks of their respective owners.

