# E·XFL



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 8-Core                                                   |
| Speed                      | 1000MIPS                                                        |
| Connectivity               | Configurable                                                    |
| Peripherals                | -                                                               |
| Number of I/O              | 90                                                              |
| Program Memory Size        | 128KB (32K x 32)                                                |
| Program Memory Type        | SRAM                                                            |
| EEPROM Size                | -                                                               |
| RAM Size                   | -                                                               |
| Voltage - Supply (Vcc/Vdd) | 0.90V ~ 5.5V                                                    |
| Data Converters            | A/D 8x12b                                                       |
| Oscillator Type            | Internal                                                        |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                 |
| Mounting Type              | Surface Mount                                                   |
| Package / Case             | 217-LFBGA                                                       |
| Supplier Device Package    | 217-FBGA (16x16)                                                |
| Purchase URL               | https://www.e-xfl.com/product-detail/xmos/xs1-a8a-128-fb217-c10 |

Email: info@E-XFL.COM

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

#### TO OUR VALUED CUSTOMERS

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

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

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





### 1 xCORE Multicore Microcontrollers

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



Key features of the XS1-A8A-128-FB217 include:

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

### 9.1 Boot from SPI master

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

Figure 11: SPI master pins

| X0D00 MISO Master In Slave Out (Data) |  |
|---------------------------------------|--|
| AUDOU MISO Master in Slave Out (Data) |  |
| X0D01 SS Slave Select                 |  |
| X0D10 SCLK Clock                      |  |
| X0D11 MOSI Master Out Slave In (Data) |  |

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

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

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

#### 9.2 Boot from xConnect Link

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

The boot-rom on the core will then:

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

### 10 Memory

#### 10.1 OTP

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

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

#### 10.2 SRAM

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

#### 10.3 Deep Sleep Memory

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

### 11 Analog-to-Digital Converter

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

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

-XMOS-



-XMOS<sup>®</sup>

| Symbol    | Parameter                           | MIN | TYP  | MAX | UNITS    | Notes |
|-----------|-------------------------------------|-----|------|-----|----------|-------|
| VDD1V8    | 1V8 Supply Voltage                  |     | 1.80 |     | V        |       |
| V(RIPPLE) | Ripple Voltage (peak to<br>peak)    |     | 10   | 40  | mV       |       |
| V(ACC)    | Voltage Accuracy                    | -5  |      | 5   | %        | A     |
| F(S)      | Switching Frequency                 |     | 1    |     | MHz      |       |
| F(SVAR)   | Variation in Switching<br>Frequency | -10 |      | 10  | %        |       |
| Effic     | Efficiency                          |     | 80   |     | %        |       |
| PGT(HIGH) | Powergood Threshold<br>(High)       |     | 95   |     | %/VDD1V8 |       |
| PGT(LOW)  | Powergood Threshold<br>(Low)        |     | 80   |     | %/VDD1V8 |       |

### 17.3 DC2 Characteristics

Figure 26: DC2 characteristics

A If supplied externally.

### 17.4 ADC Characteristics

| Symbol    | Parameter                     | MIN | TYP | MAX  | UNITS  | Notes |
|-----------|-------------------------------|-----|-----|------|--------|-------|
| N         | Resolution                    |     | 12  |      | bits   |       |
| Fs        | Conversion Speed              |     |     | 1    | MSPS   |       |
| Nch       | Number of Channels            |     | 8   |      |        |       |
| Vin       | Input Range                   | 0   |     | AVDD | V      |       |
| DNL       | Differential Non Linearity    | -1  |     | 1.5  | LSB    |       |
| INL       | Integral Non Linearity        | -4  |     | 4    | LSB    |       |
| E(GAIN)   | Gain Error                    | -10 |     | 10   | LSB    |       |
| E(OFFSET) | Offset Error                  | -3  |     | 3    | mV     |       |
| T(PWRUP)  | Power time for ADC Clock Fclk |     |     | 7    | 1/Fclk |       |
| ENOB      | Effective Number of bits      |     | 10  |      |        |       |

-XMOS®

Figure 27: ADC characteristics

#### B.1 RAM base address: 0x00

This register contains the base address of the RAM. It is initialized to 0x00010000.

**0x00**: RAM base address

| <u>_</u> | Bits | Perm | Init | Description                                |
|----------|------|------|------|--------------------------------------------|
| e.       | 31:2 | RW   |      | Most significant 16 bits of all addresses. |
| s        | 1:0  | RO   | -    | Reserved                                   |

### B.2 Vector base address: 0x01

Base address of event vectors in each resource. On an interrupt or event, the 16 most significant bits of the destination address are provided by this register; the least significant 16 bits come from the event vector.

0x01: Vector base address

|   | Bits  | Perm | Init | Description                                                    |
|---|-------|------|------|----------------------------------------------------------------|
| • | 31:16 | RW   |      | The most significant bits for all event and interrupt vectors. |
|   | 15:0  | RO   | -    | Reserved                                                       |

### B.3 xCORE Tile control: 0x02

Register to control features in the xCORE tile

| Bits | Perm | Init | Description                                                                                                                                                                                                                                             |
|------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RO   | -    | Reserved                                                                                                                                                                                                                                                |
| 5    | RW   | 0    | Set to 1 to select the dynamic mode for the clock divider when<br>the clock divider is enabled. In dynamic mode the clock divider is<br>only activated when all active logical cores are paused. In static<br>mode the clock divider is always enabled. |
| 4    | RW   | 0    | Set to 1 to enable the clock divider. This slows down the xCORE tile clock in order to use less power.                                                                                                                                                  |
| 3: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

| 0x05:       |
|-------------|
| Cause debug |
| interrupts  |

|         | Bits | Perm | Init | Description                                             |
|---------|------|------|------|---------------------------------------------------------|
| -       | 31:2 | RO   | -    | Reserved                                                |
| у.<br>g | 1    | RO   | 0    | Set to 1 when the processor is in debug mode.           |
| s       | 0    | CRW  | 0    | Set to 1 to 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:8 | RO   | -    | Reserved                              |
| 7:0  | RW   |      | Value of the clock divider minus one. |

### C.7 Security configuration: 0x07

Copy of the security register as read from OTP.

0x07: Security configuration

| <b>)x07:</b><br>:urity | Bits | Perm | Init | Description |
|------------------------|------|------|------|-------------|
| ation                  | 31:0 | RO   |      | Value.      |

-XMOS

### C.8 PLink status: 0x10 .. 0x13

Status of each of the four processor links; connecting the xCORE tile to the switch.

Bits

31:0

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

**0x41:** PC of logical core 1 PermInitDescriptionROValue.

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

| 0x42:<br>PC of logical<br>core 2 | Bits | Perm | Init | Description |
|----------------------------------|------|------|------|-------------|
|                                  | 31:0 | RO   |      | Value.      |

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

| <b>0x43:</b><br>PC of logical | Bits | Perm | Init | Description |
|-------------------------------|------|------|------|-------------|
| core 3                        | 31:0 | RO   |      | Value.      |

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

Value of the SR of logical core 0

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

| s <b>u:</b><br>cal | Bits | Perm | Init | Description |
|--------------------|------|------|------|-------------|
| 0                  | 31:0 | RO   |      | Value.      |

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

**0x61:** SR of logical core 1

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

-XMOS



### D Digital Node Configuration

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

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

Figure 43: Summary

### D.1 Device identification: 0x00

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

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

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

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

XMOS

58

|          | Bits  | Perm | Init | Description                                                                                                                                                                                         |
|----------|-------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 31    | RW   | 0    | Write '1' to this bit to enable the link, write '0' to disable it. This bit controls the muxing of ports with overlapping links.                                                                    |
|          | 30    | RW   | 0    | Set to 0 to operate in 2 wire mode or 1 to operate in 5 wire mode                                                                                                                                   |
|          | 29:28 | RO   | -    | Reserved                                                                                                                                                                                            |
|          | 27    | RO   | 0    | Set to 1 on error: an RX buffer overflow or illegal token encoding has been received. This bit clears on reading.                                                                                   |
|          | 26    | RO   | 0    | 1 if this end of the link has issued credit to allow the remote end to transmit.                                                                                                                    |
|          | 25    | RO   | 0    | 1 if this end of the link has credits to allow it to transmit.                                                                                                                                      |
|          | 24    | WO   | 0    | Set to 1 to initialize a half-duplex link. This clears this end of<br>the link's credit and issues a HELLO token; the other side of the<br>link will reply with credits. This bit is self-clearing. |
|          | 23    | WO   | 0    | Set to 1 to reset the receiver. The next symbol that is detected will be assumed to be the first symbol in a token. This bit is self-clearing.                                                      |
| 7.       | 22    | RO   | -    | Reserved                                                                                                                                                                                            |
| nk<br>n  | 21:11 | RW   | 0    | The number of system clocks between two subsequent transi-<br>tions within a token                                                                                                                  |
| nd<br>on | 10:0  | RW   | 0    | The number of system clocks between two subsequent transmit tokens.                                                                                                                                 |

0x80 .. 0x87 Link configuration and initialization

### D.15 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:5 | RO   | -    | Reserved                                                                                        |  |
| [<br> | 4:0  | RW   | 0    | The destination channel end on this node that packets received in static mode are forwarded to. |  |

-XMOS<sup>®</sup>

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

| Bits  | Perm | Init | Description                                                                                                                                                                                                                                                                                                                             |  |
|-------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:25 | RO   | -    | Reserved                                                                                                                                                                                                                                                                                                                                |  |
| 24    | RW   |      | Tristate processor mode pins.                                                                                                                                                                                                                                                                                                           |  |
| 23:18 | RO   | -    | Reserved                                                                                                                                                                                                                                                                                                                                |  |
| 17:16 | RW   |      | Processor mode pins.                                                                                                                                                                                                                                                                                                                    |  |
| 15:2  | RO   | -    | Reserved                                                                                                                                                                                                                                                                                                                                |  |
| 1     | WO   | 0    | xCORE Tile reset. Set to 1 to initiate a reset of the xCORE Tile.<br>This bit is self clearing. A write to this configuration register<br>with this bit asserted results in no response packet being sent<br>to the sender regardless of whether or not a response was<br>requested.                                                    |  |
| 0     | WO   | 0    | System reset. Set to 1 to initiate a reset whose scope includes<br>most configuration and peripheral control registers. This bit is<br>self clearing. A write to this configuration register with this bit<br>asserted results in no response packet being sent to the sender<br>regardless of whether or not a response was requested. |  |

**0x50:** Reset and Mode Control

### E.5 System clock frequency: 0x51

| Bits | Perm | Init | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | -    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6:0  | RW   | 25   | Oscillator clock frequency in MHz rounded up to the nearest<br>integer value. Only values between 5 and 100 MHz are valid -<br>writes outside this range are ignored and will be NACKed.<br>This field must be set on start up of the device and any time that<br>the input oscillator clock frequency is changed. It must contain<br>the system clock frequency in MHz rounded up to the nearest<br>integer value. The following functions depend on the correct<br>frequency settings:<br>* Processor reset delay<br>* The watchdog clock<br>* The real-time clock when running in sleep mode |

-XMOS<sup>®</sup>

0x51: System clock frequency

| Bits  | Perm | Init | Description                                                                                                                                                                                         |  |  |
|-------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:28 | RO   | -    | Reserved                                                                                                                                                                                            |  |  |
| 27    | RO   | 0    | Set to 1 on error: an RX buffer overflow or illegal token encoding has been received. This bit clears on reading.                                                                                   |  |  |
| 26    | RO   | 0    | 1 if this end of the link has issued credit to allow the remote end to transmit.                                                                                                                    |  |  |
| 25    | RO   | 0    | 1 if this end of the link has credits to allow it to transmit.                                                                                                                                      |  |  |
| 24    | WO   | 0    | Set to 1 to initialize a half-duplex link. This clears this end of<br>the link's credit and issues a HELLO token; the other side of the<br>link will reply with credits. This bit is self-clearing. |  |  |
| 23    | WO   | 0    | Set to 1 to reset the receiver. The next symbol that is detected<br>will be assumed to be the first symbol in a token. This bit is<br>self-clearing.                                                |  |  |
| 22    | RO   | -    | Reserved                                                                                                                                                                                            |  |  |
| 21:11 | RW   | 1    | The number of system clocks between two subsequent transi-<br>tions within a token                                                                                                                  |  |  |
| 10:0  | RW   | 1    | The number of system clocks between two subsequent transmit tokens.                                                                                                                                 |  |  |

### E.6 Link Control and Status: 0x80

0x80: Link Control and Status

### E.7 1 KHz Watchdog Control: 0xD6

The watchdog provides a mechanism to prevent programs from hanging by resetting the xCORE Tile after a pre-set time. The watchdog should be periodically "kicked" by the application, causing the count-down to be restarted. If the watchdog expires, it may be due to a program hanging, for example because of a (transient) hardware issue.

The watchdog timeout is measured in 1 ms clock ticks, meaning that a time between 1 ms and 65 seconds can be set for the timeout. The watchdog timer is only clocked during the AWAKE power state. When writing the timeout value, both the timeout and its one's complement should be written. This reduces the chances of accidentally setting kicking the watchdog. If the written value does not comprise a 16-bit value with a 16-bit one's complement, the request will be NACKed, otherwise an ACK will be sent.

If the watchdog expires, the xCORE Tile is reset.

| 0xD6                | Bits  | Perm | Init | Description                                                                               |
|---------------------|-------|------|------|-------------------------------------------------------------------------------------------|
| 1 KHz               | 31:16 | RO   | 0    | Current value of watchdog timer.                                                          |
| Watchdog<br>Control | 15:0  | RW   | 1000 | Number of 1kHz cycles after which the watchdog should expire and initiate a system reset. |

68

0x18: ADC Control input pin 6

| Bits | Perm | Init | Description                                                                                                                                                                      |
|------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RW   | 0    | The node and channel-end identifier to which data for this ADC input pin should be send to. This is the top 24 bits of the channel-end identifier as allocated on an xCORE Tile. |
| 7:1  | RO   | -    | Reserved                                                                                                                                                                         |
| 0    | RW   | 0    | Set to 1 to enable this input pin on the ADC.                                                                                                                                    |

### F.8 ADC Control input pin 7: 0x1C

Controls specific to ADC input pin 7.

0x1C: ADC Control input pin 7

| Bits | Perm | Init | Description                                                                                                                                                                      |
|------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RW   | 0    | The node and channel-end identifier to which data for this ADC input pin should be send to. This is the top 24 bits of the channel-end identifier as allocated on an xCORE Tile. |
| 7:1  | RO   | -    | Reserved                                                                                                                                                                         |
| 0    | RW   | 0    | Set to 1 to enable this input pin on the ADC.                                                                                                                                    |

-XMOS

### F.9 ADC General Control: 0x20

General ADC control.

|            | Number    | Perm | Description             |
|------------|-----------|------|-------------------------|
| Figure 46: | 0x00 0x7F | RW   | Deep sleep memory       |
| Summary    | 0xFF      | RW   | Deep sleep memory valid |

#### G.1 Deep sleep memory: 0x00 .. 0x7F

128 bytes of memory that can be used to hold data when the xCORE Tile is powered down.

0x00 .. 0x7F Deep sleep memory

| k/F:<br>leep | Bits | Perm | Init | Description       |
|--------------|------|------|------|-------------------|
| nory         | 7:0  | RW   |      | User defined data |

#### G.2 Deep sleep memory valid: 0xFF

One byte of memory that is reset to 0. The program can write a non zero value in this register to indicate that the data in deep sleep memory is valid.

0xFF Deep sleep memory valid

| OxFF:<br>sleep | Bits | Perm | Init | Description                    |
|----------------|------|------|------|--------------------------------|
| valid          | 7:0  | RW   | 0    | User defined data, reset to 0. |

### **H** Oscillator Configuration

The Oscillator is peripheral 4. The control registers are accessed using 8-bit reads and writes (use write\_periph\_8(device, 4, ...) and read\_periph\_8(device, 4, ...) for reads and writes).

Figure 47: Summary

| Number | Perm | Description                   |
|--------|------|-------------------------------|
| 0x00   | RW   | General oscillator control    |
| 0x01   | RW   | On-silicon-oscillator control |
| 0x02   | RW   | Crystal-oscillator control    |

-XMOS

| Bits | Perm | Init | Description                                                                                                                                                                        |
|------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | -    | Reserved                                                                                                                                                                           |
| 7    | RW   | 0    | By default, when waking up, the voltage levels stored in the LEVEL CONTROL registers are used. Set to 1 to use the power-on voltage levels.                                        |
| 6    | WO   |      | Set to 1 to re-apply the current contents of the AWAKE state. Use<br>this when the program has changed the contents of the AWAKE<br>state register. Self clearing.                 |
| 5    | RW   | 0    | Set to 1 to use a 64-bit timer.                                                                                                                                                    |
| 4    | RW   | 0    | Set to 1 to wake-up on the timer.                                                                                                                                                  |
| 3    | RW   | 1    | If waking on the WAKE pin is enabled (see above), then by default<br>the device wakes up when the WAKE pin is pulled high. Set to 0<br>to wake-up when the WAKE pin is pulled low. |
| 2    | RW   | 0    | Set to 1 to wake-up when the WAKE pin is at the right level.                                                                                                                       |
| 1    | RW   | 0    | Set to 1 to initiate sleep sequence - self clearing. Only set this bit when in AWAKE state.                                                                                        |
| 0    | RW   | 0    | Sleep clock select. Set to 1 to use the default clock rather than<br>the internal 31.25 kHz oscillator. Note: this bit is only effective<br>in the ASLEEP state.                   |

**0x00:** General control

### J.2 Time to wake-up, least significant 32 bits: 0x04

This register stores the time to wake-up. The value is only used if wake-up from the real-time clock is enabled, and the device is asleep.

| 0x04:          |
|----------------|
| Time to        |
| wake-up,       |
| least          |
| significant 32 |
| bits           |

| Bits | Perm | Init | Description                                   |
|------|------|------|-----------------------------------------------|
| 31:0 | RW   | 0    | Least significant 32 bits of time to wake-up. |

#### J.3 Time to wake-up, most significant 32 bits: 0x08

-XMOS

This register stores the time to wake-up. The value is only used if wake-up from the real-time clock is enabled, if 64-bit comparisons are enabled, and the device is asleep. In most cases, 32-bit comparisons suffice.

| Bits  | Perm | Init | Description                                                                                                                                                             |
|-------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | -    | Reserved                                                                                                                                                                |
| 29    | RO   | 0    | 1 if VOUT6 was enabled in the previous state.                                                                                                                           |
| 28    | RO   | 0    | 1 if LDO5 was enabled in the previous state.                                                                                                                            |
| 27:26 | RO   | -    | Reserved                                                                                                                                                                |
| 25    | RO   | 1    | 1 if DCDC2 was enabled in the previous state.                                                                                                                           |
| 24    | RO   | 0    | 1 if DCDC1 was enabled in the previous state.                                                                                                                           |
| 23:19 | RO   | -    | Reserved                                                                                                                                                                |
| 18:16 | RO   |      | Current state of the power sequence state machine<br>0: Reset<br>1: Asleep<br>2: Waking 1<br>3: Waking 2<br>4: Awake Wait<br>5: Awake<br>6: Sleeping 1<br>7: Sleeping 2 |
| 15    | RO   | -    | Reserved                                                                                                                                                                |
| 14    | RO   | 0    | Set to 1 to disable clock to the xCORE Tile.                                                                                                                            |
| 13:10 | RO   | -    | Reserved                                                                                                                                                                |
| 9     | RO   | 0    | Sets modulation used by DCDC2:<br>0: PWM modulation (max 475 mA)<br>1: PFM modulation (max 50 mA)                                                                       |
| 8     | RO   | 0    | Sets modulation used by DCDC1:<br>0: PWM modulation (max 700 mA)<br>1: PFM modulation (max 50 mA)                                                                       |
| 7:6   | RO   | -    | Reserved                                                                                                                                                                |
| 5     | RO   | 0    | Set to 1 to enable VOUT6 (IO supply).                                                                                                                                   |
| 4     | RO   | 0    | Set to 1 to enable LDO5 (core PLL supply).                                                                                                                              |
| 3:2   | RO   | -    | Reserved                                                                                                                                                                |
| 1     | RO   | 0    | Set to 1 to enable DCDC2 (analogue supply).                                                                                                                             |
| 0     | RO   | 0    | Set to 1 to enable DCDC1 (core supply).                                                                                                                                 |

**0x24:** Power sequence status

### J.11 DCDC control: 0x2C

This register controls the two DC-DC converters.

-XMOS<sup>®</sup>

### N Schematics Design Check List

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

### N.1 Clock

- Pins MODE0 and MODE1 are set to the correct value for the chosen frequency. The MODE settings are shown in the Oscillator section, Section 8. If you have a choice between two values, choose the value with the highest multiplier ratio since that will boot faster.
- OSC\_EXT\_N is tied to ground (for use with a crystal or oscillator) or tied to VDDIO (for use with the internal oscillator). If using the internal oscillator, set MODE0 and MODE1 to be for the 20-48 MHz range (Section 8).
- ☐ If you have used an oscillator, it is a 1V8 oscillator. (Section 16)

### N.2 USB ULPI Mode

This section can be skipped if you do not have an external USB PHY.

- $\Box$  If using ULPI, the ULPI signals are connected to specific ports as shown in Section K.
- □ If using ULPI, the ports that are used internally are not connected, see Section K. (Note that this limitation only applies when the ULPI is enabled, they can still be used before or after the ULPI is being used.)

#### N.3 Boot

- □ The device is connected to a SPI flash for booting, connected to X0D0, X0D01, X0D10, and X0D11 (Section 9). If not, you must boot the device through OTP or JTAG.
- □ The device that is connected to flash has both MODE2 and MODE3 connected to pin 3 on the xSYS Header (MSEL). If no debug adapter connection is supported (not recommended) MODE2 and MODE3 are to be left NC (Section 9). MODE4 is set in accordance with Section 9.
- ☐ The SPI flash that you have chosen is supported by **xflash**, or you have created a specification file for it.

#### N.4 JTAG, XScope, and debugging

- $\Box$  You have decided as to whether you need an XSYS header or not (Section M)
- □ If you included an XSYS header, you connected pin 3 to any MODE2/MODE3 pin that would otherwise be NC (Section M).
- □ If you have not included an XSYS header, you have devised a method to program the SPI-flash or OTP (Section M).

#### N.5 GPIO

You have not mapped both inputs and outputs to the same multi-bit port.

#### N.6 Multi device designs

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

-XM()S

- $\Box$  One device is connected to a SPI flash for booting.
- Devices that boot from link have MODE2 grounded and MODE3 NC. These device must have link XLB connected to a device to boot from (see 9).
- □ If you included an XSYS header, you have included buffers for RST\_N, TMS, TCK, MODE2, and MODE3 (Section L).

### **R** Revision History

| Date       | Description                                                                                          |
|------------|------------------------------------------------------------------------------------------------------|
| 2013-04-16 | First release                                                                                        |
| 2013-07-19 | Updated Features list with available ports and links - Section 2                                     |
|            | Simplified link bits in Signal Description - Section 4                                               |
|            | New JTAG, xSCOPE and Debugging appendix - Section M                                                  |
|            | New Schematics Design Check List - Section N                                                         |
|            | New PCB Layout Design Check List - Section O                                                         |
| 2013-12-09 | Added Industrial Ambient Temperature - Section 17.1                                                  |
|            | Annotated V(ACC) parameter - Section 17.2                                                            |
|            | Updated V(IH) parameter - Section 17.9                                                               |
|            | Updated V(OH) parameter - Section 17.5                                                               |
| 2014-02-26 | Added C8 and I8 parts - Section 19                                                                   |
| 2014-03-25 | Added footnotes to DC and Switching Characteristics - Section 17                                     |
| 2015-04-14 | Updated Introduction - Section 1; Pin Configuration - Section 3; Signal Descrip-<br>tion - Section 4 |

## XMOS®

X5601,

Copyright © 2015, All Rights Reserved.

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