



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 24-Core                                                 |
| Speed                      | 4000MIPS                                                       |
| Connectivity               | -                                                              |
| Peripherals                | -                                                              |
| Number of I/O              | 176                                                            |
| Program Memory Size        | -                                                              |
| Program Memory Type        | ROMIess                                                        |
| EEPROM Size                | -                                                              |
| RAM Size                   | 1M x 8                                                         |
| 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             | 374-LFBGA                                                      |
| Supplier Device Package    | 374-FBGA (18x18)                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/xmos/xl224-1024-fb374-i40 |

Email: info@E-XFL.COM

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

# 1 xCORE Multicore Microcontrollers

The xCORE200 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.



Figure 1: XL224-1024-FB374 block diagram

Key features of the XL224-1024-FB374 include:

- ► **Tiles**: Devices consist of one or more xCORE tiles. Each tile contains between five 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 6.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

# 2 XL224-1024-FB374 Features

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

- 24 real-time logical cores on 4 xCORE tiles
- Cores share up to 2000 MIPS
  - Up to 4000 MIPS in dual issue mode
- Each logical core has:
  - Guaranteed throughput of between 1/5 and 1/6 of tile MIPS
  - 16x32bit dedicated registers
- 167 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

- 256 general-purpose I/O pins, configurable as input or output
  - Up to 56 x 1bit port, 22 x 4bit port, 13 x 8bit port, 6 x 16bit port, 4 x 32bit port 8 xCONNECT links
- Port sampling rates of up to 60 MHz with respect to an external clock
- 128 channel ends (32 per tile) for communication with other cores, on or off-chip

#### Memory

- 1024KB internal single-cycle SRAM (max 256KB per tile) for code and data storage
- 32KB internal OTP (max 8KB per tile) for application boot code

#### Hardware resources

- 24 clock blocks (6 per tile)
- 40 timers (10 per tile)
- 16 locks (4 per tile)
- JTAG Module for On-Chip Debug

#### Security Features

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

-XM()S

- 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
  - 40: 2000 MIPS
- Power Consumption
  - 1140 mA (typical)
- ▶ 374-pin FBGA package 0.8 mm pitch

| Signal | Function                                      |                  |                 |                 |                   |                   | Туре | Properties |
|--------|-----------------------------------------------|------------------|-----------------|-----------------|-------------------|-------------------|------|------------|
| X1D17  | X <sub>0</sub> L3 <sup>0</sup>                |                  | 4D <sup>1</sup> | 8B <sup>3</sup> | 16A <sup>11</sup> |                   | I/0  | IO, PD     |
| X1D18  | X <sub>0</sub> L3 <sup>0</sup> <sub>out</sub> |                  | 4D <sup>2</sup> | 8B <sup>4</sup> | 16A <sup>12</sup> |                   | I/O  | IO, PD     |
| X1D19  | X <sub>0</sub> L3 <sup>1</sup> <sub>out</sub> |                  | 4D <sup>3</sup> | 8B <sup>5</sup> | 16A <sup>13</sup> |                   | I/0  | IO, PD     |
| X1D20  |                                               |                  | 4C <sup>2</sup> | 8B <sup>6</sup> | 16A <sup>14</sup> | 32A <sup>30</sup> | I/0  | IO, PD     |
| X1D21  |                                               |                  | 4C <sup>3</sup> | 8B <sup>7</sup> | 16A <sup>15</sup> | 32A <sup>31</sup> | I/0  | IO, PD     |
| X1D22  | X <sub>0</sub> L3 <sup>4</sup> <sub>out</sub> | 1G <sup>0</sup>  |                 |                 |                   |                   | I/0  | IO, PD     |
| X1D23  |                                               | 1H <sup>0</sup>  |                 |                 |                   |                   | I/O  | IO, PD     |
| X1D24  |                                               | 11 <sup>0</sup>  |                 |                 |                   |                   | I/O  | IO, PD     |
| X1D25  |                                               | 1J <sup>0</sup>  |                 |                 |                   |                   | I/0  | IO, PD     |
| X1D26  |                                               |                  | 4E <sup>0</sup> | 8C <sup>0</sup> | 16B <sup>0</sup>  |                   | I/0  | IOT, PD    |
| X1D27  |                                               |                  | 4E <sup>1</sup> | 8C1             | 16B <sup>1</sup>  |                   | I/0  | IOT, PD    |
| X1D28  |                                               |                  | 4F <sup>0</sup> | 8C <sup>2</sup> | 16B <sup>2</sup>  |                   | I/O  | IOT, PD    |
| X1D29  |                                               |                  | 4F <sup>1</sup> | 8C <sup>3</sup> | 16B <sup>3</sup>  |                   | I/O  | IOT, PD    |
| X1D30  |                                               |                  | 4F <sup>2</sup> | 8C <sup>4</sup> | 16B <sup>4</sup>  |                   | I/0  | IOT, PD    |
| X1D31  |                                               |                  | 4F <sup>3</sup> | 8C <sup>5</sup> | 16B <sup>5</sup>  |                   | I/0  | IOT, PD    |
| X1D32  |                                               |                  | 4E <sup>2</sup> | 8C <sup>6</sup> | 16B <sup>6</sup>  |                   | I/O  | IOT, PD    |
| X1D33  |                                               |                  | 4E <sup>3</sup> | 8C <sup>7</sup> | 16B <sup>7</sup>  |                   | I/O  | IOT, PD    |
| X1D34  | X <sub>0</sub> L0 <sup>2</sup> <sub>out</sub> | 1K <sup>0</sup>  |                 |                 |                   |                   | I/O  | IO, PD     |
| X1D35  | X <sub>0</sub> L0 <sup>3</sup> <sub>out</sub> | 1L <sup>0</sup>  |                 |                 |                   |                   | I/O  | IO, PD     |
| X1D36  | X <sub>0</sub> L0 <sup>4</sup> <sub>out</sub> | 1M <sup>0</sup>  |                 | 8D <sup>0</sup> | 16B <sup>8</sup>  |                   | I/O  | IO, PD     |
| X1D37  | X <sub>0</sub> L3 <sup>4</sup> <sub>in</sub>  | 1N <sup>0</sup>  |                 | 8D1             | 16B <sup>9</sup>  |                   | I/O  | IO, PD     |
| X1D38  | $X_0L3_{in}^3$                                | 10 <sup>0</sup>  |                 | 8D <sup>2</sup> | 16B <sup>10</sup> |                   | I/O  | IO, PD     |
| X1D39  | X <sub>0</sub> L3 <sup>2</sup> <sub>in</sub>  | 1 P <sup>0</sup> |                 | 8D <sup>3</sup> | 16B <sup>11</sup> |                   | I/O  | IO, PD     |
| X1D40  |                                               |                  |                 | 8D <sup>4</sup> | 16B <sup>12</sup> |                   | I/O  | IOT, PD    |
| X1D41  |                                               |                  |                 | 8D <sup>5</sup> | 16B <sup>13</sup> |                   | I/0  | IOT, PD    |
| X1D42  |                                               |                  |                 | 8D <sup>6</sup> | 16B <sup>14</sup> |                   | I/O  | IOT, PD    |
| X1D43  |                                               |                  |                 | 8D <sup>7</sup> | 16B <sup>15</sup> |                   | I/O  | IOT, PD    |
| X1D49  | X <sub>0</sub> L1 <sup>4</sup> <sub>in</sub>  |                  |                 |                 |                   | 32A <sup>0</sup>  | I/O  | IO, PD     |
| X1D50  | X <sub>0</sub> L1 <sup>3</sup>                |                  |                 |                 |                   | 32A <sup>1</sup>  | I/O  | IO, PD     |
| X1D51  | X <sub>0</sub> L1 <sup>2</sup>                |                  |                 |                 |                   | 32A <sup>2</sup>  | I/O  | IO, PD     |
| X1D52  | X <sub>0</sub> L1 <sup>1</sup>                |                  |                 |                 |                   | 32A <sup>3</sup>  | I/O  | IO, PD     |
| X1D53  | $X_0L1_{in}^0$                                |                  |                 |                 |                   | 32A <sup>4</sup>  | I/0  | IO, PD     |
| X1D54  | X <sub>0</sub> L1 <sup>0</sup> <sub>out</sub> |                  |                 |                 |                   | 32A <sup>5</sup>  | I/0  | IO, PD     |
| X1D55  | X <sub>0</sub> L1 <sup>1</sup> <sub>out</sub> |                  |                 |                 |                   | 32A <sup>6</sup>  | I/0  | IO, PD     |
| X1D56  | X <sub>0</sub> L1 <sup>2</sup> <sub>out</sub> |                  |                 |                 |                   | 32A <sup>7</sup>  | I/0  | IO, PD     |
| X1D57  | X <sub>0</sub> L1 <sup>3</sup>                |                  |                 |                 |                   | 32A <sup>8</sup>  | I/0  | IO, PD     |
| X1D58  | X <sub>0</sub> L1 <sup>4</sup>                |                  |                 |                 |                   | 32A <sup>9</sup>  | I/0  | IO, PD     |
| X1D61  | X <sub>0</sub> L2 <sup>4</sup>                |                  |                 |                 |                   | 32A <sup>10</sup> | I/O  | IO, PD     |
| X1D62  | X <sub>0</sub> L2 <sup>3</sup>                |                  |                 |                 |                   | 32A <sup>11</sup> | I/O  | IO, PD     |
| X1D63  | X <sub>0</sub> L2 <sup>2</sup>                |                  |                 |                 |                   | 32A <sup>12</sup> | I/0  | IO, PD     |
| X1D64  | X <sub>0</sub> L2 <sup>1</sup>                |                  |                 |                 |                   | 32A <sup>13</sup> | I/0  | IO, PD     |
| X1D65  | X <sub>0</sub> L2 <sup>0</sup>                |                  |                 |                 |                   | 32A <sup>14</sup> | I/O  | IO, PD     |
| X1D66  | X <sub>0</sub> L2 <sup>0</sup> <sub>out</sub> |                  |                 |                 |                   | 32A <sup>15</sup> | I/0  | IO, PD     |

(continued)

XS2-L24A-1024-FB374

X010436,



(continued)

| Signal | Function                                                                                           | Туре              | Properties |
|--------|----------------------------------------------------------------------------------------------------|-------------------|------------|
| X2D53  | X <sub>2</sub> L5 <sup>0</sup> <sub>in</sub> 32A                                                   | 4 I/O             | IO, PD     |
| X2D54  | X <sub>2</sub> L5 <sup>0</sup> <sub>out</sub> 32A                                                  | 5 I/O             | IO, PD     |
| X2D55  | X <sub>2</sub> L5 <sup>1</sup> 32A                                                                 | <sup>6</sup> I/O  | IO, PD     |
| X2D56  | X <sub>2</sub> L5 <sup>2</sup> <sub>out</sub> 32A                                                  | <sup>7</sup> I/O  | IO, PD     |
| X2D57  | X <sub>2</sub> L5 <sup>3</sup> <sub>out</sub> 32A                                                  | <sup>8</sup> I/O  | IO, PD     |
| X2D58  | X <sub>2</sub> L5 <sup>4</sup> <sub>out</sub> 32A                                                  | <sup>9</sup> I/O  | IO, PD     |
| X2D61  | X <sub>2</sub> L6 <sup>4</sup> 32A                                                                 | <sup>10</sup> I/O | IO, PD     |
| X2D62  | X <sub>2</sub> L6 <sup>3</sup> 32A                                                                 | <sup>11</sup> I/O | IO, PD     |
| X2D63  | X <sub>2</sub> L6 <sup>2</sup> 32A                                                                 | <sup>12</sup> I/O | IO, PD     |
| X2D64  | X <sub>2</sub> L6 <sup>1</sup> <sub>in</sub> 32A                                                   | <sup>13</sup> I/O | IO, PD     |
| X2D65  | X <sub>2</sub> L6 <sup>0</sup> <sub>in</sub> 32A                                                   | <sup>14</sup> I/O | IO, PD     |
| X2D66  | X <sub>2</sub> L6 <sup>0</sup> <sub>out</sub> 32A                                                  | <sup>15</sup> I/O | IO, PD     |
| X2D67  | X <sub>2</sub> L6 <sup>1</sup> 32A                                                                 | <sup>16</sup> I/O | IO, PD     |
| X2D68  | X <sub>2</sub> L6 <sup>2</sup> <sub>out</sub> 32A                                                  | <sup>17</sup> I/O | IO, PD     |
| X2D69  | X <sub>2</sub> L6 <sup>3</sup> <sub>out</sub> 32A                                                  | <sup>18</sup> I/O | IO, PD     |
| X2D70  | X <sub>2</sub> L6 <sup>4</sup> <sub>out</sub> 32A                                                  | <sup>19</sup> I/O | IO, PD     |
| X3D00  | X <sub>2</sub> L7 <sup>2</sup> <sub>in</sub> 1A <sup>0</sup>                                       | I/O               | IO, PD     |
| X3D01  | X <sub>2</sub> L7 <sup>1</sup> <sub>in</sub> 1B <sup>0</sup>                                       | I/0               | IO, PD     |
| X3D02  | X <sub>2</sub> L4 <sup>0</sup> 4A <sup>0</sup> 8A <sup>0</sup> 16A <sup>0</sup> 32A                | <sup>20</sup> I/O | IO, PD     |
| X3D03  | X <sub>2</sub> L4 <sup>0</sup> 4A <sup>1</sup> 8A <sup>1</sup> 16A <sup>1</sup> 32A                | <sup>21</sup> I/O | IO, PD     |
| X3D04  | X <sub>2</sub> L4 <sup>1</sup> 4B <sup>0</sup> 8A <sup>2</sup> 16A <sup>2</sup> 32A                | <sup>22</sup> I/O | IO, PD     |
| X3D05  | X <sub>2</sub> L4 <sup>2</sup> <sub>out</sub> 4B <sup>1</sup> 8A <sup>3</sup> 16A <sup>3</sup> 32A | <sup>23</sup> I/O | IO, PD     |
| X3D06  | X <sub>2</sub> L4 <sup>3</sup> <sub>out</sub> 4B <sup>2</sup> 8A <sup>4</sup> 16A <sup>4</sup> 32A | <sup>24</sup> I/O | IO, PD     |
| X3D07  | X <sub>2</sub> L4 <sup>4</sup> 4B <sup>3</sup> 8A <sup>5</sup> 16A <sup>5</sup> 32A                | <sup>25</sup> I/O | IO, PD     |
| X3D08  | X <sub>2</sub> L7 <sup>4</sup> 4A <sup>2</sup> 8A <sup>6</sup> 16A <sup>6</sup> 32A                | <sup>26</sup> I/O | IO, PD     |
| X3D09  | X <sub>2</sub> L7 <sup>3</sup> <sub>in</sub> 4A <sup>3</sup> 8A <sup>7</sup> 16A <sup>7</sup> 32A  | <sup>27</sup> I/O | IO, PD     |
| X3D10  | 1C <sup>0</sup>                                                                                    | I/0               | IOT, PD    |
| X3D11  | 1D <sup>0</sup>                                                                                    | I/0               | IOT, PD    |
| X3D12  | 1E <sup>0</sup>                                                                                    | I/O               | IO, PD     |
| X3D13  | 1F <sup>0</sup>                                                                                    | I/0               | IO, PD     |
| X3D14  | 4C <sup>0</sup> 8B <sup>0</sup> 16A <sup>8</sup> 32A                                               | <sup>28</sup> I/O | IO, PD     |
| X3D15  | 4C <sup>1</sup> 8B <sup>1</sup> 16A <sup>9</sup> 32A                                               | <sup>29</sup> I/O | IO, PD     |
| X3D20  | 4C <sup>2</sup> 8B <sup>6</sup> 16A <sup>14</sup> 32A                                              | <sup>30</sup> I/O | IO, PD     |
| X3D21  | 4C <sup>3</sup> 8B <sup>7</sup> 16A <sup>15</sup> 32A                                              | <sup>31</sup> I/O | IO, PD     |
| X3D23  | 1H <sup>0</sup>                                                                                    | I/O               | IO, PD     |
| X3D24  | 110                                                                                                | I/0               | IO, PD     |
| X3D25  | 1J <sup>0</sup>                                                                                    | I/O               | IO, PD     |
| X3D26  | 4E <sup>0</sup> 8C <sup>0</sup> 16B <sup>0</sup>                                                   | I/0               | IOT, PD    |
| X3D27  | 4E <sup>1</sup> 8C <sup>1</sup> 16B <sup>1</sup>                                                   | I/O               | IOT, PD    |
| X3D28  | 4F <sup>0</sup> 8C <sup>2</sup> 16B <sup>2</sup>                                                   | I/O               | IOT, PD    |
| X3D29  | 4F <sup>1</sup> 8C <sup>3</sup> 16B <sup>3</sup>                                                   | I/O               | IOT, PD    |
| X3D30  | 4F <sup>2</sup> 8C <sup>4</sup> 16B <sup>4</sup>                                                   | I/O               | IOT, PD    |
| X3D31  | 4F <sup>3</sup> 8C <sup>5</sup> 16B <sup>5</sup>                                                   | I/0               | IOT, PD    |

# 6 Product Overview

The XL224-1024-FB374 is a powerful device that consists of four xCORE Tiles, each comprising a flexible logical processing cores with tightly integrated I/O and on-chip memory.

### 6.1 Logical cores

Each tile has 6 active logical cores, which issue instructions down a shared fivestage pipeline. Instructions from the active cores are issued round-robin. If up to five logical cores are active, each core is allocated a fifth of the processing cycles. If more than five logical cores are active, each core is allocated at least 1/n cycles (for *n* cores). Figure 3 shows the guaranteed core performance depending on the number of cores used.

Figure 3: Logical core performance

| ire 3: | Speed | MIPS      | Frequency | Mi  | inimum | MIPS | oer cor | e (for <i>n</i> | core | 5) |  |
|--------|-------|-----------|-----------|-----|--------|------|---------|-----------------|------|----|--|
| core   | grade |           |           | 1   | 2      | 3    | 4       | 5               | 6    |    |  |
| ance   | 20    | 2000 MIPS | 500 MHz   | 100 | 100    | 100  | 100     | 100             | 83   |    |  |

There is no way that the performance of a logical core can be reduced below these predicted levels (unless *priority threads* are used: in this case the guaranteed minimum performance is computed based on the number of priority threads as defined in the architecture manual). 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 five 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.

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

### 6.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 XL224-1024-FB374, 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. xCORE-200 IO pins can be used as *open collector* outputs, where signals are driven low if a zero is output, but left high impedance if a one is output. This option is set on a per-port basis.

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.

## 6.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 frequency of 100MHz; the remaining clock blocks can be set to run at different frequencies.

-XM()S



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. xCORE-200 clock blocks optionally divide the clock input from a 1-bit port.

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 xCORE Tile reference clock.

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

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



The JTAG chain structure is illustrated in Figure 14. 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 15.

| Figure 15    | Bit31   | Bit31 Device Identification Register |         |         |         |         |                    |       |   |  |
|--------------|---------|--------------------------------------|---------|---------|---------|---------|--------------------|-------|---|--|
| rigure 15.   | Version |                                      | Part N  | umber   |         | Man     | ufacturer Identity | /     | 1 |  |
| IDCODE       | 0 0 0 0 | 0 0 0 0                              | 0 0 0 0 | 0 0 0 0 | 0 1 1 0 | 0 1 1 0 | 0 0 1 1            | 0 0 1 | 1 |  |
| Teturn value | 0       | 0                                    | 0       | 0       | 6       | 6       | 3                  | 3     |   |  |

-XM()S

The JTAG usercode register can be read by using the USERCODE instruction. Its contents are specified in Figure 16. The OTP User ID field is read from bits [22:31] of the security register on xCORE Tile 0, *see* §9.1 (all zero on unprogrammed devices).

Figure 16: USERCODE return value

|   | Bit | 31              |   |   |      |     |    |   |   |   |   |     |      | ι | Jser | code | Reg | giste | r |   |   |       |      |       |      |   |   |   |   |   | E | lit0 |
|---|-----|-----------------|---|---|------|-----|----|---|---|---|---|-----|------|---|------|------|-----|-------|---|---|---|-------|------|-------|------|---|---|---|---|---|---|------|
| - |     |                 |   | 0 | TP U | ser | ID |   |   |   |   | Unı | ised |   |      |      |     |       |   |   |   | Silio | on I | Revis | sion |   |   |   |   |   |   |      |
| - | 0   | 0               | 0 | 0 | 0    | 0   | 0  | 0 | 0 | 0 | 0 | 0   | 0    | 0 | 1    | 0    | 1   | 0     | 0 | 0 | 0 | 0     | 0    | 0     | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0    |
|   |     | 0 0 0 2 8 0 0 0 |   |   |      |     |    |   |   |   |   |     |      |   |      |      |     |       |   |   |   |       |      |       |      |   |   |   |   |   |   |      |

# 11 Board Integration

The device has the following power supply pins:

- VDD pins for the xCORE Tile, including USB\_VDD and USB\_2\_VDD pins that power the USB PHY
- VDDIO pins for the I/O lines
- PLL\_AVDD pins for the PLL
- ▶ OTP\_VCC pins for the OTP
- ▶ USB\_VDD33 and USB\_2\_VDD33 pins for the analogue supply to the USB-PHY

Several pins of each type are provided to minimize the effect of inductance within the package, all of which must be connected. The power supplies must be brought up monotonically and input voltages must not exceed specification at any time.

The VDD supply must ramp from 0V to its final value within  $10 \, \text{ms}$  to ensure correct startup.

The VDDIO and OTP\_VCC supply must ramp to its final value before VDD reaches 0.4 V.

The PLL\_AVDD supply should be separated from the other noisier supplies on the board. The PLL requires a very clean power supply, and a low pass filter (for example, a  $2.2 \Omega$  resistor and 100 nF multi-layer ceramic capacitor) is recommended on this pin.

The following ground pins are provided:

- PLL\_AGND for PLL\_AVDD
- GND for all other supplies

All ground pins must be connected directly to the board ground.

The VDD and VDDIO supplies should be decoupled close to the chip by several 100 nF low inductance multi-layer ceramic capacitors between the supplies and GND (for example, 100nF 0402 for every other supply pin). The ground side of the decoupling capacitors should have as short a path back to the GND pins as



23

# 12 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                            | 2.30  | 3.30 | 3.60  | V     |       |
| VDDIOT 3v3 | I/O supply voltage                            | 3.135 | 3.30 | 3.465 | V     |       |
| VDDIOT 2v5 | I/O supply voltage                            | 2.375 | 2.50 | 2.625 | V     |       |
| USB_VDD    | USB tile DC supply voltage                    | 0.95  | 1.00 | 1.05  | V     |       |
| VDD33      | Peripheral supply                             | 3.135 | 3.30 | 3.465 | V     |       |
| PLL_AVDD   | PLL analog supply                             | 0.95  | 1.00 | 1.05  | V     |       |
| CI         | xCORE Tile I/O load<br>capacitance            |       |      | 25    | pF    |       |
| Ta         | 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    |       |

## 12.1 Operating Conditions

Figure 17: Operating conditions

## 12.2 DC Characteristics, VDDIO=3V3

| Symbol | Parameter                                | MIN   | TYP | MAX  | UNITS | Notes |
|--------|------------------------------------------|-------|-----|------|-------|-------|
| V(IH)  | Input high voltage                       | 2.00  |     | 3.60 | V     | А     |
| V(IL)  | Input low voltage                        | -0.30 |     | 0.70 | V     | А     |
| V(OH)  | Output high voltage                      | 2.20  |     |      | V     | B, C  |
| V(OL)  | Output low voltage                       |       |     | 0.40 | V     | B, C  |
| I(PU)  | Internal pull-up current (Vin=0V)        | -100  |     |      | μA    | D     |
| I(PD)  | Internal pull-down current<br>(Vin=3.3V) |       |     | 100  | μA    | D     |
| I(LC)  | Input leakage current                    | -10   |     | 10   | μA    |       |

Figure 18: DC characteristics

A All pins except power supply pins.

B Pins X1D40, X1D41, X1D42, X1D43, X1D26, X1D27, X3D40, X3D41, X3D42, X3D43, X3D26, and X3D27 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. In order to pull the pin to the opposite state, a 4K7 resistor is recommended to overome the internal pull current.



## 12.5 Power Consumption

| Symbol     | Parameter              | MIN | ТҮР  | MAX  | UNITS   | Notes      |
|------------|------------------------|-----|------|------|---------|------------|
| I(DDCQ)    | Quiescent VDD current  |     | 90   |      | mA      | А, В, С    |
| PD         | Tile power dissipation |     | 325  |      | µW/MIPS | A, D, E, F |
| IDD        | Active VDD current     |     | 1140 | 1400 | mA      | A, G       |
| I(ADDPLL)  | PLL_AVDD current       |     | 5    | 7    | mA      | Н          |
| I(VDD33)   | VDD33 current          |     | 53.4 |      | mA      | I          |
| I(USB_VDD) | USB_VDD current        |     | 16.6 |      | mA      | J          |

Figure 22: xCORE Tile currents

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.
- G Measurement conditions: VDD = 1.0 V, VDDIO = 3.3 V, 25 °C, 500 MHz, average device resource usage.
- H PLL\_AVDD = 1.0 V
- I HS mode transmitting while driving all 0's data (constant JKJK on DP/DM). Loading of 10 pF. Transfers do not include any interpacket delay.
- J HS receive mode; no traffic.



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,

| 1 | 2.6 | Clock |
|---|-----|-------|
|   |     |       |

Figure 23: Clock

| Symbol | Parameter                 | MIN  | TYP | MAX | UNITS | Notes |
|--------|---------------------------|------|-----|-----|-------|-------|
| f      | Frequency                 | 3.25 | 24  | 100 | MHz   |       |
| SR     | Slew rate                 | 0.10 |     |     | V/ns  |       |
| TJ(LT) | Long term jitter (pk-pk)  |      |     | 2   | %     | A     |
| f(MAX) | Processor clock frequency |      |     | 500 | MHz   | В     |

A Percentage of CLK period.

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

Further details can be found in the XS1-L Clock Frequency Control document,

### B.4 xCORE Tile boot status: 0x03

This read-only register describes the boot status of the xCORE tile.

| Bits  | Perm | Init | Description                                               |  |
|-------|------|------|-----------------------------------------------------------|--|
| 31:24 | RO   | -    | Reserved                                                  |  |
| 23:16 | RO   |      | Processor number.                                         |  |
| 15:9  | RO   | -    | Reserved                                                  |  |
| 8     | RO   |      | Overwrite BOOT_MODE.                                      |  |
| 7:6   | RO   | -    | Reserved                                                  |  |
| 5     | RO   |      | Indicates if core1 has been powered off                   |  |
| 4     | RO   |      | Cause the ROM to not poll the OTP for correct read levels |  |
| 3     | RO   |      | Boot ROM boots from RAM                                   |  |
| 2     | RO   |      | Boot ROM boots from JTAG                                  |  |
| 1:0   | RO   |      | The boot PLL mode pin value.                              |  |

0x03: xCORE Tile boot status

## B.5 Security configuration: 0x05

Copy of the security register as read from OTP.

| Bits  | Perm | Init | Description                                                 |  |
|-------|------|------|-------------------------------------------------------------|--|
| 31    | RW   |      | Disables write permission on this register                  |  |
| 30:15 | RO   | -    | Reserved                                                    |  |
| 14    | RW   |      | Disable access to XCore's global debug                      |  |
| 13    | RO   | -    | Reserved                                                    |  |
| 12    | RW   |      | lock all OTP sectors                                        |  |
| 11:8  | RW   |      | lock bit for each OTP sector                                |  |
| 7     | RW   |      | Enable OTP reduanacy                                        |  |
| 6     | RO   | -    | Reserved                                                    |  |
| 5     | RW   |      | Override boot mode and read boot image from OTP             |  |
| 4     | RW   |      | Disable JTAG access to the PLL/BOOT configuration registers |  |
| 3:1   | RO   | -    | Reserved                                                    |  |
| 0     | RW   |      | Disable access to XCore's JTAG debug TAP                    |  |

**0x05:** Security configuration

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

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

| Bits  | Perm | Init | Description                                                                                              |  |
|-------|------|------|----------------------------------------------------------------------------------------------------------|--|
| 31:24 | RO   | -    | Reserved                                                                                                 |  |
| 23:16 | DRW  | 0    | A bit for each thread in the machine allowing the breakpoint to be enabled individually for each thread. |  |
| 15:2  | RO   | -    | Reserved                                                                                                 |  |
| 1     | DRW  | 0    | When 0 break when PC == IBREAK_ADDR. When 1 = break when PC != IBREAK_ADDR.                              |  |
| 0     | DRW  | 0    | When 1 the instruction breakpoint is enabled.                                                            |  |

0x40 .. 0x43: Instruction breakpoint control

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

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

**0x50 .. 0x53:** Data watchpoint address 1

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

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

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

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

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

-XMOS

XS2-L24A-1024-FB374

|                     | Bits  | Perm | Init | Description                                                                                              |
|---------------------|-------|------|------|----------------------------------------------------------------------------------------------------------|
|                     | 31:24 | RO   | -    | Reserved                                                                                                 |
|                     | 23:16 | DRW  | 0    | A bit for each thread in the machine allowing the breakpoint to be enabled individually for each thread. |
| 0x70 0x73:          | 15:3  | RO   | -    | Reserved                                                                                                 |
| Data<br>break point | 2     | DRW  | 0    | When 1 the breakpoints will be be triggered on loads.                                                    |
| control             | 1     | DRW  | 0    | Determines the break condition: $0 = A AND B$ , $1 = A OR B$ .                                           |
| register            | 0     | DRW  | 0    | When 1 the instruction breakpoint is enabled.                                                            |

B.26 Resources breakpoint mask: 0x80 .. 0x83

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

| 0x80 0x83: |      |      |      |             |
|------------|------|------|------|-------------|
| breakpoint | Bits | Perm | Init | Description |
| mask       | 31:0 | DRW  |      | Value.      |

### B.27 Resources breakpoint value: 0x90 .. 0x93

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

| 0x90 0x93: |      |      |      |             |
|------------|------|------|------|-------------|
| breakpoint | Bits | Perm | Init | Description |
| value      | 31:0 | DRW  |      | Value.      |

### B.28 Resources breakpoint control register: 0x9C .. 0x9F

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

-XMOS

42

0x41: PC of logical core 1

| Bits | Perm | Init | Description |
|------|------|------|-------------|
| 31:0 | CRO  |      | Value.      |

## C.11 PC of logical core 2: 0x42

Value of the PC of logical core 2.

0x42: PC of logical core 2

| Bits | Perm | Init | Description |
|------|------|------|-------------|
| 31:0 | CRO  |      | Value.      |

## C.12 PC of logical core 3: 0x43

Value of the PC of logical core 3.

| 0v43          |      |      |      |             |
|---------------|------|------|------|-------------|
| PC of logical | Bits | Perm | Init | Description |
| core 3        | 31:0 | CRO  |      | Value.      |

### C.13 PC of logical core 4: 0x44

Value of the PC of logical core 4.

**0x44** PC of logical core 4

| Jx44:<br>gical | Bits | Perm | Init | Description |
|----------------|------|------|------|-------------|
| ore 4          | 31:0 | CRO  |      | Value.      |

## C.14 PC of logical core 5: 0x45

Value of the PC of logical core 5.

**0x45:** PC of logical core 5

| Bits | Perm | Init | Description |
|------|------|------|-------------|
| 31:0 | CRO  |      | Value.      |

# **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,  $\rightarrow$  ...) 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                       |
| 0x09      | R    | System JTAG device ID register        |
| 0x0A      | R    | System USERCODE register              |
| 0x0C      | RW   | Directions 0-7                        |
| 0x0D      | RW   | Directions 8-15                       |
| 0x10      | RW   | DEBUG_N configuration, tile 0         |
| 0x11      | RW   | DEBUG_N configuration, tile 1         |
| 0x1F      | RO   | Debug source                          |
| 0x20 0x28 | RW   | Link status, direction, and network   |
| 0x40 0x47 | RO   | PLink status and network              |
| 0x80 0x88 | 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   | -    | Reserved                                          |
| 0x00      | 23:16 | RO   |      | Sampled values of BootCtl pins on Power On Reset. |
| Device    | 15:8  | RO   |      | SSwitch revision.                                 |
| ification | 7:0   | RO   |      | SSwitch version.                                  |

-XMOS<sup>®</sup>

identi

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

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

0x01: System switch description

| Bits  | Perm | Init | Description                          |
|-------|------|------|--------------------------------------|
| 31:24 | RO   | -    | Reserved                             |
| 23:16 | RO   |      | Number of SLinks on the SSwitch.     |
| 15:8  | RO   |      | Number of processors on the SSwitch. |
| 7:0   | RO   |      | Number of processors on the device.  |

### D.3 Switch configuration: 0x04

This register enables the setting of two security modes (that disable updates to the PLL or any other registers) and the header-mode.

| Bits | Perm | Init | Description                                                                         |
|------|------|------|-------------------------------------------------------------------------------------|
| 31   | RW   | 0    | 0 = SSCTL registers have write access. $1 = SSCTL$ registers can not be written to. |
| 30:9 | RO   | -    | Reserved                                                                            |
| 8    | RW   | 0    | 0 = PLL_CTL_REG has write access. 1 = PLL_CTL_REG can not be written to.            |
| 7:1  | RO   | -    | Reserved                                                                            |
| 0    | RW   | 0    | 0 = 2-byte headers, $1 = 1$ -byte headers (reset as 0).                             |

**0x04:** Switch configuration

## D.4 Switch node identifier: 0x05

This register contains the node identifier.

| 0x05        |
|-------------|
| Switch node |
| identifier  |

| <b>x05:</b><br>node | Bits  | Perm | Init | Description                 |
|---------------------|-------|------|------|-----------------------------|
|                     | 31:16 | RO   | -    | Reserved                    |
| tifier              | 15:0  | RW   | 0    | The unique ID of this node. |

## D.5 PLL settings: 0x06

An on-chip PLL multiplies the input clock up to a higher frequency clock, used to clock the I/O, processor, and switch, see Oscillator. Note: a write to this register will cause the tile to be reset.

| Bits | Perm | Init | Description                                                    |
|------|------|------|----------------------------------------------------------------|
| 31:5 | RO   | -    | Reserved                                                       |
| 4    | RW   |      | If set, external pin, is the source of last GlobalDebug event. |
| 3:2  | RO   | -    | Reserved                                                       |
| 1    | RW   |      | If set, XCore1 is the source of last GlobalDebug event.        |
| 0    | RW   |      | If set, XCore0 is the source of last GlobalDebug event.        |

**0x1F:** Debug source

## D.15 Link status, direction, and network: 0x20 .. 0x28

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

| Bits  | Perm | Init | Description                                                                                 |
|-------|------|------|---------------------------------------------------------------------------------------------|
| 31:26 | RO   | -    | Reserved                                                                                    |
| 25:24 | RO   |      | Identify the SRC_TARGET type 0 - SLink, 1 - PLink, 2 - SSCTL, 3 - Undefine.                 |
| 23:16 | RO   |      | When the link is in use, this is the destination link number to which all packets are sent. |
| 15:12 | RO   | -    | Reserved                                                                                    |
| 11:8  | RW   | 0    | The direction that this link operates in.                                                   |
| 7:6   | RO   | -    | Reserved                                                                                    |
| 5:4   | RW   | 0    | Determines the network to which this link belongs, reset as 0.                              |
| 3     | RO   | -    | Reserved                                                                                    |
| 2     | RO   |      | 1 when the current packet is considered junk and will be thrown away.                       |
| 1     | RO   |      | 1 when the dest side of the link is in use.                                                 |
| 0     | RO   |      | 1 when the source side of the link is in use.                                               |

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

## D.16 PLink status and network: 0x40 .. 0x47

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

## D.18 Static link configuration: 0xA0 .. 0xA7

These registers are used for static (ie, non-routed) links. When a link is made static, all traffic is forwarded to the designated channel end and no routing is attempted. The registers control links C, D, A, B, G, H, E, and F in that order.

| Bits | Perm | Init | Description                                                                                     |
|------|------|------|-------------------------------------------------------------------------------------------------|
| 31   | RW   | 0    | Enable static forwarding.                                                                       |
| 30:9 | RO   | -    | Reserved                                                                                        |
| 8    | RW   | 0    | The destination processor on this node that packets received in static mode are forwarded to.   |
| 7:5  | RO   | -    | Reserved                                                                                        |
| 4:0  | RW   | 0    | The destination channel end on this node that packets received in static mode are forwarded to. |

**0xA0 .. 0xA7:** Static link configuration



# J Revision History

| Date       | Description                                                                                      |
|------------|--------------------------------------------------------------------------------------------------|
| 2015-03-20 | Preliminary release                                                                              |
| 2015-04-14 | Added RST to pins to be pulled hard, and removed reference to TCK from Errata                    |
|            | Removed TRST_N references in packages that have no TRST_N                                        |
| 2015-05-06 | Removed references to DEBUG_N                                                                    |
| 2015-07-09 | Updated electrical characteristics - Section 12                                                  |
| 2015-08-27 | Updated part marking and product code - Section 14                                               |
| 2015-11-23 | Updated status of X2D04, X2D05, X2D06, X2D07 during boot - Section 8                             |
|            | Updated Schematics Design Checklist: GPIO for X2D04, X2D05, X2D06, X2D07 during boot - Section F |
| 2015-12-18 | Clarified connectivity of internal and external xCONNECT links - Sections 3 and 4                |
|            | Made pin names canonical - Sections 3 and 4                                                      |
|            | Updated JTAG diagram - Section 10                                                                |
|            | Removed references to 400MHz parts - Section 12                                                  |
| 2016-01-05 | Updated signal tables to use VDDIO - Section 4                                                   |
|            | Updated IDD value - Section 12                                                                   |
|            | Updated land pattern description - Section 11.1                                                  |
| 2016-04-20 | Typical internal pull-up and pull down current diagrams added - Section 12                       |

XMOS®

Copyright © 2016, All Rights Reserved.

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