# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China



XS1-U8A-64-FB96 Datasheet

Document Number: XM002429,



# **Table of Contents**

| 1   | xCORE Multicore Microcontrollers      | 2   |
|-----|---------------------------------------|-----|
| 2   | XS1-U8A-64-FB96 Features              | 4   |
| 3   | Pin Configuration                     | 5   |
| 4   | Signal Description                    | 6   |
| 5   | Example Application Diagram           | 9   |
| 6   | Product Overview                      | 10  |
| 7   | xCORE Tile Resources                  | 11  |
| 8   | Oscillator                            |     |
| 9   | Boot Procedure                        | 15  |
| 10  | Memory                                | 19  |
| 11  | USB PHY                               | 19  |
| 12  | Analog-to-Digital Converter           |     |
| 13  | Supervisor Logic                      | 20  |
| 14  | Energy management                     | 21  |
| 15  | JTAG                                  |     |
| 16  | Board Integration                     | 24  |
| 17  | Example XS1-U8A-64-FB96 Board Designs | 30  |
| 18  | DC and Switching Characteristics      | 34  |
| 19  | Package Information                   | 39  |
| 20  | Ordering Information                  | 40  |
| App | endices                               | 41  |
| Α   | Configuring the device                | 41  |
| В   | Processor Status Configuration        | 44  |
| С   | xCORE Tile Configuration              | 53  |
| D   | Digital Node Configuration            | 61  |
| E   | Analogue Node Configuration           | 68  |
| F   | USB PHY Configuration                 |     |
| G   | ADC Configuration                     | 79  |
| Н   | Deep sleep memory Configuration       | 82  |
| 1   | Oscillator Configuration              | 83  |
| J   | Real time clock Configuration         | 85  |
| K   | Power control block Configuration     | 85  |
| L   | Device Errata                         |     |
| Μ   | JTAG, xSCOPE and Debugging            |     |
| Ν   | Schematics Design Check List          | 100 |
| 0   | PCB Layout Design Check List          |     |
| Ρ   | Associated Design Documentation       |     |
| Q   | Related Documentation                 | 103 |
| R   | Revision History                      | 104 |

#### TO OUR VALUED CUSTOMERS

It is our intention to provide you with accurate and comprehensive documentation for the hardware and software components used in this product. To subscribe to receive updates, visit http://www.xmos.com/.

XMOS Ltd. is the owner or licensee of the information in this document 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 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.



# 1 xCORE Multicore Microcontrollers

The XS1-U Series is a comprehensive range of 32-bit multicore microcontrollers that brings the low latency and timing determinism of the xCORE architecture to mainstream embedded applications. Unlike conventional microcontrollers, xCORE multicore microcontrollers execute multiple real-time tasks simultaneously and communicate between tasks using a high speed network. Because xCORE multicore microcontrollers are completely deterministic, you can write software to implement functions that traditionally require dedicated hardware.



Key features of the XS1-U8A-64-FB96 include:

- Tiles: Devices consist of one or more xCORE tiles. Each tile contains between four and eight 32-bit xCOREs with highly integrated I/O and on-chip memory.
- Logical cores Each logical core can execute tasks such as computational code, DSP code, control software (including logic decisions and executing a state machine) or software that handles I/O. Section 7.1
- xTIME scheduler The xTIME scheduler performs functions similar to an RTOS, in hardware. It services and synchronizes events in a core, so there is no requirement for interrupt handler routines. The xTIME scheduler triggers cores on events generated by hardware resources such as the I/O pins, communication channels and timers. Once triggered, a core runs independently and concurrently to other cores, until it pauses to wait for more events. Section 7.2

- Channels and channel ends Tasks running on logical cores communicate using channels formed between two channel ends. Data can be passed synchronously or asynchronously between the channel ends assigned to the communicating tasks. Section 7.5
- xCONNECT Switch and Links Between tiles, channel communications are implemented over a high performance network of xCONNECT Links and routed through a hardware xCONNECT Switch. Section 7.6
- ▶ **Ports** The I/O pins are connected to the processing cores by Hardware Response ports. The port logic can drive its pins high and low, or it can sample the value on its pins optionally waiting for a particular condition. Section 7.3
- Clock blocks xCORE devices include a set of programmable clock blocks that can be used to govern the rate at which ports execute. Section 7.4
- Memory Each xCORE Tile integrates a bank of SRAM for instructions and data, and a block of one-time programmable (OTP) memory that can be configured for system wide security features. Section 10
- PLL The PLL is used to create a high-speed processor clock given a low speed external oscillator. Section 8
- ▶ **USB** The USB PHY provides High-Speed and Full-Speed, device, host, and on-thego functionality. Data is communicated through ports on the digital node. A library is provided to implement USB device functionality. Section 11
- ▶ JTAG The JTAG module can be used for loading programs, boundary scan testing, in-circuit source-level debugging and programming the OTP memory. Section 15

#### 1.1 Software

Devices are programmed using C, C++ or xC (C with multicore extensions). XMOS provides tested and proven software libraries, which allow you to quickly add interface and processor functionality such as USB, Ethernet, PWM, graphics driver, and audio EQ to your applications.

# 1.2 xTIMEcomposer Studio

The xTIMEcomposer Studio development environment provides all the tools you need to write and debug your programs, profile your application, and write images into flash memory or OTP memory on the device. Because xCORE devices operate deterministically, they can be simulated like hardware within xTIMEcomposer: uniquely in the embedded world, xTIMEcomposer Studio therefore includes a static timing analyzer, cycle-accurate simulator, and high-speed in-circuit instrumentation.

xTIMEcomposer can be driven from either a graphical development environment, or the command line. The tools are supported on Windows, Linux and MacOS X and available at no cost from xmos.com/downloads. Information on using the tools is provided in the xTIMEcomposer User Guide, X3766.

# 2 XS1-U8A-64-FB96 Features

#### ► Multicore Microcontroller with Advanced Multi-Core RISC Architecture

- Eight real-time logical cores
- Core share up to 500 MIPS
- Each logical core has:
  - Guaranteed throughput of between  $\frac{1}{4}$  and  $\frac{1}{8}$  of tile MIPS  $\frac{16x32bit}{4}$  dedicated registers
- 159 high-density 16/32-bit instructions
  - All have single clock-cycle execution (except for divide)
  - $32x32 \rightarrow 64$ -bit MAC instructions for DSP, arithmetic and user-definable cryptographic functions
- ▶ USB PHY, fully compliant with USB 2.0 specification
- ▶ 12b 1MSPS 4-channel SAR Analog-to-Digital Converter
- ▶ 1 x LDO
- > 2 x DC-DC converters and Power Management Unit
- Watchdog Timer
- Onchip clocks/oscillators
  - Crystal oscillator
  - 20MHz/31kHz silicon oscillators

#### Programmable I/O

- 38 general-purpose I/O pins, configurable as input or output
  - Up to 9 x 1 bit port, 2 x 4bit port, 1 x 8bit port
  - 3 xCONNECT links
- Port sampling rates of up to 60 MHz with respect to an external clock
- 32 channel ends for communication with other cores, on or off-chip
- Memory
  - 64KB internal single-cycle SRAM for code and data storage
  - 8KB internal OTP for application boot code
  - 128 bytes Deep Sleep Memory

#### Hardware resources

- 6 clock blocks
- 10 timers
- 4 locks

#### JTAG Module for On-Chip Debug

- Security Features
  - Programming lock disables debug and prevents read-back of memory contents
  - AES bootloader ensures secrecy of IP held on external flash memory
- Ambient Temperature Range
  - Commercial qualification: 0°C to 70°C
  - Industrial qualification: -40 °C to 85 °C
- Speed Grade
  - 5: 500 MIPS
- Power Consumption with USB running (typical)
  - 300 mW (typical)
  - Sleep Mode: 500 µW
- ▶ 96-pin FBGA package 0.8 mm pitch

# 3 Pin Configuration

|   | 1              | 2            | 3    | 4       | 5          | 6          | 7            | 8           | 9           | 10          | 11           | 12           |
|---|----------------|--------------|------|---------|------------|------------|--------------|-------------|-------------|-------------|--------------|--------------|
| A | AVDD           | ADC0         | ADC2 | NC      | USB_<br>DP | USB_<br>DN | USB_<br>VBUS | X0D35       | X0D00       | X0D10       | X0D12        | 32A<br>X0D49 |
| В | TDO            | ADC1         | ADC3 | NC      | MODE[2]    | MODE[3]    | USB_<br>ID   | X0D24       | X0D01       | X0D11       | 32A<br>X0D50 | X0D51        |
| С | тск            | RST_N        |      |         |            |            |              |             |             |             | 32A<br>X0D52 | 32A<br>X0D53 |
| D | TMS            | TDI          |      |         |            |            |              |             |             |             | 32A<br>X0D54 | 32A<br>X0D55 |
| Е | XI/<br>CLK     | DEBUG_<br>N  |      |         | AVSS       | GND        | GND          | GND         |             |             | 32A<br>X0D56 | 32A<br>X0D57 |
| F | хо             | OSC<br>EXT_N |      |         | GND        | GND        | GND          | GND         |             |             | 32A<br>X0D58 | X0D61        |
| G | X0D43/<br>WAKE | NC           |      |         | GND        | GND        | GND          | GND         |             |             | 32A<br>X0D62 | 32A<br>X0D63 |
| н | VSUP           | NC           |      |         | GND        | GND        | GND          | GND         |             |             | 32A<br>X0D64 | 32A<br>X0D65 |
| J | SW1            | SW1          |      |         |            |            |              |             |             |             | 32A<br>X0D66 | 32A<br>X0D67 |
| к | VDDCORE        | VDDCORE      |      |         |            |            |              |             |             |             | 32A<br>X0D68 | 32A<br>X0D69 |
| L | PGND           | PGND         | NC   | MODE[1] | MODE[0]    | VDDIO      | X0D22        | 40<br>X0D20 | 4D<br>X0D18 | 4D<br>X0D16 | 4C<br>X0D14  | 32A<br>X0D70 |
| м | VSUP           | VSUP         | PGND | VDD1V8  | SW2        | VDDIO      | VDDIO        | 40<br>X0D21 | 4D<br>X0D19 | 4D<br>X0D17 | 4C<br>X0D15  | X0D13        |

# 4 Signal Description

This section lists the signals and I/O pins available on the XS1-U8A-64-FB96. The device provides a combination of 1 bit, 4bit, 8bit and 16bit ports, as well as wider ports that are fully or partially (gray) bonded out. All pins of a port provide either output or input, but signals in different directions cannot be mapped onto the same port.

Pins may have one or more of the following properties:

PD/PU: The IO pin a weak pull-down or pull-up resistor. On GPIO pins this resistor can be enabled.

| Power pins (9) |                               |      |            |  |  |  |  |
|----------------|-------------------------------|------|------------|--|--|--|--|
| Signal         | Function                      | Туре | Properties |  |  |  |  |
| AVSS           | Digital ground                | GND  |            |  |  |  |  |
| GND            | Digital ground                | GND  |            |  |  |  |  |
| PGND           | Power ground                  | GND  |            |  |  |  |  |
| SW1            | DCDC1 switched output voltage | PWR  |            |  |  |  |  |
| SW2            | DCDC2 switched output voltage | PWR  |            |  |  |  |  |
| VDD1V8         | 1v8 voltage supply            | PWR  |            |  |  |  |  |
| VDDCORE        | Core voltage supply           | PWR  |            |  |  |  |  |
| VDDIO          | Digital I/O power             | PWR  |            |  |  |  |  |
| VSUP           | Power supply (3V3/5V0)        | PWR  |            |  |  |  |  |

ST: The IO pin has a Schmitt Trigger on its input.

|        | Analog pins (5)              |       |            |  |  |  |  |  |
|--------|------------------------------|-------|------------|--|--|--|--|--|
| Signal | Function                     | Туре  | Properties |  |  |  |  |  |
| ADC0   | Analog input                 | Input |            |  |  |  |  |  |
| ADC1   | Analog input                 | Input |            |  |  |  |  |  |
| ADC2   | Analog input                 | Input |            |  |  |  |  |  |
| ADC3   | Analog input                 | Input |            |  |  |  |  |  |
| AVDD   | Supply and reference voltage | PWR   |            |  |  |  |  |  |

|          | USB pins (4)                   |        |            |  |  |  |  |  |
|----------|--------------------------------|--------|------------|--|--|--|--|--|
| Signal   | Function                       | Туре   | Properties |  |  |  |  |  |
| USB_DN   | USB Serial Data Inverted       | I/O    |            |  |  |  |  |  |
| USB_DP   | USB Serial Data                | I/O    |            |  |  |  |  |  |
| USB_ID   | USB Device ID (OTG) - Reserved | Output |            |  |  |  |  |  |
| USB_VBUS | USB Power Detect Pin           | Input  |            |  |  |  |  |  |

-XMOS

|           | Clocks pins (4)                |        |            |  |  |  |  |  |
|-----------|--------------------------------|--------|------------|--|--|--|--|--|
| Signal    | Function                       | Туре   | Properties |  |  |  |  |  |
| MODE[3:0] | Boot mode select               | Input  | PU, ST     |  |  |  |  |  |
| OSC_EXT_N | Use Silicon Oscillator         | Input  | ST         |  |  |  |  |  |
| XI/CLK    | Crystal Oscillator/Clock Input | Input  |            |  |  |  |  |  |
| хо        | Crystal Oscillator Output      | Output |            |  |  |  |  |  |

|         | JTAG pins (5)    |        |            |  |  |  |  |
|---------|------------------|--------|------------|--|--|--|--|
| Signal  | Function         | Туре   | Properties |  |  |  |  |
| DEBUG_N | Multi-chip debug | I/O    | PU         |  |  |  |  |
| ТСК     | Test clock       | Input  | PU, ST     |  |  |  |  |
| TDI     | Test data input  | Input  | PU, ST     |  |  |  |  |
| TDO     | Test data output | Output | PD, OT     |  |  |  |  |
| TMS     | Test mode select | Input  | PU, ST     |  |  |  |  |

| Misc pins (1) |                    |       |            |  |  |  |
|---------------|--------------------|-------|------------|--|--|--|
| Signal        | Function           | Туре  | Properties |  |  |  |
| RST_N         | Global reset input | Input | PU, ST     |  |  |  |

|            | I/O pins (38)                                                                                      |      |                                  |
|------------|----------------------------------------------------------------------------------------------------|------|----------------------------------|
| Signal     | Function                                                                                           | Туре | Properties                       |
| X0D00      | 1A <sup>0</sup>                                                                                    | I/0  | PD <sub>S</sub> , R <sub>S</sub> |
| X0D01      | 1 B <sup>0</sup>                                                                                   | I/0  | PD <sub>S</sub> , R <sub>S</sub> |
| X0D10      | 1C <sup>0</sup>                                                                                    | I/O  | PD <sub>S</sub> , R <sub>S</sub> |
| X0D11      | 1D <sup>0</sup>                                                                                    | I/O  | PD <sub>S</sub> , R <sub>S</sub> |
| X0D12      | 1 E <sup>0</sup>                                                                                   | I/O  | PDs                              |
| X0D13      | XLB <sup>4</sup> <sub>out</sub> 1F <sup>0</sup>                                                    | I/O  | PDs                              |
| X0D14      | XLB <sup>3</sup> <sub>out</sub> 4C <sup>0</sup> 8B <sup>0</sup> 16A <sup>8</sup> 32A <sup>28</sup> | I/O  | PDs                              |
| X0D15      | $XLB_{out}^2$ 4C <sup>1</sup> 8B <sup>1</sup> 16A <sup>9</sup> 32A <sup>29</sup>                   | I/O  | PDs                              |
| X0D16      | $XLB_{out}^{1}$ $4D^{0}$ $8B^{2}$ 16A <sup>10</sup>                                                | I/O  | PDs                              |
| X0D17      | $XLB_{out}^{0}$ 4D <sup>1</sup> 8B <sup>3</sup> 16A <sup>11</sup>                                  | I/O  | PDs                              |
| X0D18      | $XLB_{in}^{0}$ 4D <sup>2</sup> 8B <sup>4</sup> 16A <sup>12</sup>                                   | I/O  | PDs                              |
| X0D19      | $XLB_{in}^{1}$ $4D^{3}$ $8B^{5}$ $16A^{13}$                                                        | I/O  | PDs                              |
| X0D20      | $XLB_{in}^2$ $4C^2$ $8B^6$ $16A^{14}$ $32A^{30}$                                                   | I/O  | PDs                              |
| X0D21      | $XLB_{in}^3$ 4C <sup>3</sup> 8B <sup>7</sup> 16A <sup>15</sup> 32A <sup>31</sup>                   | I/O  | PDs                              |
| X0D22      | XLB <sup>4</sup> <sub>in</sub> 1G <sup>0</sup>                                                     | I/O  | PDs                              |
| X0D24      | 110                                                                                                | I/O  | PDs                              |
| X0D35      | 1L <sup>0</sup>                                                                                    | I/O  | PDs                              |
| X0D43/WAKE | 8D <sup>7</sup> 16B <sup>15</sup>                                                                  | I/O  | PUs                              |
| X0D49      | XLC <sup>4</sup> <sub>out</sub> 32A <sup>0</sup>                                                   | I/O  | PDs                              |
|            |                                                                                                    |      | (continued)                      |

(continued)

XS1-U8A-64-FB96



| Signal | Function                        |                   | Туре | Properties |
|--------|---------------------------------|-------------------|------|------------|
| X0D50  | XLC <sup>3</sup> <sub>out</sub> | 32A <sup>1</sup>  | I/0  | PDs        |
| X0D51  | XLC <sup>2</sup> <sub>out</sub> | 32A <sup>2</sup>  | I/0  | PDs        |
| X0D52  | XLC <sup>1</sup>                | 32A <sup>3</sup>  | I/0  | PDs        |
| X0D53  | XLC <sup>0</sup> <sub>out</sub> | 32A <sup>4</sup>  | I/O  | PDs        |
| X0D54  | XLC <sup>0</sup> <sub>in</sub>  | 32A <sup>5</sup>  | I/0  | PDs        |
| X0D55  | XLC <sup>1</sup>                | 32A <sup>6</sup>  | I/0  | PDs        |
| X0D56  | XLC <sup>2</sup> <sub>in</sub>  | 32A <sup>7</sup>  | I/0  | PDs        |
| X0D57  | XLC <sup>3</sup>                | 32A <sup>8</sup>  | I/O  | PDs        |
| X0D58  | XLC <sup>4</sup>                | 32A <sup>9</sup>  | I/0  | PDs        |
| X0D61  | XLD <sup>4</sup> <sub>out</sub> | 32A <sup>10</sup> | I/O  | PDs        |
| X0D62  | XLD <sup>3</sup> <sub>out</sub> | 32A <sup>11</sup> | I/0  | PDs        |
| X0D63  | XLD <sup>2</sup> <sub>out</sub> | 32A <sup>12</sup> | I/0  | PDs        |
| X0D64  | XLD <sup>1</sup> <sub>out</sub> | 32A <sup>13</sup> | I/0  | PDs        |
| X0D65  | XLD <sup>0</sup> <sub>out</sub> | 32A <sup>14</sup> | I/0  | PDs        |
| X0D66  | XLD <sup>0</sup> <sub>in</sub>  | 32A <sup>15</sup> | I/0  | PDs        |
| X0D67  | XLD <sup>1</sup>                | 32A <sup>16</sup> | I/O  | PDs        |
| X0D68  | XLD <sup>2</sup> <sub>in</sub>  | 32A <sup>17</sup> | I/O  | PDs        |
| X0D69  | XLD <sup>3</sup> <sub>in</sub>  | 32A <sup>18</sup> | I/O  | PDs        |
| X0D70  | XLD <sup>4</sup> <sub>in</sub>  | 32A <sup>19</sup> | I/O  | PDs        |

# 5 Example Application Diagram



# 6 Product Overview

The XS1-U8A-64-FB96 comprises a digital and an analog node, as shown in Figure 3. The digital node comprises an xCORE Tile, a Switch, and a PLL (Phase-locked-loop). The analog node comprises the USB PHY, a multi-channel ADC (Analog to Digital Converter), deep sleep memory, an oscillator, a real-time counter, and power supply control.



All communication between the digital and analog node takes place over a link that is connected to the Switch of the digital node. As such, the analog node can be controlled from any node on the system. The analog functions can be configured using a set of node configuration registers, and a set of registers for each of the peripherals.

The device can be programmed using high-level languages such as C/C++ and the XMOS-originated XC language, which provides extensions to C that simplify the control over concurrency, I/O and timing, or low-level assembler.

# 6.1 XCore Tile

The xCORE Tile is a flexible multicore microcontroller component with tightly integrated I/O and on-chip memory. The tile contains multiple logical cores that run simultaneously, each of which is guaranteed a slice of processing power and can execute computational code, control software and I/O interfaces. The logical cores use channels to exchange data within a tile or across tiles. Multiple devices can be deployed and connected using an integrated switching network, enabling more resources to be added to a design. The I/O pins are driven using intelligent ports that can serialize data, interpret strobe signals and wait for scheduled times or events, making the device ideal for real-time control applications.

# 6.2 USB PHY

The USB PHY is fully compliant with the USB 2.0 specification. It supports high speed (480-Mbps) and full speed (12Mbps) operation.

-XM()S

The XMOS XUD software component performs all the low-level I/O operations required to meet the USB 2.0 specification, removing all low-level timing requirements from the application.

# 6.3 ADC and Power Management

Each XS1-U8A-64-FB96 device includes a set of analog components, including a 12b, 4-channel ADC, power management unit, watchdog timer, real-time counter and deep sleep memory. The device reduces the number of additional external components required and allows designs to be implemented using simple 2-layer boards.

# 7 xCORE Tile Resources

# 7.1 Logical cores

The tile has 8 active logical cores, which issue instructions down a shared fourstage pipeline. Instructions from the active cores are issued round-robin. If up to four logical cores are active, each core is allocated a quarter of the processing cycles. If more than four logical cores are active, each core is allocated at least 1/ncycles (for *n* cores). Figure 4 shows the guaranteed core performance depending on the number of cores used.

Figure 4: Logical core performance

| gure 4: | Speed | MIPS     | Frequency | Minimum MIPS per core (for <i>n</i> cores) |     |     |     |     |    |    |    |
|---------|-------|----------|-----------|--------------------------------------------|-----|-----|-----|-----|----|----|----|
| al core | grade |          |           | 1                                          | 2   | 3   | 4   | 5   | 6  | 7  | 8  |
| mance   | 5     | 500 MIPS | 500 MHz   | 125                                        | 125 | 125 | 125 | 100 | 83 | 71 | 63 |

There is no way that the performance of a logical core can be reduced below these predicted levels. Because cores may be delayed on I/O, however, their unused processing cycles can be taken by other cores. This means that for more than four logical cores, the performance of each core is often higher than the predicted minimum but cannot be guaranteed.

The logical cores are triggered by events instead of interrupts and run to completion. A logical core can be paused to wait for an event.

# 7.2 xTIME scheduler

The xTIME scheduler handles the events generated by xCORE Tile resources, such as channel ends, timers and I/O pins. It ensures that all events are serviced and synchronized, without the need for an RTOS. Events that occur at the I/O pins are handled by the Hardware-Response ports and fed directly to the appropriate xCORE Tile. An xCORE Tile can also choose to wait for a specified time to elapse, or for data to become available on a channel.

Tasks do not need to be prioritised as each of them runs on their own logical xCORE. It is possible to share a set of low priority tasks on a single core using cooperative multitasking.



# 7.3 Hardware Response Ports

Hardware Response ports connect an xCORE tile to one or more physical pins and as such define the interface between hardware attached to the XS1-U8A-64-FB96, and the software running on it. A combination of 1 bit, 4 bit, 8 bit, 16 bit and 32 bit ports are available. All pins of a port provide either output or input. Signals in different directions cannot be mapped onto the same port.



The port logic can drive its pins high or low, or it can sample the value on its pins, optionally waiting for a particular condition. Ports are accessed using dedicated instructions that are executed in a single processor cycle.

Data is transferred between the pins and core using a FIFO that comprises a SERDES and transfer register, providing options for serialization and buffered data.

Each port has a 16-bit counter that can be used to control the time at which data is transferred between the port value and transfer register. The counter values can be obtained at any time to find out when data was obtained, or used to delay I/O until some time in the future. The port counter value is automatically saved as a timestamp, that can be used to provide precise control of response times.

The ports and xCONNECT links are multiplexed onto the physical pins. If an xConnect Link is enabled, the pins of the underlying ports are disabled. If a port is enabled, it overrules ports with higher widths that share the same pins. The pins on the wider port that are not shared remain available for use when the narrower port is enabled. Ports always operate at their specified width, even if they share pins with another port.

# 7.4 Clock blocks

xCORE devices include a set of programmable clocks called clock blocks that can be used to govern the rate at which ports execute. Each xCORE tile has six clock blocks: the first clock block provides the tile reference clock and runs at a default frequencies.



A clock block can use a 1-bit port as its clock source allowing external application clocks to be used to drive the input and output interfaces.

In many cases I/O signals are accompanied by strobing signals. The xCORE ports can input and interpret strobe (known as readyIn and readyOut) signals generated by external sources, and ports can generate strobe signals to accompany output data.

On reset, each port is connected to clock block 0, which runs from the processor reference clock.

# 7.5 Channels and Channel Ends

Logical cores communicate using point-to-point connections, formed between two channel ends. A channel-end is a resource on an xCORE tile, that is allocated by the program. Each channel-end has a unique system-wide identifier that comprises a unique number and their tile identifier. Data is transmitted to a channel-end by an output-instruction; and the other side executes an input-instruction. Data can be passed synchronously or asynchronously between the channel ends.

# 7.6 xCONNECT Switch and Links

XMOS devices provide a scalable architecture, where multiple xCORE devices can be connected together to form one system. Each xCORE device has an xCONNECT interconnect that provides a communication infrastructure for all tasks that run on the various xCORE tiles on the system.

The interconnect relies on a collection of switches and XMOS links. Each xCORE device has an on-chip switch that can set up circuits or route data. The switches are connected by xConnect Links. An XMOS link provides a physical connection between two switches. The switch has a routing algorithm that supports many different topologies, including lines, meshes, trees, and hypercubes.

The links operate in either 2 wires per direction or 5 wires per direction mode, depending on the amount of bandwidth required. Circuit switched, streaming



14



Figure 7: Switch, links and channel ends

and packet switched data can both be supported efficiently. Streams provide the fastest possible data rates between tiles (up to 313 MBit/s), but each stream requires a single link to be reserved between switches on two tiles. All packet communications can be multiplexed onto a single link.

Information on the supported routing topologies that can be used to connect multiple devices together can be found in the XS1-L Link Performance and Design Guide, X2999.

# 8 Oscillator

The oscillator block provides:

- An oscillator circuit. Together with an external resonator (crystal or ceramic), the oscillator circuit can provide a clock-source for both the real-time counter and the xCORE Tile. The external resonator can be chosen by the designer to have the appropriate frequency and accuracy. If desired, an external oscillator can be used on the XI/CLK input pin, this must be a 1.8 V oscillator.
- A 20 MHz silicon oscillator. This enables the device to boot and execute code without requiring an external crystal. The silicon oscillator is not as accurate as an external crystal.
- A 31,250 Hz oscillator. This enables the real-time counter to operate whilst the device is in low-power mode. This oscillator is not as accurate as an external crystal.

The oscillator can be controlled through package pins, a set of peripheral registers, and a digital node control register.



A package pin OSC\_EXT\_N is used to select the oscillator to use on boot. It must be grounded to select an external resonator or connected to VDDIO to select the on-chip 20 MHz oscillator. If an external resonator is used, then it must be in the range 5-100 MHz. If the USB PHY is used, then an external crystal (12 or 24 MHz) or an external oscillator (12, 24, 48, or 96 MHz) is required in order to provide a stable USB clock. Two more package pins, MODE0 and MODE1 are used to inform the node of the frequency.

The analog node runs at the frequency provided by the oscillator. Hence, increasing the clock frequency will speed up operation of the analog node, and will speed up communicating data with the digital node. The digital node has a PLL.

The PLL creates a high-speed clock that is used for the switch, tile, and reference clock.

The PLL multiplication value is selected through the two MODE pins, and can be changed by software to speed up the tile or use less power. The MODE pins are set as shown in Figure 8:

Figure 8: PLL multiplier values and MODE pins

| Oscillator | MODE |   | MODE Tile      |       | PLL | setting | gs |
|------------|------|---|----------------|-------|-----|---------|----|
| Frequency  | 1    | 0 | Frequency      |       | OD  | F       | R  |
| 5-13 MHz   | 0    | 0 | 130-399.75 MHz | 30.75 | 1   | 122     | 0  |
| 13-20 MHz  | 1    | 1 | 260-400.00 MHz | 20    | 2   | 119     | 0  |
| 20-48 MHz  | 1    | 0 | 167-400.00 MHz | 8.33  | 2   | 49      | 0  |
| 48-100 MHz | 0    | 1 | 196-400.00 MHz | 4     | 2   | 23      | 0  |

Figure 8 also lists the values of OD, F and R, which are the registers that define the ratio of the tile frequency to the oscillator frequency:

$$F_{core} = F_{osc} \times \frac{F+1}{2} \times \frac{1}{R+1} \times \frac{1}{OD+1}$$

*OD*, *F* and *R* must be chosen so that  $0 \le R \le 63$ ,  $0 \le F \le 4095$ ,  $0 \le OD \le 7$ , and  $260MHz \le F_{osc} \times \frac{F+1}{2} \times \frac{1}{R+1} \le 1.3GHz$ . The *OD*, *F*, and *R* values can be modified by writing to the digital node PLL configuration register.

The MODE pins must be held at a static value during and after deassertion of the system reset.

If a different tile frequency is required (eg, 500 MHz), then the PLL must be reprogrammed after boot to provide the required tile frequency. The XMOS tools perform this operation by default. Further details on configuring the clock can be found in the XS1-L Clock Frequency Control document, X1433.

# 9 Boot Procedure

The device is kept in reset by driving RST\_N low. When in reset, all GPIO pins are high impedance. When the device is taken out of reset by releasing RST\_N the processor starts its internal reset process. After approximately 750,000 input

clocks, all GPIO pins have their internal pull-resistor enabled, and the processor boots at a clock speed that depends on MODE0 and MODE1.

The processor boot procedure is illustrated in Figure 9. In normal usage, MODE[3:2] controls the boot source according to the table in Figure 10. If bit 5 of the security register (*see* §10.1) is set, the device boots from OTP.



|                     | MODE[3] | MODE[2] | Boot Source                              |
|---------------------|---------|---------|------------------------------------------|
|                     | 0       | 0       | None: Device waits to be booted via JTAG |
| Figure 10:          | 0       | 1       | Reserved                                 |
| Boot source<br>pins | 1       | 0       | xConnect Link B                          |
|                     | 1       | 1       | SPI                                      |

The boot image has the following format:

- ► A 32-bit program size *s* in words.
- Program consisting of  $s \times 4$  bytes.
- A 32-bit CRC, or the value 0x0D15AB1E to indicate that no CRC check should be performed.

The program size and CRC are stored least significant byte first. The program is loaded into the lowest memory address of RAM, and the program is started from that address. The CRC is calculated over the byte stream represented by the program size and the program itself. The polynomial used is 0xEDB88320 (IEEE 802.3); the CRC register is initialized with 0xFFFFFFFF and the residue is inverted to produce the CRC.

# 9.1 Boot from SPI master

If set to boot from SPI master, the processor enables the four pins specified in Figure 11, and drives the SPI clock at 2.5 MHz (assuming a 400 MHz core clock). A



READ command is issued with a 24-bit address 0x000000. The clock polarity and phase are 0 / 0.

|                                         | Pin   | Signal | Description                |
|-----------------------------------------|-------|--------|----------------------------|
| <b>Figure 11:</b><br>SPI master<br>pins | X0D00 | MISO   | Master In Slave Out (Data) |
|                                         | X0D01 | SS     | Slave Select               |
|                                         | X0D10 | SCLK   | Clock                      |
|                                         | X0D11 | MOSI   | Master Out Slave In (Data) |

The xCORE Tile expects each byte to be transferred with the *least-significant bit first*. Programmers who write bytes into an SPI interface using the most significant bit first may have to reverse the bits in each byte of the image stored in the SPI device.

If a large boot image is to be read in, it is faster to first load a small boot-loader that reads the large image using a faster SPI clock, for example 50 MHz or as fast as the flash device supports.

The pins used for SPI boot are hardcoded in the boot ROM and cannot be changed. If required, an SPI boot program can be burned into OTP that uses different pins.

# 9.2 Boot from xConnect Link

If set to boot from an xConnect Link, the processor enables Link B around 200 ns after the boot process starts. Enabling the Link switches off the pull-down on resistors X0D16..X0D19, drives X0D16 and X0D17 low (the initial state for the Link), and monitors pins X0D18 and X0D19 for boot-traffic. X0D18 and X0D19 must be low at this stage. If the internal pull-down is too weak to drain any residual charge, external pull-downs of 10K may be required on those pins.

The boot-rom on the core will then:

- 1. Allocate channel-end 0.
- 2. Input a word on channel-end 0. It will use this word as a channel to acknowledge the boot. Provide the null-channel-end 0x0000FF02 if no acknowledgment is required.
- 3. Input the boot image specified above, including the CRC.
- 4. Input an END control token.
- 5. Output an END control token to the channel-end received in step 2.
- 6. Free channel-end 0.
- 7. Jump to the loaded code.

18

# 9.3 Boot from OTP

If an xCORE tile is set to use secure boot (see Figure 9), the boot image is read from address 0 of the OTP memory in the tile's security module.

This feature can be used to implement a secure bootloader which loads an encrypted image from external flash, decrypts and CRC checks it with the processor, and discontinues the boot process if the decryption or CRC check fails. XMOS provides a default secure bootloader that can be written to the OTP along with secret decryption keys.

Each tile has its own individual OTP memory, and hence some tiles can be booted from OTP while others are booted from SPI or the channel interface. This enables systems to be partially programmed, dedicating one or more tiles to perform a particular function, leaving the other tiles user-programmable.

# 9.4 Security register

The security register enables security features on the xCORE tile. The features shown in Figure 12 provide a strong level of protection and are sufficient for providing strong IP security.

| Feature              | Bit  | Description                                                                                                                                                                                                                                |  |
|----------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Disable JTAG         | 0    | The JTAG interface is disabled, making it impossible<br>for the tile state or memory content to be accessed<br>via the JTAG interface.                                                                                                     |  |
| Disable Link access  | 1    | Other tiles are forbidden access to the processor state<br>via the system switch. Disabling both JTAG and Link<br>access transforms an xCORE Tile into a "secure island"<br>with other tiles free for non-secure user application<br>code. |  |
| Secure Boot          | 5    | The processor is forced to boot from address 0 of the OTP, allowing the processor boot ROM to be bypassed ( <i>see</i> §9).                                                                                                                |  |
| Redundant rows       | 7    | Enables redundant rows in OTP.                                                                                                                                                                                                             |  |
| Sector Lock 0        | 8    | Disable programming of OTP sector 0.                                                                                                                                                                                                       |  |
| Sector Lock 1        | 9    | Disable programming of OTP sector 1.                                                                                                                                                                                                       |  |
| Sector Lock 2        | 10   | Disable programming of OTP sector 2.                                                                                                                                                                                                       |  |
| Sector Lock 3        | 11   | Disable programming of OTP sector 3.                                                                                                                                                                                                       |  |
| OTP Master Lock      | 12   | Disable OTP programming completely: disables up-<br>dates to all sectors and security register.                                                                                                                                            |  |
| Disable JTAG-OTP     | 13   | Disable all (read & write) access from the JTAG inter-<br>face to this OTP.                                                                                                                                                                |  |
| Disable Global Debug | 14   | Disables access to the DEBUG_N pin.                                                                                                                                                                                                        |  |
|                      | 2115 | General purpose software accessable security register available to end-users.                                                                                                                                                              |  |
|                      | 3122 | General purpose user programmable JTAG UserID code extension.                                                                                                                                                                              |  |

 $-X \Lambda ()S$ 

Figure 12: Security register features

# 10 Memory

# 10.1 OTP

The xCORE Tile integrates 8 KB one-time programmable (OTP) memory along with a security register that configures system wide security features. The OTP holds data in four sectors each containing 512 rows of 32 bits which can be used to implement secure bootloaders and store encryption keys. Data for the security register is loaded from the OTP on power up. All additional data in OTP is copied from the OTP to SRAM and executed first on the processor.

The OTP memory is programmed using three special I/O ports: the OTP address port is a 16-bit port with resource ID 0x100200, the OTP data is written via a 32-bit port with resource ID 0x200100, and the OTP control is on a 16-bit port with ID 0x100300. Programming is performed through libotp and xburn.

# 10.2 SRAM

The xCORE Tile integrates a single 64KBSRAM bank for both instructions and data. All internal memory is 32 bits wide, and instructions are either 16-bit or 32-bit. Byte (8-bit), half-word (16-bit) or word (32-bit) accesses are supported and are executed within one tile clock cycle. There is no dedicated external memory interface, although data memory can be expanded through appropriate use of the ports.

#### 10.3 Deep Sleep Memory

The XS1-U8A-64-FB96 device includes 128 bytes of deep sleep memory for state storage during sleep mode. Deep sleep memory is volatile and if device input power is remove, the data will be lost.

# 11 USB PHY

The USB PHY provides High-Speed and Full-Speed, device, host, and on-the-go functionality. The PHY is configured through a set of peripheral registers (Appendix F), and data is communicated through ports on the digital node. A library, libxud\_s.a, is provided to implement USB device functionality.

# 11.1 Logical Core Requirements

The XMOS XUD software component runs in a single logical core with endpoint and application cores communicating with it via a combination of channel communication and shared memory variables.

Each IN (host requests data from device) or OUT (data transferred from host to device) endpoint requires one logical core.

To guarantee correct operation the USB logical core must run at at least 80 MIPS, and the logical cores that communicate with the USB core must also run at 80



MIPS. This means that no more than six logical cores execute at any one time on a 500MHz device.

# 12 Analog-to-Digital Converter

The device has a 12-bit 1MSample/second Successive Approximation Register (SAR) Analogue to Digital Converter (ADC). It has 4 input pins which are multiplexed into the ADC. The sampling of the ADC is controlled using GPIO pin X0D24 that is triggered either by writing to port 11, or by driving the pin externally. On each rising edge of the sample pin the ADC samples, holds and converts the data value from one of the analog input pins. Each of the 4 inputs can be enabled individually. Each of the enabled analog inputs is sampled in turn, on successive rising edges of the sample pin. The data is transmitted to the channel-end that the user configures during initialization of the ADC. Data is transmitted over the channel in individual packets, or in packets that contain multiple consecutive samples. The ADC uses an external reference voltage, nominally 3V3, which represents the full range of the ADC. The ADC configuration registers are documented in Appendix G.

The minimum latency for reading a value from the ADC into the xCORE register is shown in Figure 13:

F 1 L rea fror

| Figure 13:                      | Sample | Tile clock frequency | Start of packet | Subsequent samples |
|---------------------------------|--------|----------------------|-----------------|--------------------|
| Minimum<br>latency to           | 32-bit | 500 MHz              | 840 ns          | 710 ns             |
| ad sample<br>om ADC to<br>xCORE | 32-bit | 400 MHz              | 870 ns          | 740 ns             |
|                                 | 16-bit | 500 MHz              | 770 ns          | 640 ns             |
|                                 | 16-bit | 400 MHz              | 800 ns          | 670 ns             |

#### 13 Supervisor Logic

An independent supervisor circuit provides power-on-reset, brown-out, and watchdog capabilities. This facilitates the design of systems that fail gracefully, whilst keeping BOM costs down.

The reset supervisor holds the chip in reset until all power supplies are good. This provides a power-on-reset (POR). An external reset is optional and the pin RST\_N can be left not-connected.

If at any time any of the power supplies drop because of too little supply or too high a demand, the power supervisor will bring the chip into reset until the power supplies have been restored. This will reboot the system as if a cold-start has happened.

The 16-bit watchdog timer provides 1 ms accuracy and runs independently of the real-time counter. It can be programmed with a time-out of between 1 ms and 65 seconds (Appendix E). If the watchdog is not set before it times out, the XS1-U8A-64-FB96 is reset. On boot, the program can read a register to test whether the

reset was due to the watchdog. The watchdog timer is only enabled and clocked whilst the processor is in the AWAKE power state.

# 14 Energy management

XS1-U8A-64-FB96 devices can be powered by:

- An external 5v core and 3.3v I/O supply, increasing efficiency for USB bus powered applications.
- ► A single 3.3v supply.

# 14.1 DC-DC

XS1-U8A-64-FB96 devices include two DC-DC buck converters which can be configured to take input voltages between 3.3-5V power supply and output circuit voltages (nominally 1.8V and 1.0V) required by the analog peripherals and digital node.

# 14.2 Power mode controller

The device transitions through multiple states during the power-up and powerdown process.



The device is quiescent in the ASLEEP state, and is running in the AWAKE state. The other states allow a controlled transition between AWAKE and ASLEEP.

A transition from AWAKE state to ASLEEP state is instigated by a sleep request: either a write to the general control register or from the USB block requesting entry to standby mode. Sleep requests must only be made in the AWAKE state.

A transition from the ASLEEP state into the AWAKE state is instigated by a wakeup request triggered by a request from the USB block to exit standby mode an input, or a timer. The device only responds to a wakeup stimulus in the ASLEEP state. If wakeup stimulus occurs whilst transitioning from AWAKE to ASLEEP, the appropriate response occurs when the ASLEEP state is reached.

Configuration is through a set of registers documented in Appendix K.

# 14.3 Deep Sleep Modes and Real-Time Counter

The normal mode in which the XS1-U8A-64-FB96 operates is the AWAKE mode. In this mode, all cores, memory, and peripherals operate as normal. To save power, the XS1-U8A-64-FB96 can be put into a deep sleep mode, called ASLEEP, where the digital node is powered down, and most peripherals are powered down. The XS1-U8A-64-FB96 will stay in the ASLEEP mode until one of three conditions:

- 1. An external pin is asserted or deasserted (set by the program);
- 2. The 64-bit real-time counter reaches a value set by the program; or
- 3. The USB host (if USB is enabled) performs a wakeup.

Clocks used

Asleep

31,250 SiOsc

31.250 SiOsc

5 MHz ext osc

24 MHz crystal

Awake

20 Mhz SiOsc

24 MHz Crystal

5 MHz ext osc

24 MHz Crystal

When the chip is awake, the real-time counter counts the number of clock ticks on the oscillator. As such, the real-time counter will run at a fixed ratio, but synchronously with the 100 MHz timers on the xCORE Tile. When asleep, the real-time counter can be automatically switched to the 31,250 Hz silicon oscillator to save power (see Appendix I). To ensure that the real-time counter increases linearly over time, a programmable value is added to the counter on every 31,250 Hz clock-tick. This means that the clock will run at a granularity of 31,250 Hz but still maintain real-time in terms of the frequency of the main oscillator. If an accurate clock is required, even whilst asleep, then an external crystal or oscillator shall be provided that is used in both AWAKE and ASLEEP state.

The designer has to make a trade-off between accuracy of clocks when asleep and awake, costs, and deep-sleep power consumption. Four example designs are shown in Figure 15.

Power

Asleep

lowest

lowest

medium

highest

BOM

costs

lowest

medium

highest

medium

| Figure 15:    |
|---------------|
| Example       |
| trade-offs in |
| oscillator    |
| selection     |



Asleep

lowest

lowest

highest

highest

Accuracy

Awake

lowest

highest

highest

highest

During deep-sleep, the program can store some state in 128 bytes of Deep Sleep Memory.

#### 14.4 Requirements during sleep mode

Whilst in sleep mode, the device must still be powered as normal over 3V3 or 5V0 on VSUP, and 3V3 on VDDIO; however it will draw less power on both VSUP and VDDIO.

For best results (lowest power):

- > The XTAL bias and XTAL oscillators should be switched off.
- ▶ The sleep register should be configured to
  - Disable all power supplies except DCDC2.
  - Set all power supplies to PFM mode
  - Mask the clock
  - Assert reset
- All GPIO and JTAG pins should be quiescent, and none should be driven against a pull-up or pull-down.
- ▶ 3V3 should be supplied as the input voltage to VSUP.

This will result in a power consumption of less than 100 uA on both VSUP and VDDIO.

If any power supply loses power-good status during the asleep-to-awake or awake-to-asleep transitions, a system reset is issued.

# 15 JTAG

The JTAG module can be used for loading programs, boundary scan testing, incircuit source-level debugging and programming the OTP memory.



XMOS