# E·XFL

#### XMOS - XS1-L16A-128-QF124-I8 Datasheet



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                          |
|----------------------------|-----------------------------------------------------------------|
| Core Processor             | XCore                                                           |
| Core Size                  | 32-Bit 16-Core                                                  |
| Speed                      | 800MIPS                                                         |
| Connectivity               | Configurable                                                    |
| Peripherals                | -                                                               |
| Number of I/O              | 84                                                              |
| Program Memory Size        | 128KB (32K x 32)                                                |
| Program Memory Type        | SRAM                                                            |
| EEPROM Size                | -                                                               |
| RAM Size                   | -                                                               |
| Voltage - Supply (Vcc/Vdd) | 0.95V ~ 3.6V                                                    |
| Data Converters            | -                                                               |
| Oscillator Type            | External                                                        |
| Operating Temperature      | -40°C ~ 85°C (TA)                                               |
| Mounting Type              | Surface Mount                                                   |
| Package / Case             | 124-TFQFN Dual Rows, Exposed Pad                                |
| Supplier Device Package    | 124-QFN DualRow (10x10)                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/xmos/xs1-l16a-128-qf124-i8 |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

# 2 XS1-L16A-128-QF124 Features

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

- 16 real-time logical cores on 2 xCORE tiles
- Cores share up to 1000 MIPS
- Each logical core has:
  - Guaranteed throughput of between 1/4 and 1/8 of tile MIPS
  - 16x32bit 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

#### Programmable I/O

- 84 general-purpose I/O pins, configurable as input or output
  - Up to 32 x 1 bit port, 12 x 4bit port, 7 x 8bit port, 3 x 16bit port
    4 xCONNECT links
- Port sampling rates of up to 60 MHz with respect to an external clock
- 64 channel ends for communication with other cores, on or off-chip

#### Memory

- 128KB internal single-cycle SRAM (max 64KB per tile) for code and data storage
- 16KB internal OTP (max 8KB per tile) for application boot code

#### Hardware resources

- 12 clock blocks (6 per tile)
- 20 timers (10 per tile)
- 8 locks (4 per tile)

#### ► JTAG Module for On-Chip Debug

#### Security Features

• Programming lock disables debug and prevents read-back of memory contents

-XMOS

• 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

- 10: 1000 MIPS
- 8: 800 MIPS
- Power Consumption
  - Active Mode
    - 400 mA at 500 MHz (typical)
    - 320 mA at 400 MHz (typical)
  - Standby Mode
    - 28 mA
- ▶ 124-pin dual-row QFN package 0.5 mm pitch



| Signal | Functio                         | on               |                 |                 |                   |                   | Туре | Properties                       |
|--------|---------------------------------|------------------|-----------------|-----------------|-------------------|-------------------|------|----------------------------------|
| X1D00  |                                 | 1A <sup>0</sup>  |                 |                 |                   |                   | I/O  | PD <sub>S</sub> , R <sub>S</sub> |
| X1D01  | XLA <sup>4</sup> out            | 1 B <sup>0</sup> |                 |                 |                   |                   | I/O  | PD <sub>S</sub> , R <sub>S</sub> |
| X1D02  | XLA <sup>3</sup><br>out         |                  | 4A <sup>0</sup> | 8A <sup>0</sup> | 16A <sup>0</sup>  | 32A <sup>20</sup> | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D03  | XLA <sup>2</sup> <sub>out</sub> |                  | 4A <sup>1</sup> | 8A <sup>1</sup> | 16A <sup>1</sup>  | 32A <sup>21</sup> | I/O  | PDs, Ru                          |
| X1D04  | XLA <sup>1</sup> <sub>out</sub> |                  | 4B <sup>0</sup> | 8A <sup>2</sup> | 16A <sup>2</sup>  | 32A <sup>22</sup> | I/O  | PDs, Ru                          |
| X1D05  | XLA <sup>0</sup> out            |                  | 4B <sup>1</sup> | 8A <sup>3</sup> | 16A <sup>3</sup>  | 32A <sup>23</sup> | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D06  | XLA <sup>0</sup>                |                  | 4B <sup>2</sup> | 8A <sup>4</sup> | 16A <sup>4</sup>  | 32A <sup>24</sup> | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D07  | XLA <sup>1</sup>                |                  | 4B <sup>3</sup> | 8A <sup>5</sup> | 16A <sup>5</sup>  | 32A <sup>25</sup> | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D08  | XLA <sup>2</sup>                |                  | 4A <sup>2</sup> | 8A <sup>6</sup> | 16A <sup>6</sup>  | 32A <sup>26</sup> | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D09  | XLA <sup>3</sup>                |                  | 4A <sup>3</sup> | 8A <sup>7</sup> | 16A <sup>7</sup>  | 32A <sup>27</sup> | I/0  | $PD_S, R_U$                      |
| X1D10  | XLA <sup>4</sup>                | 1C <sup>0</sup>  |                 |                 |                   |                   | I/O  | PDs, Rs                          |
| X1D11  |                                 | 1D <sup>0</sup>  |                 |                 |                   |                   | I/O  | PD <sub>S</sub> , R <sub>S</sub> |
| X1D12  |                                 | 1E <sup>0</sup>  |                 |                 |                   |                   | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D13  | XLB <sup>4</sup> out            | 1 F <sup>0</sup> |                 |                 |                   |                   | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D14  | XLB <sup>3</sup> out            |                  | 4C <sup>0</sup> | 8B <sup>0</sup> | 16A <sup>8</sup>  | 32A <sup>28</sup> | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D15  | XLB <sup>2</sup><br>out         |                  | 4C <sup>1</sup> | 8B1             | 16A <sup>9</sup>  | 32A <sup>29</sup> | I/0  | $PD_S, R_U$                      |
| X1D16  | XLB <sup>1</sup><br>out         |                  | 4D <sup>0</sup> | 8B <sup>2</sup> | 16A <sup>10</sup> |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D17  | XLB <sup>0</sup> out            |                  | 4D <sup>1</sup> | 8B <sup>3</sup> | 16A <sup>11</sup> |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D18  | XLB <sup>0</sup>                |                  | 4D <sup>2</sup> | 8B <sup>4</sup> | 16A <sup>12</sup> |                   | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D19  | XLB <sup>1</sup>                |                  | 4D <sup>3</sup> | 8B <sup>5</sup> | 16A <sup>13</sup> |                   | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D20  | XLB <sup>2</sup>                |                  | 4C <sup>2</sup> | 8B <sup>6</sup> | 16A <sup>14</sup> | 32A <sup>30</sup> | I/0  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D21  | XLB <sup>3</sup>                |                  | 4C <sup>3</sup> | 8B <sup>7</sup> | 16A <sup>15</sup> | 32A <sup>31</sup> | I/0  | $PD_S, R_U$                      |
| X1D22  | XLB <sup>4</sup>                | 1G <sup>0</sup>  |                 |                 |                   |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D23  |                                 | 1H <sup>0</sup>  |                 |                 |                   |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D24  |                                 | 110              |                 |                 |                   |                   | I/O  | PDs                              |
| X1D25  |                                 | 1J <sup>0</sup>  |                 |                 |                   |                   | I/O  | PDs                              |
| X1D26  |                                 |                  | 4E <sup>0</sup> | 8C <sup>0</sup> | 16B <sup>0</sup>  |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D27  |                                 |                  | 4E <sup>1</sup> | 8C1             | 16B <sup>1</sup>  |                   | I/O  | $PD_S, R_U$                      |
| X1D28  |                                 |                  | 4F <sup>0</sup> | 8C <sup>2</sup> | 16B <sup>2</sup>  |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D29  |                                 |                  | 4F <sup>1</sup> | 8C <sup>3</sup> | 16B <sup>3</sup>  |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D30  |                                 |                  | 4F <sup>2</sup> | 8C <sup>4</sup> | 16B <sup>4</sup>  |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D31  |                                 |                  | 4F <sup>3</sup> | 8C <sup>5</sup> | 16B <sup>5</sup>  |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D32  |                                 |                  | 4E <sup>2</sup> | 8C <sup>6</sup> | 16B <sup>6</sup>  |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D33  |                                 |                  | 4E <sup>3</sup> | 8C <sup>7</sup> | 16B <sup>7</sup>  |                   | I/O  | $PD_S, R_U$                      |
| X1D34  |                                 | 1K <sup>0</sup>  |                 |                 |                   |                   | I/O  | PDs                              |
| X1D35  |                                 | 1L <sup>0</sup>  |                 |                 |                   |                   | I/O  | PDs                              |
| X1D36  |                                 | 1 M <sup>0</sup> |                 | 8D <sup>0</sup> | 16B <sup>8</sup>  |                   | I/O  | PDs                              |
| X1D37  |                                 | 1 N <sup>0</sup> |                 | 8D <sup>1</sup> | 16B <sup>9</sup>  |                   | I/O  | PD <sub>S</sub> , R <sub>U</sub> |
| X1D38  |                                 | 100              |                 | 8D <sup>2</sup> | 16B <sup>10</sup> |                   | I/O  | $PD_S, R_U$                      |
| X1D39  |                                 | 1 P <sup>0</sup> |                 | 8D <sup>3</sup> | 16B <sup>11</sup> |                   | I/O  | PD <sub>s</sub> , R <sub>U</sub> |

XS1-L16A-128-QF124

## 5 Product Overview

The XS1-L16A-128-QF124 is a powerful device that consists of two xCORE Tiles, each comprising a flexible logical processing cores with tightly integrated I/O and on-chip memory.

#### 5.1 Logical cores

MIPS

800 MIPS

1000 MIPS

Frequency

400 MHz

500 MHz

Speed

grade

8

10

Each 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 2 shows the guaranteed core performance depending on the number of cores used.

2

100

125

3

100

125

Minimum MIPS per core (for *n* cores)

5

80

100

6

67

83

7

57

71

8

50

63

4

100

125

Figure 2: Logical core performance

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.

1

100

125

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.

#### 5.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.

#### 5.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-L16A-128-QF124, and the software running on it. A combination of 1 bit, 4bit, 8bit, 16bit and 32bit ports are available. All pins of a port provide either output or input. Signals in different directions cannot be mapped onto the same port. Figure 8: Boot source pins

| MODE | MODE | MODE | Boot Source                                                    |
|------|------|------|----------------------------------------------------------------|
| [4]  | [3]  | [2]  |                                                                |
| Х    | 0    | 0    | None: Device waits to be booted via JTAG                       |
| X    | 0    | 1    | Reserved                                                       |
| 0    | 1    | 0    | Tile0 boots from link B, Tile1 from channel end 0 via Tile0    |
| 0    | 1    | 1    | Tile0 boots from SPI, Tile1 from channel end 0 via Tile0       |
| 1    | 1    | 0    | Tile0 and Tile1 independently enable link B and internal links |
|      |      |      | (E, F, G, H), and boot from channel end 0                      |
| 1    | 1    | 1    | Tile0 and Tile 1 boot from SPI independently                   |

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.

#### 7.1 Boot from SPI master

If set to boot from SPI master, the processor enables the four pins specified in Figure 9, 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                |
|------------|-------|--------|----------------------------|
|            | X0D00 | MISO   | Master In Slave Out (Data) |
| Figure 9:  | X0D01 | SS     | Slave Select               |
| SPI master | X0D10 | SCLK   | Clock                      |
| pins       | 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.

#### 7.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

# 9 JTAG



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

The JTAG chain structure is illustrated in Figure 11. Directly after reset, two TAP controllers are present in the JTAG chain for each xCORE Tile: the boundary scan TAP and the chip TAP. The boundary scan TAP is a standard 1149.1 compliant TAP that can be used for boundary scan of the I/O pins. The chip TAP provides access into the xCORE Tile, switch and OTP for loading code and debugging.

The TRST\_N pin must be asserted low during and after power up for 100 ns. If JTAG is not required, the TRST\_N pin can be tied to ground to hold the JTAG module in reset.

The DEBUG\_N pin is used to synchronize the debugging of multiple xCORE Tiles. This pin can operate in both output and input mode. In output mode and when configured to do so, DEBUG\_N is driven low by the device when the processor hits a debug break point. Prior to this point the pin will be tri-stated. In input mode and when configured to do so, driving this pin low will put the xCORE Tile into debug mode. Software can set the behavior of the xCORE Tile based on this pin. This pin should have an external pull up of  $4K7-47K\Omega$  or left not connected in single core applications.

The JTAG device identification register can be read by using the IDCODE instruction. Its contents are specified in Figure 12.

| <b>Figure 12</b>   | Bit31 |   |             | Device Identification Register |   |   |   |   |   |   |                       |   | В | it0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------------|-------|---|-------------|--------------------------------|---|---|---|---|---|---|-----------------------|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Figure 12: Version |       |   | Part Number |                                |   |   |   |   |   |   | Manufacturer Identity |   |   |     |   | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|                    | 0 0 0 | 0 | 0           | 0                              | 0 | 0 | 0 | 0 | 0 | 0 | 0                     | 0 | 0 | 0   | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| Tetuini value      | 0     |   |             | 0                              |   |   |   | ( | ) |   |                       | ( | 0 |     |   | i | 2 |   |   | ( | 5 |   |   |   | 3 |   |   | : | 3 |   |

 $\cdot X MOS$ 



-XMOS

21

#### 11 **DC and Switching Characteristics**

| Symbol    | Parameter                                     | MIN  | ΤΥΡ  | MAX  | UNITS | Notes |
|-----------|-----------------------------------------------|------|------|------|-------|-------|
| VDD       | Tile DC supply voltage                        | 0.95 | 1.00 | 1.05 | V     |       |
| VDDIO     | I/O supply voltage                            | 3.00 | 3.30 | 3.60 | V     |       |
| PLL_AVDD  | PLL analog supply                             | 0.95 | 1.00 | 1.05 | V     |       |
| PCU_VDD   | PCU tile DC supply voltage                    | 0.95 | 1.00 | 1.05 | V     |       |
| PCU_VDDIO | PCU I/O DC supply voltage                     | 3.00 | 3.30 | 3.60 | V     |       |
| OTP_VCC   | OTP supply voltage                            | 3.00 | 3.30 | 3.60 | V     |       |
| Cl        | xCORE Tile I/O load<br>capacitance            |      |      | 25   | pF    |       |
| Та        | Ambient operating<br>temperature (Commercial) | 0    |      | 70   | °C    |       |
|           | Ambient operating<br>temperature (Industrial) | -40  |      | 85   | °C    |       |
| Tj        | Junction temperature                          |      |      | 125  | °C    |       |
| Tstg      | Storage temperature                           | -65  |      | 150  | °C    |       |

#### 11.1 Operating Conditions

Figure 18: Operating conditions

Figure 19: DC characteristics

### 11.2 DC Characteristics

| Symbol | Parameter            | MIN   | TYP | MAX  | UNITS | Notes |
|--------|----------------------|-------|-----|------|-------|-------|
| V(IH)  | Input high voltage   | 2.00  |     | 3.60 | V     | A     |
| V(IL)  | Input low voltage    | -0.30 |     | 0.70 | V     | A     |
| V(OH)  | Output high voltage  | 2.00  |     |      | V     | B, C  |
| V(OL)  | Output low voltage   |       |     | 0.60 | V     | B, C  |
| R(PU)  | Pull-up resistance   |       | 35K |      | Ω     | D     |
| R(PD)  | Pull-down resistance |       | 35K |      | Ω     | D     |

A All pins except power supply pins.

B Ports 1A, 1D, 1E, 1H, 1J, 1K and 1L are nominal 8 mA drivers, the remainder of the general-purpose I/Os are 4 mA.

C Measured with 4 mA drivers sourcing 4 mA, 8 mA drivers sourcing 8 mA.

D Used to guarantee logic state for an I/O when high impedance. The internal pull-ups/pull-downs should not be used to pull external circuitry.

### 11.3 ESD Stress Voltage

Figure 2 ESD stre voltad

| 20: | Symbol | Parameter        | MIN   | TYP | MAX  | UNITS | Notes |
|-----|--------|------------------|-------|-----|------|-------|-------|
| SS  | HBM    | Human body model | -2.00 |     | 2.00 | KV    |       |
| ye  | MM     | Machine model    | -200  |     | 200  | V     |       |

-XMOS

#### 11.4 Reset Timing

Figure 21: Reset timing

| Symbol  | Parameters          | MIN | TYP | MAX | UNITS | Notes |
|---------|---------------------|-----|-----|-----|-------|-------|
| T(RST)  | Reset pulse width   | 5   |     |     | us    |       |
| T(INIT) | Initialization time |     |     | 150 | μs    | А     |

A Shows the time taken to start booting after RST\_N has gone high.

#### 11.5 Power Consumption

| Symbol    | Parameter                             | MIN | ТҮР | MAX | UNITS   | Notes      |
|-----------|---------------------------------------|-----|-----|-----|---------|------------|
| I(DDCQ)   | Quiescent VDD current                 |     | 28  |     | mA      | A, B, C    |
| PD        | Tile power dissipation                |     | 450 |     | µW/MIPS | A, D, E, F |
| IDD       | Active VDD current (Speed Grade<br>8) |     | 320 | 600 | mA      | A, G       |
|           | Active VDD current (Speed Grade 10)   |     | 400 | 750 | mA      | А, Н       |
| I(ADDPLL) | PLL_AVDD current                      |     |     | 14  | mA      | Ι          |

xCORE Tile currents

Figure 22:

A Use for budgetary purposes only.

B Assumes typical tile and I/O voltages with no switching activity.

C Includes PLL current.

D Assumes typical tile and I/O voltages with nominal switching activity.

E Assumes 1 MHz = 1 MIPS.

F PD(TYP) value is the usage power consumption under typical operating conditions.

-XM()S

G Measurement conditions: VDD = 1.0 V, VDDIO = 3.3 V, 25 °C, 400 MHz, average device resource usage.

H Measurement conditions: VDD = 1.0 V, VDDIO = 3.3 V, 25 °C, 500 MHz, average device resource usage.

I PLL\_AVDD = 1.0 V



The tile power consumption of the device is highly application dependent and should be used for budgetary purposes only.

More detailed power analysis can be found in the XS1-L Power Consumption document, X2999.

The asynchronous nature of links means that the relative phasing of CLK clocks is not important in a multi-clock system, providing each meets the required stability criteria.

| Symbol   | Parameter                     | MIN | ТҮР | MAX | UNITS | Notes |
|----------|-------------------------------|-----|-----|-----|-------|-------|
| f(TCK_D) | TCK frequency (debug)         |     |     | 18  | MHz   |       |
| f(TCK_B) | TCK frequency (boundary scan) |     |     | 10  | MHz   |       |
| T(SETUP) | TDO to TCK setup time         | 5   |     |     | ns    | А     |
| T(HOLD)  | TDO to TCK hold time          | 5   |     |     | ns    | А     |
| T(DELAY) | TCK to output delay           |     |     | 15  | ns    | В     |

#### 11.9 JTAG Timing

Figure 26: JTAG timing

A Timing applies to TMS and TDI inputs.

B Timing applies to TDO output from negative edge of TCK.

All JTAG operations are synchronous to TCK apart from the global asynchronous reset TRST\_N.



 $\Rightarrow$  ref, ...), where tileref is the name of the xCORE Tile, e.g. tile[1]. These functions implement the protocols described below.

Instead of using the functions above, a channel-end can be allocated to communicate with the xCORE tile configuration registers. The destination of the channel-end should be set to 0xnnnnC20C where nnnnn is the tile-identifier.

A write message comprises the following:

| control-token | 24-bit response        | 16-bit          | 32-bit | control-token |
|---------------|------------------------|-----------------|--------|---------------|
| 192           | channel-end identifier | register number | data   | 1             |

The response to a write message comprises either control tokens 3 and 1 (for success), or control tokens 4 and 1 (for failure).

A read message comprises the following:

| control-token | 24-bit response        | 16-bit          | control-token |
|---------------|------------------------|-----------------|---------------|
| 193           | channel-end identifier | register number | 1             |

The response to the read message comprises either control token 3, 32-bit of data, and control-token 1 (for success), or control tokens 4 and 1 (for failure).

#### A.3 Accessing node configuration

Node configuration registers can be accessed through the interconnect using the functions write\_node\_config\_reg(device, ...) and read\_node\_config\_reg(device, ...), where device is the name of the node. These functions implement the protocols described below.

Instead of using the functions above, a channel-end can be allocated to communicate with the node configuration registers. The destination of the channel-end should be set to 0xnnnnC30C where nnnn is the node-identifier.

A write message comprises the following:

| control-token | 24-bit response        | 16-bit          | 32-bit | control-token |
|---------------|------------------------|-----------------|--------|---------------|
| 192           | channel-end identifier | register number | data   | 1             |

The response to a write message comprises either control tokens 3 and 1 (for success), or control tokens 4 and 1 (for failure).

A read message comprises the following:

| control-token | 24-bit response        | 16-bit          | control-token |
|---------------|------------------------|-----------------|---------------|
| 193           | channel-end identifier | register number | 1             |

The response to a read message comprises either control token 3, 32-bit of data, and control-token 1 (for success), or control tokens 4 and 1 (for failure).

-XM()S

# **B** Processor Status Configuration

The processor status control registers can be accessed directly by the processor using processor status reads and writes (use getps(reg) and setps(reg,value) for reads and writes).

| Number    | Perm | Description                           |
|-----------|------|---------------------------------------|
| 0x00      | RW   | RAM base address                      |
| 0x01      | RW   | Vector base address                   |
| 0x02      | RW   | xCORE Tile control                    |
| 0x03      | RO   | xCORE Tile boot status                |
| 0x05      | RO   | Security configuration                |
| 0x06      | RW   | Ring Oscillator Control               |
| 0x07      | RO   | Ring Oscillator Value                 |
| 0x08      | RO   | Ring Oscillator Value                 |
| 0x09      | RO   | Ring Oscillator Value                 |
| 0x0A      | RO   | Ring Oscillator Value                 |
| 0x10      | DRW  | Debug SSR                             |
| 0x11      | DRW  | Debug SPC                             |
| 0x12      | DRW  | Debug SSP                             |
| 0x13      | DRW  | DGETREG operand 1                     |
| 0x14      | DRW  | DGETREG operand 2                     |
| 0x15      | DRW  | Debug interrupt type                  |
| 0x16      | DRW  | Debug interrupt data                  |
| 0x18      | DRW  | Debug core control                    |
| 0x20 0x27 | DRW  | Debug scratch                         |
| 0x30 0x33 | DRW  | Instruction breakpoint address        |
| 0x40 0x43 | DRW  | Instruction breakpoint control        |
| 0x50 0x53 | DRW  | Data watchpoint address 1             |
| 0x60 0x63 | DRW  | Data watchpoint address 2             |
| 0x70 0x73 | DRW  | Data breakpoint control register      |
| 0x80 0x83 | DRW  | Resources breakpoint mask             |
| 0x90 0x93 | DRW  | Resources breakpoint value            |
| 0x9C 0x9F | DRW  | Resources breakpoint control register |

-XMOS"

Figure 30: Summary

XS1-L16A-128-QF124

#### B.8 Ring Oscillator Value: 0x08

This register contains the current count of the xCORE Tile Wire ring oscillator. This value is not reset on a system reset.

**0x08:** Ring Oscillator Value

| Bits  | Perm | Init | Description                   |
|-------|------|------|-------------------------------|
| 31:16 | RO   | -    | Reserved                      |
| 15:0  | RO   | -    | Ring oscillator counter data. |

#### B.9 Ring Oscillator Value: 0x09

This register contains the current count of the Peripheral Cell ring oscillator. This value is not reset on a system reset.

**0x09** Ring Oscillator Value

| ):     | Bits  | Perm | Init | Description                   |
|--------|-------|------|------|-------------------------------|
| ,<br>r | 31:16 | RO   | -    | Reserved                      |
| è      | 15:0  | RO   | -    | Ring oscillator counter data. |

#### B.10 Ring Oscillator Value: 0x0A

This register contains the current count of the Peripheral Wire ring oscillator. This value is not reset on a system reset.

**0x0A:** Ring Oscillator Value

| <b>A</b> : | Bits  | Perm | Init | Description                   |
|------------|-------|------|------|-------------------------------|
| 9<br>or    | 31:16 | RO   | -    | Reserved                      |
| e          | 15:0  | RO   | -    | Ring oscillator counter data. |

#### B.11 Debug SSR: 0x10

This register contains the value of the SSR register when the debugger was called.

| 0x10:     | Bits | Perm | Init | Description |
|-----------|------|------|------|-------------|
| Debug SSR | 31:0 | RO   | -    | Reserved    |

#### B.12 Debug SPC: 0x11

This register contains the value of the SPC register when the debugger was called.

#### B.19 Debug scratch: 0x20 .. 0x27

A set of registers used by the debug ROM to communicate with an external debugger, for example over JTAG. This is the same set of registers as the Debug Scratch registers in the xCORE tile configuration.

0x20 .. 0x27: Debug scratch

| kz7:<br>bug | Bits | Perm | Init | Description |
|-------------|------|------|------|-------------|
| atch        | 31:0 | DRW  |      | Value.      |

#### B.20 Instruction breakpoint address: 0x30 .. 0x33

This register contains the address of the instruction breakpoint. If the PC matches this address, then a debug interrupt will be taken. There are four instruction breakpoints that are controlled individually.

0x30 .. 0x33: Instruction breakpoint address

| tion<br>oint | Bits | Perm | Init | Description |
|--------------|------|------|------|-------------|
| ress         | 31:0 | DRW  |      | Value.      |

#### B.21 Instruction breakpoint control: 0x40 .. 0x43

This register controls which logical cores may take an instruction breakpoint, and under which condition.

| Bit   | Perm | Init | Description                                                                                                                                                                                 |
|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | -    | Reserved                                                                                                                                                                                    |
| 23:10 | DRW  | 0    | A bit for each logical core in the tile allowing the breakpoint to be enabled individually for each logical core.                                                                           |
| 15:2  | RO   | -    | Reserved                                                                                                                                                                                    |
|       | DRW  | 0    | Set to 1 to cause an instruction breakpoint if the PC is not<br>equal to the breakpoint address. By default, the breakpoint is<br>triggered when the PC is equal to the breakpoint address. |
| (     | DRW  | 0    | When 1 the instruction breakpoint is enabled.                                                                                                                                               |

0x40 .. 0x43: Instruction breakpoint control

#### B.22 Data watchpoint address 1: 0x50 .. 0x53

This set of registers contains the first address for the four data watchpoints.

XMOS

0x50 .. 0x53: Data watchpoint address 1

| Data<br>point | Bits | Perm | Init | Description |
|---------------|------|------|------|-------------|
| ess 1         | 31:0 | DRW  |      | Value.      |

#### B.23 Data watchpoint address 2: 0x60 .. 0x63

This set of registers contains the second address for the four data watchpoints.

0x60 .. 0x63: Data watchpoint address 2

| a<br>it | Bits | Perm | Init | Description |
|---------|------|------|------|-------------|
| 2       | 31:0 | DRW  |      | Value.      |

#### B.24 Data breakpoint control register: 0x70 .. 0x73

This set of registers controls each of the four data watchpoints.

|                      | Bits  | Perm | Init | Description                                                                                                                                                                                                                                                                                       |  |  |
|----------------------|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                      | 31:24 | RO   | -    | Reserved                                                                                                                                                                                                                                                                                          |  |  |
|                      | 23:16 | DRW  | 0    | A bit for each logical core in the tile allowing the breakpoint to be enabled individually for each logical core.                                                                                                                                                                                 |  |  |
|                      | 15:3  | RO   | -    | Reserved                                                                                                                                                                                                                                                                                          |  |  |
|                      | 2     | DRW  | 0    | Set to 1 to enable breakpoints to be triggered on loads. Breakpoints always trigger on stores.                                                                                                                                                                                                    |  |  |
| <b>3:</b><br>a<br>it | 1     | DRW  | 0    | By default, data watchpoints trigger if memory in the range [Address1Address2] is accessed (the range is inclusive of Address1 and Address2). If set to 1, data watchpoints trigger if memory outside the range (Address2Address1) is accessed (the range is exclusive of Address2 and Address1). |  |  |
| r                    | 0     | DRW  | 0    | When 1 the instruction breakpoint is enabled.                                                                                                                                                                                                                                                     |  |  |

0x70 .. 0x73: Data breakpoint control register

#### B.25 Resources breakpoint mask: 0x80 .. 0x83

This set of registers contains the mask for the four resource watchpoints.

-XMOS<sup>®</sup>

# D Node Configuration

The digital node control registers can be accessed using configuration reads and writes (use write\_node\_config\_reg(device, ...) and read\_node\_config\_reg(device, ...) for reads and writes).

| Number    | Perm | Description                           |
|-----------|------|---------------------------------------|
| 0x00      | RO   | Device identification                 |
| 0x01      | RO   | System switch description             |
| 0x04      | RW   | Switch configuration                  |
| 0x05      | RW   | Switch node identifier                |
| 0x06      | RW   | PLL settings                          |
| 0x07      | RW   | System switch clock divider           |
| 0x08      | RW   | Reference clock                       |
| 0x0C      | RW   | Directions 0-7                        |
| 0x0D      | RW   | Directions 8-15                       |
| 0x10      | RW   | DEBUG_N configuration                 |
| 0x1F      | RO   | Debug source                          |
| 0x20 0x27 | RW   | Link status, direction, and network   |
| 0x40 0x43 | RW   | PLink status and network              |
| 0x80 0x87 | RW   | Link configuration and initialization |
| 0xA0 0xA7 | RW   | Static link configuration             |

Figure 32: Summary

### D.1 Device identification: 0x00

This register contains version and revision identifiers and the mode-pins as sampled at boot-time.

|                | Bits  | Perm | Init | Description                                    |
|----------------|-------|------|------|------------------------------------------------|
|                | 31:24 | RO   | 0x00 | Chip identifier.                               |
| 0×00:          | 23:16 | RO   |      | Sampled values of pins MODE0, MODE1, on reset. |
| Device         | 15:8  | RO   |      | SSwitch revision.                              |
| identification | 7:0   | RO   |      | SSwitch version.                               |

#### D.2 System switch description: 0x01

This register specifies the number of processors and links that are connected to this switch.

-XMOS

#### D.11 Debug source: 0x1F

Contains the source of the most recent debug event.

| Bits | Perm | Init | Description                                                                        |
|------|------|------|------------------------------------------------------------------------------------|
| 31:5 | RO   | -    | Reserved                                                                           |
| 4    | RW   |      | If set, the external DEBUG_N pin is the source of the most recent debug interrupt. |
| 3:1  | RO   | -    | Reserved                                                                           |
| 0    | RW   |      | If set, the xCORE Tile is the source of the most recent debug interrupt.           |

0x1F: Debug source

#### D.12 Link status, direction, and network: 0x20 .. 0x27

These registers contain status information for low level debugging (read-only), the network number that each link belongs to, and the direction that each link is part of. The registers control links C, D, A, B, G, H, E, and F in that order.

| Bits  | Perm | Init | Description                                                                                                                                                                              |
|-------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RO   | -    | Reserved                                                                                                                                                                                 |
| 25:24 | RO   |      | If this link is currently routing data into the switch, this field<br>specifies the type of link that the data is routed to:<br>0: plink<br>1: external link<br>2: internal control link |
| 23:16 | RO   | 0    | If the link is routing data into the switch, this field specifies the destination link number to which all tokens are sent.                                                              |
| 15:12 | RO   | -    | Reserved                                                                                                                                                                                 |
| 11:8  | RW   | 0    | The direction that this this link is associated with; set for rout-<br>ing.                                                                                                              |
| 7:6   | RO   | -    | Reserved                                                                                                                                                                                 |
| 5:4   | RW   | 0    | Determines the network to which this link belongs, set for quality of service.                                                                                                           |
| 3     | RO   | -    | Reserved                                                                                                                                                                                 |
| 2     | RO   | 0    | Set to 1 if the current packet is junk and being thrown away. A packet is considered junk if, for example, it is not routable.                                                           |
| 1     | RO   | 0    | Set to 1 if the switch is routing data into the link, and if a route exists from another link.                                                                                           |
| 0     | RO   | 0    | Set to 1 if the link is routing data into the switch, and if a route is created to another link on the switch.                                                                           |

-XMOS

0x20 .. 0x27: Link status, direction, and network

#### D.13 PLink status and network: 0x40 .. 0x43

These registers contain status information and the network number that each processor-link belongs to.

| Bits  | Perm | Init | Description                                                                                                                                                                              |  |
|-------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:26 | RO   | -    | Reserved                                                                                                                                                                                 |  |
| 25:24 | RO   |      | If this link is currently routing data into the switch, this field<br>specifies the type of link that the data is routed to:<br>0: plink<br>1: external link<br>2: internal control link |  |
| 23:16 | RO   | 0    | If the link is routing data into the switch, this field specifies the destination link number to which all tokens are sent.                                                              |  |
| 15:6  | RO   | -    | Reserved                                                                                                                                                                                 |  |
| 5:4   | RW   | 0    | Determines the network to which this link belongs, set for quality of service.                                                                                                           |  |
| 3     | RO   | -    | Reserved                                                                                                                                                                                 |  |
| 2     | RO   | 0    | Set to 1 if the current packet is junk and being thrown away. A packet is considered junk if, for example, it is not routable.                                                           |  |
| 1     | RO   | 0    | Set to 1 if the switch is routing data into the link, and if a route exists from another link.                                                                                           |  |
| 0     | RO   | 0    | Set to 1 if the link is routing data into the switch, and if a route is created to another link on the switch.                                                                           |  |

0x40 .. 0x43: PLink status and network

#### D.14 Link configuration and initialization: 0x80 .. 0x87

-XMOS<sup>®</sup>

These registers contain configuration and debugging information specific to external links. The link speed and width can be set, the link can be initialized, and the link status can be monitored. The registers control links C, D, A, B, G, H, E, and F in that order.

- ▶ TDO to pin 13 of the xSYS header
- RST\_N and TRST\_N to pin 15 of the xSYS header
- If MODE2 is configured high, connect MODE2 to pin 3 of the xSYS header. Do not connect to VDDIO.
- If MODE3 is configured high, connect MODE3 to pin 3 of the xSYS header. Do not connect to VDDIO.

The RST\_N net should be open-drain, active-low, and have a pull-up to VDDIO.

#### G.3 Full xSYS header

For a full xSYS header you will need to connect the pins as discussed in Section G.2, and then connect a 2-wire xCONNECT Link to the xSYS header. The links can be found in the Signal description table (Section 4): they are labelled XLA, XLB, etc in the function column. The 2-wire link comprises two inputs and outputs, labelled  ${}^{1}_{out}$ ,  ${}^{0}_{out}$ ,  ${}^{0}_{in}$ , and  ${}^{1}_{in}$ . For example, if you choose to use XLB of tile 0 for xSCOPE I/O, you need to connect up XLB<sup>1</sup><sub>out</sub>, XLB<sup>0</sup><sub>out</sub>, XLB<sup>0</sup><sub>in</sub>, XLB<sup>1</sup><sub>in</sub> as follows:

- XLB<sup>1</sup><sub>out</sub> (X0D16) to pin 6 of the xSYS header with a 33R series resistor close to the device.
- XLB<sup>0</sup><sub>out</sub> (X0D17) to pin 10 of the xSYS header with a 33R series resistor close to the device.
- ▶ XLB<sup>0</sup><sub>in</sub> (X0D18) to pin 14 of the xSYS header.
- >  $XLB_{in}^{1}$  (X0D19) to pin 18 of the xSYS header.

-XM()S

# H Schematics Design Check List

✓ This section is a checklist for use by schematics designers using the XS1-L16A-128-QF124. Each of the following sections contains items to check for each design.

#### H.1 Power supplies

- □ VDDIO and OTP\_VCC supply is within specification before the VDD (core) supply is turned on. Specifically, the VDDIO and OTP\_VCC supply is within specification before VDD (core) reaches 0.4V (Section 10).
- The VDD (core) supply ramps monotonically (rises constantly) from 0V to its final value (0.95V 1.05V) within 10ms (Section 10).
- $\Box$  The VDD (core) supply is capable of supplying 600mA (Section 10).
- PLL\_AVDD is filtered with a low pass filter, for example an RC filter, see Section 10
- The PCU\_VDD pin is connected to the VDD supply and PCU\_VDDIO is connected to the VDDIO supply (Section 10).

#### H.2 Power supply decoupling

- The design has multiple decoupling capacitors per supply, for example at least four0402 or 0603 size surface mount capacitors of 100nF in value, per supply (Section 10).
- □ A bulk decoupling capacitor of at least 10uF is placed on each supply (Section 10).

#### H.3 Power on reset

The RST\_N and TRST\_N pins are asserted (low) during or after power up. The device is not used until these resets have taken place. As the errata in the datasheets show, the internal pull-ups on these two pins can occasionally provide stronger than normal pull-up currents. For this reason, an RC type reset circuit is discouraged as behavior would be unpredictable. A voltage supervisor type reset device is recommended to guarantee a good reset. This also has the benefit of resetting the system should the relevant supply go out of specification.

-XM()S

# J Associated Design Documentation

| Document Title                                 | Information                               | Document Number |
|------------------------------------------------|-------------------------------------------|-----------------|
| Estimating Power Consumption For XS1-L Devices | Power consumption                         | X4271           |
| Programming XC on XMOS Devices                 | Timers, ports, clocks, cores and channels | X9577           |
| xTIMEcomposer User Guide                       | Compilers, assembler and linker/mapper    | X3766           |
|                                                | Timing analyzer, xScope, debugger         |                 |
|                                                | Flash and OTP programming utilities       |                 |

# **K** Related Documentation

| Document Title                                  | Information                         | Document Number |
|-------------------------------------------------|-------------------------------------|-----------------|
| The XMOS XS1 Architecture                       | ISA manual                          | X7879           |
| XS1 Port I/O Timing                             | Port timings                        | X5821           |
| xCONNECT Architecture                           | Link, switch and system information | X4249           |
| XS1-L Link Performance and Design<br>Guidelines | Link timings                        | X2999           |
| XS1-L Clock Frequency Control                   | Advanced clock control              | X1433           |
| XS1-L Active Power Conservation                 | Low-power mode during idle          | X7411           |

-XMOS<sup>®</sup>-