



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 12-Core                                                |
| Speed                      | 2000MIPS                                                      |
| Connectivity               | USB                                                           |
| Peripherals                | -                                                             |
| Number of I/O              | 104                                                           |
| Program Memory Size        | -                                                             |
| Program Memory Type        | ROMIess                                                       |
| EEPROM Size                | -                                                             |
| RAM Size                   | 512K 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             | 236-LFBGA                                                     |
| Supplier Device Package    | 236-FBGA (10x10)                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/xmos/xu212-512-fb236-c20 |

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: XU212-512-FB236 block diagram

Key features of the XU212-512-FB236 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 on events generated by hardware resources such as the I/O pins, communication channels and timers. Once triggered, a core runs independently and concurrently to other cores, until it pauses to wait for more events. Section 6.2
- Channels and channel ends Tasks running on logical cores communicate using channels formed between two channel ends. Data can be passed synchronously or asynchronously between the channel ends assigned to the communicating tasks. Section 6.5
- xCONNECT Switch and Links Between tiles, channel communications are implemented over a high performance network of xCONNECT Links and routed through a hardware xCONNECT Switch. Section 6.6

-XM()S

- ▶ **Ports** The I/O pins are connected to the processing cores by Hardware Response ports. The port logic can drive its pins high and low, or it can sample the value on its pins optionally waiting for a particular condition. Section 6.3
- Clock blocks xCORE devices include a set of programmable clock blocks that can be used to govern the rate at which ports execute. Section 6.4
- Memory Each xCORE Tile integrates a bank of SRAM for instructions and data, and a block of one-time programmable (OTP) memory that can be configured for system wide security features. Section 9
- PLL The PLL is used to create a high-speed processor clock given a low speed external oscillator. Section 7
- ▶ **USB** The USB PHY provides High-Speed and Full-Speed, device, host, and on-thego functionality. Data is communicated through ports on the digital node. A library is provided to implement USB device functionality. Section 10
- JTAG The JTAG module can be used for loading programs, boundary scan testing, in-circuit source-level debugging and programming the OTP memory. Section 11

#### 1.1 Software

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

#### 1.2 xTIMEcomposer Studio

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

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



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.



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

#### 8.2 Boot from SPI master

If set to boot from SPI master, the processor enables the four pins specified in Figure 11, and drives the SPI clock at 2.5 MHz (assuming a 400 MHz core clock). A READ command is issued with a 24-bit address 0x000000. The clock polarity and phase are 0 / 0.

Figure 11: SPI master pins

| Pin   | Signal | Description                |
|-------|--------|----------------------------|
| X0D00 | MISO   | Master In Slave Out (Data) |
| X0D01 | SS     | Slave Select               |
| X0D10 | SCLK   | Clock                      |
| X0D11 | MOSI   | Master Out Slave In (Data) |
|       |        |                            |

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

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

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

#### 8.3 Boot from SPI slave

If set to boot from SPI slave, the processor enables the three pins specified in Figure 12 and expects a boot image to be clocked in. The supported clock polarity and phase are 0/0 and 1/1.

|                | Pin   | Signal | Description                |
|----------------|-------|--------|----------------------------|
|                | X0D00 | SS     | Slave Select               |
| Figure 12:     | X0D10 | SCLK   | Clock                      |
| SPI slave pins | X0D11 | MOSI   | Master Out Slave In (Data) |

The xCORE Tile expects each byte to be transferred with the *least-significant bit first*. The pins used for SPI boot are hardcoded in the boot ROM and cannot be changed. If required, an SPI boot program can be burned into OTP that uses different pins.

#### 8.4 Boot from xConnect Link

If set to boot from an xConnect Link, the processor enables its link(s) around 2 us after the boot process starts. Enabling the Link switches off the pull-down resistors on the link, drives all the TX wires low (the initial state for the Link), and monitors the RX pins for boot-traffic; they must be low at this stage. If the internal pull-down is too weak to drain any residual charge, external pull-downs of 10K may be required on those pins.

18



#### 12.2.1 General routing and placement guidelines

The following guidelines will help to avoid signal quality and EMI problems on high speed USB designs. They relate to a four-layer (Signal, GND, Power, Signal) PCB.



For best results, most of the routing should be done on the top layer (assuming the USB connector and XS2-U12A-512-FB236 are on the top layer) closest to GND. Reference planes should be below the transmission lines in order to maintain control of the trace impedance.

We recommend that the high-speed clock and high-speed USB differential pairs are routed first before any other routing. When routing high speed USB signals, the following guidelines should be followed:

- ▶ High speed differential pairs should be routed together.
- ▶ High-speed USB signal pair traces should be trace-length matched. Maximum trace-length mismatch should be no greater than 4mm.
- Ensure that high speed signals (clocks, USB differential pairs) are routed as far away from off-board connectors as possible.

25



## 13.3 ESD Stress Voltage

Figure 24 ESD stres voltag

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

# 13.4 Reset Timing

| Figure 25:<br>Reset timing | Symbol       | Parameters                                | MIN | TYP  | MAX | UNITS | Notes |
|----------------------------|--------------|-------------------------------------------|-----|------|-----|-------|-------|
|                            | T(RST)       | Reset pulse width                         | 5   |      |     | μs    |       |
|                            | T(INIT)      | Initialization time                       |     |      | 150 | μs    | А     |
|                            | A Showic the | time taken to start booting after PST N b |     | high |     |       |       |

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

#### 13.5 Power Consumption

| Symbol     | Parameter              | MIN | TYP  | MAX | UNITS   | Notes      |
|------------|------------------------|-----|------|-----|---------|------------|
| I(DDCQ)    | Quiescent VDD current  |     | 45   |     | mA      | A, B, C    |
| PD         | Tile power dissipation |     | 325  |     | µW/MIPS | A, D, E, F |
| IDD        | Active VDD current     |     | 570  | 700 | mA      | A, G       |
| I(ADDPLL)  | PLL_AVDD current       |     | 5    | 7   | mA      | Н          |
| I(VDD33)   | VDD33 current          |     | 26.7 |     | mA      | I          |
| I(USB_VDD) | USB_VDD current        |     | 8.27 |     | mA      | J          |

Figure 26: 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-U Power Consumption document,

| 1 | 3.6 | Clock |
|---|-----|-------|
|   |     |       |

Figure 27: 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   | %     | А     |
| 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-U Clock Frequency Control document,

# Appendices

# A Configuration of the XU212-512-FB236

The device is configured through banks of registers, as shown in Figure 33.



Figure 33: Registers

> The following communication sequences specify how to access those registers. Any messages transmitted contain the most significant 24 bits of the channel-end to which a response is to be sent. This comprises the node-identifier and the channel number within the node. if no response is required on a write operation, supply 24-bits with the last 8-bits set, which suppresses the reply message. Any multi-byte data is sent most significant byte first.

## A.1 Accessing a processor status register

The processor status registers are accessed directly from the processor instruction set. The instructions GETPS and SETPS read and write a word. The register number should be translated into a processor-status resource identifier by shifting the register number left 8 places, and ORing it with 0x0B. Alternatively, the functions getps(reg) and setps(reg,value) can be used from XC.

# A.2 Accessing an xCORE Tile configuration register

xCORE Tile configuration registers can be accessed through the interconnect using the functions write\_tile\_config\_reg(tileref, ...) and read\_tile\_config\_reg(tile  $\rightarrow$  ref, ...), where tileref is the name of the xCORE Tile, e.g. tile[1]. These functions implement the protocols described below.

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

A write message comprises the following:

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

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

A read message comprises the following:

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

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

#### A.3 Accessing node configuration

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

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

A write message comprises the following:

 control-token
 24-bit response
 16-bit
 32-bit
 control-token

 192
 channel-end identifier
 register number
 data
 1

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

A read message comprises the following:

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

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

## A.4 Accessing a register of an analogue peripheral

Peripheral registers can be accessed through the interconnect using the functions write\_periph\_32(device, peripheral, ...), read\_periph\_32(device, peripheral, ...)  $\leftrightarrow$ , write\_periph\_8(device, peripheral, ...), and read\_periph\_8(device, peripheral  $\leftrightarrow$ , ...); where device is the name of the analogue device, and peripheral is the number of the peripheral. These functions implement the protocols described below.

A channel-end should be allocated to communicate with the configuration registers. The destination of the channel-end should be set to 0xnnnnpp02 where nnnn is the node-identifier and pp is the peripheral identifier.



| Bits  | Perm | Init | Description                                                                                                                                                                                                                           |
|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RO   | -    | Reserved                                                                                                                                                                                                                              |
| 25:18 | RW   | 0    | RGMII TX data delay value (in PLL output cycle increments)                                                                                                                                                                            |
| 17:9  | RW   | 0    | RGMII TX clock divider value. TX clk rises when counter (clocked<br>by PLL output) reaches this value and falls when counter reaches<br>(value»1). Value programmed into this field should be actual<br>divide value required minus 1 |
| 8     | RW   | 0    | Enable RGMII interface periph ports                                                                                                                                                                                                   |
| 7:6   | RO   | -    | Reserved                                                                                                                                                                                                                              |
| 5     | RW   | 0    | Select the dynamic mode (1) for the clock divider when the clock divider is enabled. In dynamic mode the clock divider is only activated when all active threads are paused. In static mode the clock divider is always enabled.      |
| 4     | RW   | 0    | Enable the clock divider. This divides the output of the PLL to facilitate one of the low power modes.                                                                                                                                |
| 3     | RO   | -    | Reserved                                                                                                                                                                                                                              |
| 2     | RW   |      | Select between UTMI (1) and ULPI (0) mode.                                                                                                                                                                                            |
| 1     | RW   |      | Enable the ULPI Hardware support module                                                                                                                                                                                               |
| 0     | RO   | -    | Reserved                                                                                                                                                                                                                              |

0x02: xCORE Tile control

# B.4 xCORE Tile boot status: 0x03

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

-XMOS"-

|         | 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                                   |
| ).<br>2 | 2     | RO   |      | Boot ROM boots from JTAG                                  |
| 5       | 1:0   | RO   |      | The boot PLL mode pin value.                              |

0x03: xCORE Tile boot status

XS2-U12A-512-FB236

#### **B.5** Security configuration: 0x05

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

Copy of the security register as read from OTP.

0x05: Security configuration

# 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                        |
|------|------|------|------------------------------------|
| 31:2 | RO   | -    | Reserved                           |
| 1    | RW   | 0    | Core ring oscillator enable.       |
| 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.

-XMOS-

| <b>0x12:</b><br>Debug SSP | 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.

| 0x13:     | Bits | Perm | Init | Description              |
|-----------|------|------|------|--------------------------|
| DGETREG   | 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    | 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

|                | Bits  | Perm | Init | Description                                        |
|----------------|-------|------|------|----------------------------------------------------|
|                | 31:24 | CRO  |      | Processor ID of this XCore.                        |
| 0x00:          | 23:16 | CRO  |      | Number of the node in which this XCore is located. |
| Device         | 15:8  | CRO  |      | XCore revision.                                    |
| identification | 7:0   | CRO  |      | XCore version.                                     |

#### C.2 xCORE Tile description 1: 0x01

This register describes the number of logical cores, synchronisers, locks and channel ends available on this xCORE tile.

| Bits  | Perm | Init | Description              |
|-------|------|------|--------------------------|
| 31:24 | CRO  |      | Number of channel ends.  |
| 23:16 | CRO  |      | Number of the locks.     |
| 15:8  | CRO  |      | Number of synchronisers. |
| 7:0   | RO   | -    | Reserved                 |

#### C.3 xCORE Tile description 2: 0x02

This register describes the number of timers and clock blocks available on this xCORE tile.

0x02: xCORE Tile description 2

0x01: xCORE Tile description 1

|      | Bits  | Perm | Init | Description             |
|------|-------|------|------|-------------------------|
| x02: | 31:16 | RO   | -    | Reserved                |
| Tile | 15:8  | CRO  |      | Number of clock blocks. |
| on 2 | 7:0   | CRO  |      | Number of timers.       |

## C.4 Control PSwitch permissions to debug registers: 0x04

-XMOS-

This register can be used to control whether the debug registers (marked with permission CRW) are accessible through the tile configuration registers. When this bit is set, write -access to those registers is disabled, preventing debugging of the xCORE tile over the interconnect.



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

0x07 Security configuration

## C.8 Debug scratch: 0x20 .. 0x27

A set of registers used by the debug ROM to communicate with an external debugger, for example over the switch. This is the same set of registers as the Debug Scratch registers in the processor status.

0x20 .. 0x27: Debug scratch

| 0x27:<br>ebug | Bits | Perm | Init | Description |
|---------------|------|------|------|-------------|
| ratch         | 31:0 | CRW  |      | Value.      |

## C.9 PC of logical core 0: 0x40

Value of the PC of logical core 0.

0x40 PC of logical core 0

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

-XMOS

## C.10 PC of logical core 1: 0x41

Value of the PC of logical core 1.

Bits

31:0

#### C.15 PC of logical core 6: 0x46

Value of the PC of logical core 6.

**0x46:** PC of logical core 6

 Perm
 Init
 Description

 CRO
 Value.

#### C.16 PC of logical core 7: 0x47

Value of the PC of logical core 7.

0x47 PC of logical core 7

| 0x47:<br>ogical | Bits | Perm | Init | Description |
|-----------------|------|------|------|-------------|
| ore 7           | 31:0 | CRO  |      | Value.      |

## C.17 SR of logical core 0: 0x60

Value of the SR of logical core 0

**0x60:** SR of logical core 0

| <b>0x60:</b><br>ogical | Bits | Perm | Init | Description |
|------------------------|------|------|------|-------------|
| ore 0                  | 31:0 | CRO  |      | Value.      |

## C.18 SR of logical core 1: 0x61

Value of the SR of logical core 1

**0x61** SR of logical core 1

| 1:<br>al | Bits | Perm | Init | Description |
|----------|------|------|------|-------------|
| 1        | 31:0 | CRO  |      | Value.      |

# C.19 SR of logical core 2: 0x62

Value of the SR of logical core 2



# **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 36: Summary

## D.1 Device identification: 0x00

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

| <b>0x00:</b><br>Device<br>tification | Bits  | Perm | Init | Description                                       |
|--------------------------------------|-------|------|------|---------------------------------------------------|
|                                      | 31:24 | RO   | -    | Reserved                                          |
|                                      | 23:16 | RO   |      | Sampled values of BootCtl pins on Power On Reset. |
|                                      | 15:8  | RO   |      | SSwitch revision.                                 |
|                                      | 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                             |
| l: | 23:16 | RO   |      | Number of SLinks on the SSwitch.     |
| h  | 15:8  | RO   |      | Number of processors on the SSwitch. |
| n  | 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

| (05: | Bits  | Perm | Init | Description                 |
|------|-------|------|------|-----------------------------|
| ode  | 31:16 | RO   | -    | Reserved                    |
| fier | 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.

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



|                       | Bits  | Perm | Init | Description                                                                                                                                          |
|-----------------------|-------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | 31:19 | RO   | -    | Reserved                                                                                                                                             |
|                       | 18    | RW   | 0    | Set to 1 to disable pulldowns on ports 8A and 8B.                                                                                                    |
|                       | 17:14 | RO   | -    | Reserved                                                                                                                                             |
| <b>0х40:</b><br>Л РНҮ | 13    | RW   | 0    | After an auto-resume, this bit is set to indicate that the resume signalling was for reset (se0). Set to 0 to clear.                                 |
|                       | 12    | RW   | 0    | After an auto-resume, this bit is set to indicate that the resume signalling was for resume (K). Set to 0 to clear.                                  |
|                       | 11:8  | RW   | 0    | Log-2 number of clocks before any linestate change is propa-<br>gated.                                                                               |
|                       | 7     | RW   | 0    | Set to 1 to use the suspend controller handle to resume from suspend. Otherwise, the program has to poll the linestate_filt field in phy_teststatus. |
|                       | 6:4   | RW   | 0    | Control the the conf1,2,3 input pins of the PHY.                                                                                                     |
| ontrol                | 3:0   | RO   | -    | Reserved                                                                                                                                             |

## F.17 UIFM PHY control: 0x40

**0x40** UIFM PHY control