

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

| Details                    |                                                                 |
|----------------------------|-----------------------------------------------------------------|
| Product Status             | Obsolete                                                        |
| Core Processor             | XCore                                                           |
| Core Size                  | 32-Bit 24-Core                                                  |
| Speed                      | 4000MIPS                                                        |
| Connectivity               | -                                                               |
| Peripherals                |                                                                 |
| Number of I/O              | 176                                                             |
| Program Memory Size        | 2MB (2M x 8)                                                    |
| Program Memory Type        | FLASH                                                           |
| EEPROM Size                | -                                                               |
| RAM Size                   | 1M x 8                                                          |
| Voltage - Supply (Vcc/Vdd) | 0.95V ~ 3.6V                                                    |
| Data Converters            | -                                                               |
| Oscillator Type            | External                                                        |
| Operating Temperature      | 0°C ~ 70°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/xlf232-1024-fb374-c40 |

Email: info@E-XFL.COM

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

## **Table of Contents**

| 1   | xCORE Multicore Microcontrollers          |
|-----|-------------------------------------------|
| 2   | XLF232-1024-FB374 Features                |
| 3   | Pin Configuration                         |
| 4   | Signal Description                        |
| 5   | Example Application Diagram               |
| 6   | Product Overview                          |
| 7   | PLL                                       |
| 8   | Boot Procedure                            |
| 9   | Memory                                    |
| 10  | JTAG                                      |
| 11  | Board Integration                         |
| 12  | DC and Switching Characteristics          |
| 13  | Package Information                       |
| 14  | Ordering Information                      |
| App | endices                                   |
| A   | Configuration of the XLF232-1024-FB374 30 |
| В   | Processor Status Configuration            |
| С   | Tile Configuration                        |
| D   | Node Configuration                        |
| E   | JTAG, xSCOPE and Debugging                |
| F   | Schematics Design Check List              |
| G   | PCB Layout Design Check List              |
| Н   | Associated Design Documentation           |
| 1   | Related Documentation                     |
| J   | Revision History                          |

#### TO OUR VALUED CUSTOMERS

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

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

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

| Signal | Function                                      |                 |                 |                 |                   |                   | Туре     | Properties  |
|--------|-----------------------------------------------|-----------------|-----------------|-----------------|-------------------|-------------------|----------|-------------|
| X1D17  | X <sub>0</sub> L3 <sup>0</sup>                |                 | 4D <sup>1</sup> | 8B <sup>3</sup> | 16A <sup>11</sup> |                   | 1/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/O      | IO, PD      |
| X1D20  |                                               |                 | 4C <sup>2</sup> | 8B <sup>6</sup> | 16A <sup>14</sup> | 32A <sup>30</sup> | I/O      | IO, PD      |
| X1D21  |                                               |                 | 4C <sup>3</sup> | 8B <sup>7</sup> | 16A <sup>15</sup> | 32A <sup>31</sup> | I/O      | IO, PD      |
| X1D22  | X <sub>0</sub> L3 <sup>4</sup> <sub>out</sub> | 1G <sup>0</sup> |                 | -               | -                 | -                 | I/O      | IO, PD      |
| X1D23  | 0 - 001                                       | 1H <sup>0</sup> |                 |                 |                   |                   | 1/0      | IO, PD      |
| X1D24  |                                               | 110             |                 |                 |                   |                   | I/O      | IO, PD      |
| X1D25  |                                               | 1,0             |                 |                 |                   |                   | I/O      | IO, PD      |
| X1D26  |                                               | 5               | 4E <sup>0</sup> | 8C <sup>0</sup> | 16B <sup>0</sup>  |                   | 1/0      | IOT, PD     |
| X1D27  |                                               |                 | 4E <sup>1</sup> | 8C <sup>1</sup> | 16B <sup>1</sup>  |                   | I/O      | 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>  |                   | 1/0      | IOT, PD     |
| X1D31  |                                               |                 | 4F <sup>3</sup> | 8C <sup>5</sup> | 16B <sup>5</sup>  |                   | I/O      | 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>                | 1N <sup>0</sup> |                 | 8D <sup>1</sup> | 16B <sup>9</sup>  |                   | I/O      | IO, PD      |
| X1D38  | X <sub>0</sub> L3 <sup>3</sup>                | 100             |                 | 8D <sup>2</sup> | 16B <sup>10</sup> |                   | I/O      | IO, PD      |
| X1D39  | X <sub>0</sub> L3 <sup>2</sup> <sub>in</sub>  | 1P <sup>0</sup> |                 | 8D <sup>3</sup> | 16B <sup>11</sup> |                   | I/O      | IO, PD      |
| X1D40  | in                                            |                 |                 | 8D <sup>4</sup> | 16B <sup>12</sup> |                   | I/O      | IOT, PD     |
| X1D41  |                                               |                 |                 | 8D <sup>5</sup> | 16B <sup>13</sup> |                   | I/O      | IOT, PD     |
| X1D42  |                                               |                 |                 | 8D <sup>6</sup> | 16B <sup>14</sup> |                   | 1/0      | IOT, PD     |
| X1D43  |                                               |                 |                 | 8D <sup>7</sup> | 16B <sup>15</sup> |                   | 1/0      | IOT, PD     |
| X1D49  | X <sub>0</sub> L1 <sup>4</sup>                |                 |                 |                 |                   | 32A <sup>0</sup>  | 1/0      | 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>  | 1/0      | IO, PD      |
| X1D52  | X <sub>0</sub> L1 <sup>1</sup>                |                 |                 |                 |                   | 32A <sup>3</sup>  | 1/0      | IO, PD      |
| X1D53  | X <sub>0</sub> L1 <sup>0</sup>                |                 |                 |                 |                   | 32A <sup>4</sup>  | /<br>I/O | IO, PD      |
| X1D54  | X <sub>0</sub> L1 <sup>0</sup> <sub>out</sub> |                 |                 |                 |                   | 32A <sup>5</sup>  | I/O      | IO, PD      |
| X1D55  | X <sub>0</sub> L1 <sup>1</sup> <sub>out</sub> |                 |                 |                 |                   | 32A <sup>6</sup>  | 1/0      | IO, PD      |
| X1D56  | X <sub>0</sub> L1 <sup>2</sup> <sub>out</sub> |                 |                 |                 |                   | 32A <sup>7</sup>  | 1/0      | IO, PD      |
| X1D57  | X <sub>0</sub> L1 <sup>3</sup> <sub>out</sub> |                 |                 |                 |                   | 32A <sup>8</sup>  | 1/0      | IO, PD      |
| X1D58  | X <sub>0</sub> L1 <sup>4</sup> <sub>out</sub> |                 |                 |                 |                   | 32A <sup>9</sup>  | I/O      | 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> | 1/0      | IO, PD      |
| X1D64  | X <sub>0</sub> L2 <sup>1</sup>                |                 |                 |                 |                   | 32A <sup>13</sup> | I/O      | IO, PD      |
| X1D65  | X <sub>0</sub> L2 <sup>0</sup>                |                 |                 |                 |                   | 32A <sup>14</sup> | 1/0      | IO, PD      |
| X1D66  | X <sub>0</sub> L2 <sup>0</sup> <sub>out</sub> |                 |                 |                 |                   | 32A <sup>15</sup> | I/O      | IO, PD      |
|        | 00ui                                          |                 |                 |                 |                   |                   | ., -     | (continued) |

-XMOS<sup>®</sup>-

(continued)

XS2-LF32A-1024-FB374

(continued)

| X2D54 | X <sub>2</sub> L5 <sub>out</sub>               |                 |                 |                   | 32A <sup>3</sup>  | 1/0 | 10, PD  |
|-------|------------------------------------------------|-----------------|-----------------|-------------------|-------------------|-----|---------|
| X2D55 | X <sub>2</sub> L5 <sup>1</sup> <sub>out</sub>  |                 |                 |                   | 32A <sup>6</sup>  | I/0 | 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> <sub>in</sub>   |                 |                 |                   | 32A <sup>10</sup> | I/O | IO, PD  |
| X2D62 | X <sub>2</sub> L6 <sup>3</sup> <sub>in</sub>   |                 |                 |                   | 32A <sup>11</sup> | I/O | IO, PD  |
| X2D63 | X <sub>2</sub> L6 <sup>2</sup> <sub>in</sub>   |                 |                 |                   | 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> <sub>out</sub>  |                 |                 |                   | 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> 1A <sup>0</sup> |                 |                 |                   |                   | I/0 | IO, PD  |
| X3D01 | X <sub>2</sub> L7 <sup>1</sup> 1B <sup>0</sup> |                 |                 |                   |                   | 1/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> <sub>out</sub>  | 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> <sub>out</sub>  | 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> <sub>out</sub>  | 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> <sub>in</sub>   | 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/O | IOT, PD |
| X3D11 | 1D <sup>0</sup>                                |                 |                 |                   |                   | I/O | IOT, PD |
| X3D12 | 1 E <sup>0</sup>                               |                 |                 |                   |                   | I/O | IO, PD  |
| X3D13 | 1 F <sup>0</sup>                               |                 |                 |                   |                   | I/O | 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> | 8B1             | 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/O | 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/O | 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/O | IOT, PD |
|       |                                                |                 |                 |                   |                   |     |         |

XMOS<sup>®</sup>

Signal

X2D53

X2D54

Function

 $X_2L5_{in}^0$ 

 $X_2L5_{out}^0$ 

Туре

I/0

I/0

32A<sup>4</sup>

32A<sup>5</sup>

Properties

IO, PD

IO, PD

### XLF232-1024-FB374 Datasheet

| Signal | Function                                         | Туре | Properties |
|--------|--------------------------------------------------|------|------------|
| X3D32  | 4E <sup>2</sup> 8C <sup>6</sup> 16B <sup>6</sup> | I/0  | IOT, PD    |
| X3D33  | 4E <sup>3</sup> 8C <sup>7</sup> 16B <sup>7</sup> | I/0  | IOT, PD    |
| X3D40  | 8D <sup>4</sup> 16B <sup>12</sup>                | I/O  | IOT, PD    |
| X3D41  | 8D <sup>5</sup> 16B <sup>13</sup>                | I/0  | IOT, PD    |
| X3D42  | 8D <sup>6</sup> 16B <sup>14</sup>                | I/O  | IOT, PD    |
| X3D43  | 8D <sup>7</sup> 16B <sup>15</sup>                | I/0  | IOT, PD    |

|         | System pins (4)     |       |            |  |  |  |  |  |  |  |
|---------|---------------------|-------|------------|--|--|--|--|--|--|--|
| Signal  | Function            | Туре  | Properties |  |  |  |  |  |  |  |
| CLK     | PLL reference clock | Input | IO, PD, ST |  |  |  |  |  |  |  |
| DEBUG_N | Multi-chip debug    | I/O   | IO, PU     |  |  |  |  |  |  |  |
| MODE0   | Boot mode select    | Input | PU         |  |  |  |  |  |  |  |
| MODE1   | Boot mode select    | Input | PU         |  |  |  |  |  |  |  |



# 5 Example Application Diagram



Figure 2: Simplified Reference Schematic

▶ see Section 11 for details on the power supplies and PCB design



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

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

|              | Bit | 31  |      |   |   |   |   |   |   |   |    |      | De  | evice | Ide | ntifi | atio | n Re | egist | er |   |   |   |     |       |      |       |      |   |   | E | lit0 |
|--------------|-----|-----|------|---|---|---|---|---|---|---|----|------|-----|-------|-----|-------|------|------|-------|----|---|---|---|-----|-------|------|-------|------|---|---|---|------|
| Figure 12:   |     | Ver | sion |   |   |   |   |   |   |   | Pa | rt N | umb | er    |     |       |      |      |       |    |   |   |   | Man | ufact | ture | r Ide | ntit | y |   |   | 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    |
| return value |     | (   | 0    |   |   | ( | D |   |   | C | )  |      |     | (     | )   |       |      | e    | 5     |    |   | 6 | 5 |     |       |      | 3     |      |   | Э | 3 |      |

-XM()S





## 12.3 ESD Stress Voltage

Figure 17 ESD stress voltage

| 17: | Symbol | Parameter            | MIN   | ТҮР | MAX  | UNITS | Notes |
|-----|--------|----------------------|-------|-----|------|-------|-------|
| ess | HBM    | Human body model     | -2.00 |     | 2.00 | KV    |       |
| age | CDM    | Charged Device Model | -500  |     | 500  | V     |       |

#### 12.4 Reset Timing

|              | Symbol       | Parameters                                | MIN | ТҮР    | MAX | UNITS | Notes |
|--------------|--------------|-------------------------------------------|-----|--------|-----|-------|-------|
| Figure 18:   | T(RST)       | Reset pulse width                         | 5   |        |     | μs    |       |
| Reset timing | T(INIT)      | Initialization time                       |     |        | 150 | μs    | А     |
|              | A Chouse the | time taken to start beating ofter DCT N b |     | أمنعام |     |       |       |

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

## 12.5 Power Consumption

|            | Symbol    | Parameter              | MIN | ТҮР  | MAX  | UNITS   | Notes      |
|------------|-----------|------------------------|-----|------|------|---------|------------|
|            | I(DDCQ)   | Quiescent VDD current  |     | 45   |      | mA      | A, B, C    |
| Figure 19: | PD        | Tile power dissipation |     | 325  |      | µW/MIPS | A, D, E, F |
| xCORE Tile | IDD       | Active VDD current     |     | 1140 | 1400 | mA      | A, G       |
| currents   | I(ADDPLL) | PLL_AVDD current       |     | 5    | 7    | mA      | Н          |

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



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



## B.6 Ring Oscillator Control: 0x06

There are four free-running oscillators that clock four counters. The oscillators can be started and stopped using this register. The counters should only be read when the ring oscillator has been stopped for at least 10 core clock cycles (this can be achieved by inserting two nop instructions between the SETPS and GETPS). The counter values can be read using four subsequent registers. The ring oscillators are asynchronous to the xCORE tile clock and can be used as a source of random bits.

**0x06:** Ring Oscillator Control

| _       | Bits | Perm | Init | Description                        |
|---------|------|------|------|------------------------------------|
| 6:      | 31:2 | RO   | -    | Reserved                           |
| g<br>or | 1    | RW   | 0    | Core ring oscillator enable.       |
| ol      | 0    | RW   | 0    | Peripheral ring oscillator enable. |

### B.7 Ring Oscillator Value: 0x07

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

**0x07** Ring Oscillator Value

| : <b>07:</b><br>ing | Bits  | Perm | Init | Description                   |
|---------------------|-------|------|------|-------------------------------|
| tor                 | 31:16 | RO   | -    | Reserved                      |
| lue                 | 15:0  | RO   | 0    | Ring oscillator Counter data. |

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

| 3:<br>a | Bits  | Perm | Init | Description                   |  |
|---------|-------|------|------|-------------------------------|--|
| g<br>or | 31:16 | RO   | -    | Reserved                      |  |
| e       | 15:0  | RO   | 0    | 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.

-XMOS<sup>®</sup>

| Bits  | Perm | Init | Description                                                                        |  |
|-------|------|------|------------------------------------------------------------------------------------|--|
| 31:11 | RO   | -    | Reserved                                                                           |  |
| 10    | DRW  |      | Address space indentifier                                                          |  |
| 9     | DRW  |      | Determines the issue mode (DI bit) upon Kernel Entry after Exception or Interrupt. |  |
| 8     | RO   |      | Determines the issue mode (DI bit).                                                |  |
| 7     | DRW  |      | When 1 the thread is in fast mode and will continually issue.                      |  |
| 6     | DRW  |      | When 1 the thread is paused waiting for events, a lock or another resource.        |  |
| 5     | RO   | -    | Reserved                                                                           |  |
| 4     | DRW  |      | 1 when in kernel mode.                                                             |  |
| 3     | DRW  |      | 1 when in an interrupt handler.                                                    |  |
| 2     | DRW  |      | 1 when in an event enabling sequence.                                              |  |
| 1     | DRW  |      | When 1 interrupts are enabled for the thread.                                      |  |
| 0     | DRW  |      | When 1 events are enabled for the thread.                                          |  |

**0x10:** Debug SSR

## B.13 Debug SPC: 0x11

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

| 0x11:     | Bits | Perm | Init | Description |
|-----------|------|------|------|-------------|
| Debug SPC | 31:0 | DRW  |      | Value.      |

#### B.14 Debug SSP: 0x12

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

| 0x12:     | Bits | Perm | Init | Description |
|-----------|------|------|------|-------------|
| Debug SSP | 31:0 | DRW  |      | Value.      |

## B.15 DGETREG operand 1: 0x13

The resource ID of the logical core whose state is to be read.

-XMOS



| <b>0x13:</b><br>DGETREG | Bits | Perm | Init | Description              |
|-------------------------|------|------|------|--------------------------|
|                         | 31:8 | RO   | -    | Reserved                 |
| operand 1               | 7:0  | DRW  |      | Thread number to be read |

## B.16 DGETREG operand 2: 0x14

Register number to be read by DGETREG

0x14: DGETREG operand 2

| Bits | Perm | Init | Description                |  |
|------|------|------|----------------------------|--|
| 31:5 | RO   | -    | Reserved                   |  |
| 4:0  | DRW  |      | Register number to be read |  |

### **B.17** Debug interrupt type: 0x15

Register that specifies what activated the debug interrupt.

| Bits  | Perm | Init | Description                                                                                                                                                                                                                          |  |
|-------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:18 | RO   | -    | Reserved                                                                                                                                                                                                                             |  |
| 17:16 | DRW  |      | Number of the hardware breakpoint/watchpoint which caused<br>the interrupt (always 0 for =HOST= and =DCALL=). If multiple<br>breakpoints/watchpoints trigger at once, the lowest number is<br>taken.                                 |  |
| 15:8  | DRW  |      | Number of thread which caused the debug interrupt (always 0 in the case of =HOST=).                                                                                                                                                  |  |
| 7:3   | RO   | -    | Reserved                                                                                                                                                                                                                             |  |
| 2:0   | DRW  | 0    | Reserved<br>Indicates the cause of the debug interrupt<br>1: Host initiated a debug interrupt through JTAG<br>2: Program executed a DCALL instruction<br>3: Instruction breakpoint<br>4: Data watch point<br>5: Resource watch point |  |

0x15: Debug interrupt type

## B.18 Debug interrupt data: 0x16

On a data watchpoint, this register contains the effective address of the memory operation that triggered the debugger. On a resource watchpoint, it countains the resource identifier.

-XMOS-

#### 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 whe<br>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>hpoint | Bits | Perm | Init | Description |
|----------------|------|------|------|-------------|
| ress 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>hpoint<br>dress 2 | Bits | Perm | Init | Description |
|---------------------------|------|------|------|-------------|
|                           | 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-LF32A-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>breakpoint<br>control | 2     | DRW  | 0    | When 1 the breakpoints will be be triggered on loads.                                                    |
|                               | 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:<br>Resources |      |      |      |             |
|-------------------------|------|------|------|-------------|
| 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.

| <b>0x90 0x93:</b><br>Resources |      |      |      |             |
|--------------------------------|------|------|------|-------------|
| 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

41

XS2-LF32A-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. |
| 0x9C 0x9F:<br>Resources | 15:2  | RO   | -    | Reserved                                                                                                 |
| breakpoint<br>control   | 1     | DRW  | 0    | When 0 break when condition A is met. When 1 = break when condition B is met.                            |
| register                | 0     | DRW  | 0    | When 1 the instruction breakpoint is enabled.                                                            |



0x04: Control PSwitch permissions to debug registers

| Bits | Perm | Init | Description                                                                                                     |
|------|------|------|-----------------------------------------------------------------------------------------------------------------|
| 31   | CRW  | 0    | When 1 the PSwitch is restricted to RO access to all CRW registers from SSwitch, XCore(PS_DBG_Scratch) and JTAG |
| 30:1 | RO   | -    | Reserved                                                                                                        |
| 0    | CRW  | 0    | When 1 the PSwitch is restricted to RO access to all CRW registers from SSwitch                                 |

## C.5 Cause debug interrupts: 0x05

This register can be used to raise a debug interrupt in this xCORE tile.

**0x05:** Cause debug interrupts

|   | Bits | Perm | Init | Description                                 |
|---|------|------|------|---------------------------------------------|
|   | 31:2 | RO   | -    | Reserved                                    |
|   | 1    | CRW  | 0    | 1 when the processor is in debug mode.      |
| I | 0    | CRW  | 0    | Request a debug interrupt on the processor. |

## C.6 xCORE Tile clock divider: 0x06

This register contains the value used to divide the PLL clock to create the xCORE tile clock. The divider is enabled under control of the tile control register

0x06: xCORE Tile clock divider

| Bits  | Perm | Init | Description                                                   |
|-------|------|------|---------------------------------------------------------------|
| 31    | CRW  | 0    | Clock disable. Writing '1' will remove the clock to the tile. |
| 30:16 | RO   | -    | Reserved                                                      |
| 15:0  | CRW  | 0    | Clock divider.                                                |

## C.7 Security configuration: 0x07

Copy of the security register as read from OTP.

-XMOS

**0x62:** SR of logical core 2

| 3 <b>2:</b><br>al | Bits | Perm | Init | Description |
|-------------------|------|------|------|-------------|
| 2                 | 31:0 | CRO  |      | Value.      |

## C.20 SR of logical core 3: 0x63

Value of the SR of logical core 3

0x63: SR of logical core 3

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

## C.21 SR of logical core 4: 0x64

Value of the SR of logical core 4

| 0x64:         |      |      |      |             |
|---------------|------|------|------|-------------|
| SR of logical | Bits | Perm | Init | Description |
| core 4        | 31:0 | CRO  |      | Value.      |

### C.22 SR of logical core 5: 0x65

Value of the SR of logical core 5

**0x65** SR of logical core 5

| <b>x65:</b><br>gical | Bits | Perm | Init | Description |
|----------------------|------|------|------|-------------|
| ore 5                | 31:0 | CRO  |      | Value.      |

## C.23 SR of logical core 6: 0x66

Value of the SR of logical core 6

**0x66:** SR of logical core 6

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

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

-XMOS<sup>-</sup>

# E JTAG, xSCOPE and Debugging

If you intend to design a board that can be used with the XMOS toolchain and xTAG debugger, you will need an xSYS header on your board. Figure 30 shows a decision diagram which explains what type of xSYS connectivity you need. The three subsections below explain the options in detail.



E.1 No xSYS header

The use of an xSYS header is optional, and may not be required for volume production designs. However, the XMOS toolchain expects the xSYS header; if you do not have an xSYS header then you must provide your own method for writing to flash/OTP and for debugging.

#### E.2 JTAG-only xSYS header

The xSYS header connects to an xTAG debugger, which has a 20-pin 0.1" female IDC header. The design will hence need a male IDC header. We advise to use a boxed header to guard against incorrect plug-ins. If you use a 90 degree angled header, make sure that pins 2, 4, 6, ..., 20 are along the edge of the PCB.

Connect pins 4, 8, 12, 16, 20 of the xSYS header to ground, and then connect:

- ▶ TDI to pin 5 of the xSYS header
- TMS to pin 7 of the xSYS header
- TCK to pin 9 of the xSYS header
- DEBUG\_N to pin 11 of the xSYS header

# F Schematics Design Check List

✓ This section is a checklist for use by schematics designers using the XLF232-1024-FB374. Each of the following sections contains items to check for each design.

#### F.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 11).
- The VDD (core) supply ramps monotonically (rises constantly) from 0V to its final value (0.95V 1.05V) within 10ms (Section 11).
- The VDD (core) supply is capable of supplying 1400 mA (Section 11 and Figure 15).
- PLL\_AVDD is filtered with a low pass filter, for example an RC filter, see Section 11

#### F.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 11).
- A bulk decoupling capacitor of at least 10uF is placed on each supply (Section 11).

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

#### F.4 Clock

- The CLK input pin is supplied with a clock with monotonic rising edges and low jitter.
- Pins MODE0 and MODE1 are set to the correct value for the chosen oscillator frequency. The MODE settings are shown in the Oscillator section, Section 7. If you have a choice between two values, choose the value with the highest multiplier ratio since that will boot faster.

#### F.5 Boot

- $\square$  X0D01 has a 1K pull-up to VDDIO (Section 8).
- The device is kept in reset for at least 1 ms after VDDIO has reached its minimum level (Section 8).

### F.6 JTAG, XScope, and debugging

- $\Box$  You have decided as to whether you need an XSYS header or not (Section E)
- $\Box$  If you have not included an XSYS header, you have devised a method to program the SPI-flash or OTP (Section E).

#### F.7 GPIO

- $\Box$  You have not mapped both inputs and outputs to the same multi-bit port.
- Pins X0D04, X0D05, X0D06, and X0D07 are output only and are, during and after reset, pulled low or not connected (Section 8)
- Pins X2D04, X2D05, X2D06 and X2D07 are output only and during and after reset, X2D06 is pulled high and X2D04, X2D05, and X2D07 are pulled low (Section 8)

#### F.8 Multi device designs

Skip this section if your design only includes a single XMOS device.

 $\Box$  One device is connected to a QSPI or SPI flash for booting.

-XM()S

Devices that boot from link have, for example, X0D06 pulled high and have link XL0 connected to a device to boot from (Section 8).