

# Caravel Frame and SoC

Version 6.1.0

Caravel Frame and SoC documentation

### Table of Contents

| Caravel Overview                                                | 5  |
|-----------------------------------------------------------------|----|
| How do I use this guide?                                        | 7  |
| Features of Caravel                                             | 8  |
| Caravel Padframe General Features                               | 9  |
| Caravel Management SoC Features                                 | 12 |
| Caravel Pinouts                                                 | 15 |
| Caravel pins and functions                                      | 16 |
| Caravel QFN-64 pinout                                           | 21 |
| Caravel bare die pinout                                         | 22 |
| Caravel WLCSP pinout                                            | 23 |
| Getting Started                                                 |    |
| • Essentials                                                    | 25 |
| Block diagram                                                   | 26 |
| <ul><li>user_project_wrapper</li></ul>                          | 26 |
| <ul><li>caravel_user_project template</li></ul>                 | 28 |
| <ul> <li>Power-up/boot process</li> </ul>                       | 28 |
| Clocking and DLL/DCO                                            | 30 |
| DLL (Delay-Locked Loop)                                         | 31 |
| DCO (Digitally-Controlled Oscillator)                           | 32 |
| wb_clk_i                                                        | 33 |
| • user_clock2                                                   | 34 |
| Clock monitoring                                                | 36 |
| Firmware/Programming                                            |    |
| Firmware Flash SPI interface                                    | 37 |
| Writing and compiling basic firmware for the Caravel RISC-V CPU | 39 |
| Writing and simulating testbenches with Verilog or Cocotb       | 40 |
| Other important programming information                         | 41 |
| Caravel Full-chip Simulation                                    | 42 |

| General Purpose Input/Output                     | 43 |
|--------------------------------------------------|----|
| User GPIO pins                                   | 43 |
| Management GPIO pin                              | 44 |
| User GPIO configuration by firmware or HKSPI     | 46 |
| User GPIO power-on configuration by user_defines | 46 |
| Standard GPIO configuration mode constants       | 48 |
| io_oeb conventions                               | 49 |
| GPIO pin names map                               | 50 |
| Logic Analyzer                                   | 51 |
| UART (RS232 Serial Interface)                    | 52 |
| Wishbone Interface                               | 53 |
| SPI Controller                                   | 14 |
| Counter/Timer                                    | 14 |
| Housekeeping and HKSPI                           | 56 |
| Housekeeping SPI pins                            | 57 |
| Housekeeping SPI protocol definition             | 58 |
| Housekeeping SPI modes                           | 59 |
| Housekeeping SPI Pass-through mode               | 61 |
| Housekeeping SPI addresses                       | 62 |
| Interrupts (IRQs)                                | 66 |
| Registers and Memory Map                         | 67 |
| High-level memory map                            | 68 |
| Register list                                    | 69 |
| Analog Connections                               | 70 |
| • NOTES:                                         | 71 |
| Advanced Guides                                  | 72 |
| Caravel CPU code execution                       | 73 |
| Executing code from RAM                          | 74 |
| Custom ISRs                                      | 75 |

| Power-on behavior               | 76 |
|---------------------------------|----|
| Management Core wrapper         | 77 |
| Building Caravel using Litex    | 78 |
| • Misc                          | 79 |
| Bringup (Caravel Eval)          |    |
| Caravan Specifics               | 81 |
| Common features                 | 81 |
| Caravan differences             | 83 |
| Caravel Mini Specifics          | 84 |
| Common features                 | 81 |
| Caravel Mini differences        | 86 |
| Supplementary Figures           | 87 |
| Specifications and Ratings      | 88 |
| Absolute maximum ratings        | 89 |
| Schematics and PCB Design       | 90 |
| KiCad schematic and footprint   | 91 |
| PCB design guidelines           | 92 |
| Caravel Eval Board and M.2 card | 93 |
| Glossary                        | 94 |

### **Caravel Overview**

Designing and fabricating an ASIC with Efabless chipIgnite 2 requires that you use an existing supported template (or "frame"), and our free and open-source Caravel is recommended as the most popular, feature-rich, and production-ready template. The chipIgnite submission process automatically integrates your user project design area into the frame, so you don't have to worry about it.

With Caravel, you have a ready-to-use chip harness for creating your own ASIC design and getting it fabricated for prototype or production purposes. It includes a standardized padring, blank silicon design area of 10mm <sup>2</sup> and optional on-chip SoC (microcontroller/management/test framework). You can use it whether you are creating a proprietary/private chip, one for commercial purposes, or an open-source design.

#### **6** Hint

While this documentation describes **Caravel**, it also covers **Caravan** (our frame with some dedicated bare analog pads, suitable for prototyping) and **Caravel Mini**. All 3 are very similar, with some specific distinctions marked where appropriate.

For more information about the different frames and options, see: Which chipIgnite template should I use? 🗹



Caravel die floorplan

### How do I use this guide?

It is intended that you can work through each of the following sections in order to learn the basics of Caravel and how to use it, before reaching more advanced topics.

This guide covers general use of Caravel as a chip padring/harness for essential support of your design, as well as programming the Caravel SoC as a microcontroller and interfacing it with your design, and more-advanced concepts like analog connections.

### **Features of Caravel**

As a padframe, Caravel offers easy-to-connect standard features such as GPIO pins, power delivery (optionally with multple power domains), clocking, and reset logic (both a dedicated reset pin, and a POR circuit). These are well-characterized and qualified to reduce the overhead of the designer.

As an SoC, Caravel provides a wide range of optional functionality on-chip that can either be largely ignored or can be used for any of bringing up your design, debugging and providing a diagnostic/maintenance interface, controlling different peripherals that your design can leverage, or even as a full microcontroller (including CPU with external firmware interface, basic UART, and SPI controller).

### Caravel Padframe General Features

These features are universally available to any chip based on the Caravel frame, even without specific use of the Management SoC.

#### Caravel user\_project\_wrapper

Caravel includes a 10mm² "user project wrapper" design area. The user\_project\_wrapper is what a user submits as a fixed-area GDS macro. It is then automatically integrated (by the Efabless chipIgnite submission process) into the rest of the Caravel chip harness to produce the final GDS that is submitted for fabrication. This design area, in the 130nm node, is enough for on the order of 6 million transistors or 1 million logic gate primitives.

The designer can choose whether the design they include in the user project wrapper will interface with the Caravel SoC, the padframe GPIOs, the built-in clock sources, the PDN (Power Delivery Network) or any combination of these. For advanced users ordering bare dice and implementing a highly-specialized design, the user design may even use none of these features (though this is not recommended).

The user project wrapper provides support for digital, analog, and mixed-signal projects.

See: user\_project\_wrapper

#### Housekeeping SPI

The chip's power-on state defaults to assigning 4 GPIOs as a **Housekeeping SPI (HKSPI)** interface for an external SPI controller to assert debugging control over certain base configuration, debugging, and clocking of the chip.

This also includes **SPI pass-through**, able to be driven via HKSPI to take control (for reading/writing) of a firmware SPI ROM connected to the Management SoC.

See: Housekeeping and HKSPI

#### 38 GPIOs

Caravel provides **38 GPIO pins** that can be used interchangeably by the user's own digital logic, the Caravel CPU, or in some cases as analog connections:

- These 38 can be configured (and reconfigured via CPU firmware or HKSPI) to function as outputs, bidirectional, or inputs (including optional pull-up or pull-down).
- They also have built-in ESD protection, level shifting, and buffering, thus simplifying the job of the designer.
- 33 support power-on default configuration specified in silicon by the designer, while the remaining 5 have Caravel-dedicated power-on functions (that can be overridden by CPU firmware or HKSPI).
- · 29 optionally support direct pad connections for analog signals [ 1 ] .
- For Caravan : 11 are "bare analog" pads without GPIO circuitry and without ESD protection.
- Some offer additional Caravel SoC "management" functions (such as UART and additional debug functions).

See: General Purpose Input/Output

#### Footnotes

#### [1]

Caravel direct analog pad connections include ESD protection which typically limits full swing signals to about 50MHz.

# Dedicated clock input and DLL/DCO configurable clocking

Caravel and/or the user design can optionally receive (and modify) a clock signal via a dedicated clock input pin that includes circuitry for multiplying/dividing the input clock frequency.



The DLL/DCO is inactive by default, passing the optional dedicated clock input directly through to the user project wrapper. If the DLL/DCO is to be used, it must be explicitly enabled via

HKSPI or firmware running on the **Management SoC** . For more information, see the section on **Clocking, DLL and DCO** .

See: Clocking and DLL/DCO

### POR (Power-On Reset) module

See: Power-up/boot process

#### Four power domains

Caravel provides **4 power domains**: two intended as nominal 1.8V digital supplies, two intended as analog supplies in the range 1.8V to 5.5V. It also includes vddio for setting the desired external digital logic level (as a reference voltage in the range 1.8V-5.5V) for compatibility with a wide range of device.

### Caravel Management SoC Features

The Management SoC's RISC-V CPU (RV32I) is built into the die area, adjacent the user project wrapper, and can be interfaced with your design, as well as externally to the chip.

The SoC is generated using Litex and includes the following peripherals and capabilities that can be optionally enabled/disabled on subsets of the GPIO pins, to make the SoC useful both as a general-purpose microcontroller and a specialized test/debug interface for your design...

#### VexRiscv RISC-V CPU core

The CPU core is a VexRiscv minimal+debug configuration. Intended for use either as a microcontroller, general-purpose CPU, control or debug interface to the user design. It can be considered as a lightweight single-core bare-metal microcontroller, programmable in C or RISC-V assembly (RV32I, 32-bit instructions specifically), and it comprises:

- Dedicated firmware ROM SPI master for XIP loading of firmware code from an external SPI memory into a local 16-word (64-byte) instruction cache.
- 1.5kByte local SRAM for stack, scratch space/variables, or small high-speed in-memory executable subroutines.
- Interrupt and exception handling.
- · Dedicated power domain .
- **GPIO control**: Ability to reconfigure the 38 GPIOs ( **27 for Caravan** ), including taking over GPIOs as "management mode", either to activate SoC peripherals that have external interfaces, or for firmware to directly use some GPIOs.
- · Single management GPIO pin . See: Management GPIO pin

See: Firmware, Flash SPI, and Programming Guide

The CPU core also has access to a range of other SoC peripherals as described below.

#### A Note

If you don't intend to make use of the Management SoC at all, you can simply choose to not connect to its ports in the users project wrapper, and you can optionally tie its RESETD signal low externally to hold it in reset.

#### Logic Analyzer interface

The **Logic Analyzer** comprises 128 internal IO pins that can optionally be connected with your design in the user project wrapper.

See: Logic Analyzer

#### Wishbone master

The user project wrapper has an incoming **Wishbone master** interface from the CPU. This includes the wb\_clk\_i signal. It is implemented as a 32-bit Classic-Wishbone-based memory map expansion of the CPU for addresses in the range 0x30000000 - 0x300FFFFF .

See: Wishbone Interface

#### **UART**

The SoC includes a UART that is accessible only to the CPU. It can be enabled to take over two specific GPIO pins for transmit and/or receive, and it has the following features:

- Fixed baud rate proportional to 9,600 baud at a 10MHz core clock (i.e. 19,200 baud if the Caravel core clock is set to 20MHz).
- · Fixed 8N1 configuration.
- 16-byte FIFO for each of transmit and receive.
- TX/RX runs independently of the CPU.
- CPU can poll the FIFO state or enable an IRQ for the UART.

See: UART (RS232 Serial Interface)

#### SPI Controller

SPI master for direct control by user firmware.

See: SPI Controller

### 6 user IRQs

- 3 internally-driven by the user project.
- 2 externally-driven (optional) by GPIO pins.
- 1 internally-driven by SoC peripherals.

See: Interrupts (IRQs)

### Counter-timer

See: Counter/Timer

### **Caravel Pinouts**

All chips fabricated using the Caravel harness have a standard pinout with some pins dedicated to the SoC (i.e. the CPU), some for power, most for user-configurable GPIOs, and a few with shared functions.

Caravel chips can be ordered in a 64-pin QFN package, or as bare dice (unpackaged, bare silicon chips).

Older generations of chipIgnite and the Open MPW shuttles also supplied WLCSP packaged parts.

### Caravel pins and functions

#### Pin description

| Name          | Туре            | Description                                                                                                                                                                                                         |
|---------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mprj_io[37:0] | Digital I/<br>O | General purpose configurable digital I/O with pullup/pulldown, input or output, enable/disable, analog output, high voltage output, slew rate control. Shared between the user project area and the management SoC. |
| flash_clk     | Digital<br>out  | Flash SPI clock                                                                                                                                                                                                     |
| flash_csb     | Digital<br>out  | Flash SPI chip select                                                                                                                                                                                               |
| flash_io[1:0] | Digital I/<br>O | Flash SPI data input/output                                                                                                                                                                                         |
| clock         | Digital in      | External CMOS 3.3V clock source                                                                                                                                                                                     |
| resetb        | Digital in      | SoC system reset (sense inverted)                                                                                                                                                                                   |
| SDO           |                 | Housekeeping serial interface data output                                                                                                                                                                           |

| Name       | Туре            | Description                                  |
|------------|-----------------|----------------------------------------------|
|            | Digital<br>out  |                                              |
| SDI        | Digital in      | Housekeeping serial interface data input     |
| CSB        | Digital in      | Housekeeping serial interface chip select    |
| SCK        | Digital in      | Housekeeping serial interface clock          |
| ser_tx     | Digital<br>out  | UART transmit channel                        |
| ser_rx     | Digital in      | UART receive channel                         |
| irq        | Digital in      | External interrupt                           |
| gpio       | Digital I/<br>O | Management GPIO/user power enable            |
| JTAG       | Digital I/<br>O | JTAG system access                           |
| flash2_csb | Digital<br>out  | User area QSPI flash enable (sense inverted) |

| Name           | Туре            | Description                             |
|----------------|-----------------|-----------------------------------------|
| flash2_sck     | Digital<br>out  | User area QSPI flash clock              |
| flash2_io[1:0] | Digital I/<br>O | User area QSPI flash data               |
| spi_sdo        | Digital<br>out  | Serial interface controller data output |
| spi_sck        | Digital<br>out  | Serial interface controller clock       |
| spi_csb        | Digital<br>out  | Serial interface controller chip select |
| spi_sdi        | Digital in      | Serial interface controller data input  |
| vddio          | 3.3V<br>Power   | ESD and padframe power supply           |
| vdda           | 3.3V<br>Power   | Management area power supply            |

| Name                   | Туре          | Description                               |
|------------------------|---------------|-------------------------------------------|
| vccd                   | 1.8V<br>Power | Management area digital power supply      |
| vssio / vssa /<br>vssd | Ground        | ESD, padframe, and management area ground |
| vdda1                  | 3.3V<br>Power | User area 1 power supply                  |
| vccd1                  | 1.8V<br>Power | User area 1 digital power supply          |
| vssa1                  | Ground        | User area 1 ground                        |
| vssd1                  | Ground        | User area 1 digital ground                |
| vdda2                  | 3.3V<br>Power | User area 2 power supply                  |
| vccd2                  | 1.8V<br>Power | User area 2 digital power supply          |
| vssa2                  | Ground        | User area 2 ground                        |

| Name  | Туре   | Description                |
|-------|--------|----------------------------|
| vssd2 | Ground | User area 2 digital ground |

### Caravel QFN-64 pinout



Caravel QFN64 pinout

© 2024 Efabless Corporation Caravel QFN-64 pinout

### Caravel bare die pinout

Caravel bare dice have bond pads in a standard padring and are numbered starting at 1 on the top of the left-hand edge, incrementing counter-clockwise up to pad 63.

### Caravel WLCSP pinout

Wafer-level chip-scale packaging is no longer offered by Efabless for standard chipIgnite orders, but may be specially-ordered and customized for large-volume production orders.

Older generations of Caravel chip already fabricated as WLCSP instead of QFN or bare dice had the following pinout:

## **Getting Started with Caravel**

### **Essentials**

## Block diagram

## user\_project\_wrapper

## caravel\_user\_project template

## Power-up/boot process

### **Clocking and DLL/DCO**

Caravel has a dedicated clock input pin. While it is not mandatory to make use of this for any design submitted to chipIgnite, an external clock source is (in most cases) required in order for most parts of the Caravel SoC to be used.

The Caravel SoC's RISC-V CPU derives its core clock from the clock pin, as do the following peripherals that can be used by the CPU:

- UART
- · SPI Controller
- Counter/Timer

Note that HKSPI can be used without using the Caravel clock pin, as it has its own dedicated SCK clock input.

At power-on (and during any reset state) the clock signal present on the clock pin is passed, unmodified, directly to the CPU and other dependent peripherals, and is also available as an incoming signal in the user project area via both wb\_clk\_i and user\_clock2.

The CPU or HKSPI may modify this clock path, e.g. to enable the DLL (and hence multiply and divide it to derive a different clock frequency), or to switch to using Caravel's internal ring oscillator (DCO) as the clock source:



Caravel clocking diagram

While the Caravel SoC uses specifically wb\_clk\_i , if your own user project requires a clock source then you might choose to use any of:

- wb\_clk\_i recommended for synchronous interfacing with the Caravel CPU (e.g. via Wishbone Interface or Logic Analyzer ).
- user\_clock2
- · Any GPIO input pin
- · A Caravel-controlled Logic Analyzer pin
- · Your own internal oscillator, e.g. a ring oscillator

Of the options given, wb\_clk\_i and user\_clock2 are preferred because they have known timing characteristics and can either be derived from Caravel's internal ring oscillator (DCO) or from Caravel's external dedicated clock input pin – in both cases optionally also being modified by the DLL/divider circuits as described. In turn this means that they can be controlled, to a degree, by firmware running on the CPU.

## DLL (Delay-Locked Loop)

The Caravel DLL is like a PLL as found in an FPGA. The Caravel frame has a dedicated "clock" input pin.

### DCO (Digitally-Controlled Oscillator)

This is an internal ring oscillator with a fixed base frequency and which can be "trimmed" by up to 26 steps to control its actual output frequency. It is used by the DLL to generate a reasonably stable multiple of the input clock source, but can also be used simply as a direct clock source instead of the clock input pin. In this mode it can optionally be divided by two independent integer dividers (to produce each of wb\_clk\_i and user\_clock2).

Note that the actual internal DCO frequency is PVT -dependent.

## wb\_clk\_i

wb\_clk\_i is the core clock used by the Caravel CPU and related peripherals. It is also available inside the User Project Wrapper.

### user\_clock2

When the DLL is enabled, the clock source feeding <code>user\_clock2</code> 's divider is 90 degrees out of phase. That is, <code>user\_clock2</code> lags <code>wb\_clk\_i</code> by a quarter-cycle.

### Clock monitoring

It's possible to monitor wb\_clk\_i and/or user\_clock2 via GPIO pins, which can help with debugging your clock source and DLL/DCO behavior.

Caravel can use GPIOs 15 and 14 for this purpose, while Caravan (for chips fabricated as of June 2023) can use GPIOs 31 and 30 instead.

Enabling this feature requires setting the respective GPIO(s) to GPIO\_MODE\_MGMT\_STD\_OUTPUT mode, and then setting one or two bits of the clock monitor register: HKSPI register 0x1B (in firmware, this is reg\_clk\_out\_dest or address 0x26200004).

- For Caravel: Monitoring of wb\_clk\_i and user\_clock2 is via GPIOs 15 and 14 respectively. These are respectively enabled by writing 1 to bits 2 and/or 1 of the clock monitor register.
- For Caravan: Monitoring of wb\_clk\_i and user\_clock2 is via GPIOs 31 and 30 respectively. These are respectively enabled by writing 1 to bits 4 and/or 3 of the clock monitor register.

# Firmware, Flash SPI, and Programming Guide

#### Firmware Flash SPI interface

# Writing and compiling basic firmware for the Caravel RISC-V CPU

# Writing and simulating testbenches with Verilog or Cocotb

# Other important programming information

# **Caravel Full-chip Simulation**

### **General Purpose Input/Output**

In the Caravel context, "General Purpose Input/Output" (or GPIO) most often refers to the 38 User GPIO pins, but might also refer to the single extra Management GPIO pin.

#### **User GPIO pins**

Caravel provides 38 external GPIO pins, typically called mprj\_io[37] down to mprj\_io[0], sometimes referred to as GPIO[37:0] or simply IO[37:0]. These are available for use by the user design and logic, and/or by the Caravel Management SoC (including CPU, but also other dedicated periphrals that can be enabled on certain pins). While all are digital-capable, some can also carry analog signals (for advanced designs that implement their own analog circuits/devices).

- All 38 GPIOs have digital control circuitry that allows them to be configured after power-on for different modes via registers accessible via firmware or HKSPI.
- The lowest-numbered 5 of the 38 always power up in a fixed Caravel management mode: IO[4:1] are enabled for exclusive use as the HKSPI interface; IO[0] is enabled as a debug pin. Therefore, these are not immediately usable by the user design area, until they are reconfigured at run-time (if desired), in which case the respective HKSPI/debug functions are disabled (until explicitly re-enabled by firmware, or until the next power-on, only).
- The remaining 33 of 38 must have their default power-on modes masked-programmed, i.e. a simple "user\_defines" configuration file defines how they will be hard-set during fabrication. This ensures they have a known desired mode immediately after power-up, though they can still be reconfigured at run-time.
- NOTE: The GPIO configuration modes are retained across SoC resets, but not across power cycling.
- Out of the above 33 pins, 29 ( IO[35:7] ) can also be configured to support direct analog connections, thus disabling their digital control circuitry for designers who specifically want to include their own (or ready-made) analog circuits in the user project area.

Each of the 38 GPIOs provides multiple ports into the user project area to enable direct connections to the user's design/logic, and meet all supported use cases:

- · All 38 provide <code>io\_in[\*]</code> (input digital signal paths), <code>io\_out[\*]</code> (output digital signal paths), and <code>io\_oeb[\*]</code> ("Output Enable Bar" for setting the signal directions). Note that, at any given moment, whichever of these paths are actually usable or meaningful depends on what mode the pin is configured for. For example, <code>io\_oeb</code> has no effect on changing the pin direction if the pin is already configured as an output.
- The 29 that are analog-capable also provide analog\_io[\*] ports.

## Management GPIO pin

# User GPIO configuration by firmware or HKSPI

# User GPIO power-on configuration by user\_defines

# Standard GPIO configuration mode constants

### io\_oeb conventions

GPIO\_MODE\_MGMT\_STD\_OUTPUT

TBC

### GPIO pin names map

# **Logic Analyzer**

# **UART (RS232 Serial Interface)**

#### **Wishbone Interface**

#### **SPI Controller**



Not to be confused with the firmware SPI bus or HKSPI.

## **Counter/Timer**

### **Housekeeping and HKSPI**

Housekeeping (HK) describes a subset of SoC control registers which – besides being addressable by the Caravel CPU – have been made externally-accessible through a "Housekeeping SPI" (HKSPI) interface. This interface coexists on four of the Caravel GPIO pins ( mprj\_io[4:1] ) and is always enabled at power-on (but can be deactivated at run-time). Importantly, this means any simple external SPI controller can always take control over certain blocks of the chip frame/SoC. This feature is typically used for bring-up debugging purposes, and could be used for diagnostic/maintenance purposes in a field application.

With Housekeeping, you can externally access certain SoC registers (some read-only, some read/write) to inspect some aspects of the SoC state or otherwise control its behaviour, including to:

- · Verify the chipIgnite product ID and read your chip's unique Project ID.
- · Alter the chip's core clock paths/speed via DLL and DCO.
- Redirect the internal clock signals out via GPIO pins.
- Reset the Caravel RISC-V CPU.
- · Reconfigure GPIO pin functions.
- Take over and optionally reprogram a firmware SPI Flash ROM chip connected to the Caravel CPU.

"HKSPI" is an SPI responder that can be accessed from an external controller (e.g. the Caravel Eval Board ) through a standard 4-pin SPI serial interface. The SPI implementation is mode 0 🔀, with new data on SDI captured on the SCK rising edge, and output data presented on the falling edge of SCK (to be sampled on the next SCK rising edge). The SPI pins are shared with user area GPIO.

# Housekeeping SPI pins

Housekeeping SPI external interface pins

| GPIO pin   | HKSPI<br>pin | Dir    | Function                                                     |
|------------|--------------|--------|--------------------------------------------------------------|
| mprj_io[1] | SDO          | Output | Serial data out, clocked out on falling edge of SCK          |
| mprj_io[2] | SDI          | Input  | Serial data in, clocked in on rising edge of SCK             |
| mprj_io[3] | CSB          | Input  | "Chip Select bar" (falling edge starts an HKSPI transaction) |
| mprj_io[4] | SCK          | Input  | Serial clock.                                                |

#### Housekeeping SPI protocol definition

All input is in groups of 8 bits. Each byte is input MSB (most-significant-bit) first.

Every command sequence requires one command word (8 bits), followed by one address word (8 bits), followed by one or more data words (8 bits each), according to the data transfer modes described in Housekeeping SPI modes.



Housekeeping SPI signalling

Addresses are read in sequence from lower values to higher values.

Therefore groups of bits larger than 8 should be grouped such that the lowest bits are at the highest address. Any bits additional to an 8-bit boundary should be at the lowest address.

Data is captured from the register map in bytes on the falling edge of the last SCK before a data byte transfer. Multi-byte transfers should ensure that data do not change between byte reads.

CSB pin must be low to enable an SPI transmission. Data are clocked by pin SCK, with data valid on the rising edge of SCK. Output data is received on the SDO line. SDO is held high-impedance when CSB is high and at all times other than the transfer of data bits on a read command. SDO outputs become active on the falling edge of SCK, such that data are written and read on the Same SCK rising edge.

After CSB is set low, the SPI is always in the "command" state, awaiting a new command.

The first transferred byte is the command word, interpreted according to the Housekeeping SPI command word definition .

Housekeeping SPI command word definition

| Word    | Meaning      |
|---------|--------------|
| 0000000 | No operation |

| Word     | Meaning                                                |
|----------|--------------------------------------------------------|
| 10000000 | Write in streaming mode                                |
| 01000000 | Read in streaming mode                                 |
| 11000000 | Simultaneous Read/Write in streaming mode              |
| 11000100 | Pass-through (management) Read/Write in streaming mode |
| 11000110 | Pass-through (user) Read/Write in streaming mode       |
| 10nnn000 | Write in n-byte mode (up to 7 bytes)                   |
| 01nnn000 | Read in n-byte mode (up to 7 bytes)                    |
| 11nnn000 | Simultaneous Read/Write in n-byte mode (up to 7 bytes) |

#### Note

All other words are reserved and act as no-operation if not defined by the SPI responder module.

#### Housekeeping SPI modes

The two basic modes of operation are streaming mode and n-byte mode.

In **streaming mode** operation, the data is sent or received continuously, one byte at a time, with the internal address incrementing for each byte. Streaming mode operation continues until CSB is raised to end the transfer.

In **n-byte mode** operation, the number of bytes to be read and/or written is encoded in the command word, and may have a value from 1 to 7 (note that a value of zero implies streaming mode). After n bytes have been read and/or written, the SPI returns to waiting for the next command. No toggling of CSB is required to end the command or to initiate the following command.

#### Housekeeping SPI Pass-through mode

The pass-through mode puts the CPU into immediate reset, then sets <code>FLASH\_CSB</code> low to initiate a data transfer to the CPU's attached SPI flash. After the pass-through command byte has been issued, all subsequent SPI signaling on <code>SDI</code> and <code>SCK</code> are applied directly to the SPI flash (pins <code>FLASH\_IOO</code> and <code>FLASH\_CLK</code>, respectively), and the SPI flash data output (pin <code>FLASH\_IOI</code>) is applied directly to <code>SDO</code>, until the <code>CSB</code> pin is raised. When <code>CSB</code> is raised, the <code>FLASH\_CSB</code> is also raised, terminating the data transfer to the SPI flash. The CPU is brought out of reset, and starts executing instructions at the program start address.

This mode allows the SPI flash to be programmed from the same SPI communication channel as the housekeeping SPI, without the need for additional wiring to the SPI flash chip.

There are two pass-through modes. The first one corresponds to the primary SPI flash used by the management SoC. The second one corresponds to a secondary optional SPI flash that can be defined in the user project.

The pass-through mode allows a communications chip external to the Caravel chip program either SPI flash chip from a host computer without requiring separate external access to the SPI flash. Both pass-through modes only connect to I/O pins 0 and 1 of the SPI flash chips, and so must operate only in the 4-pin SPI mode. The user project may elect to operate the SPI flash in quad mode using a 6-pin interface.

#### Housekeeping SPI addresses

The purpose of the housekeeping SPI is to give access to certain system values and controls independently of the CPU. The housekeeping SPI can be accessed even when the CPU is in full reset. Some control registers in the housekeeping SPI affect the behaviour of the CPU in a way that can be potentially detrimental to the CPU operation, such as adjusting the trim value of the digital frequency-locked loop generating the CPU core clock.

While both the CPU and HKSPI can access the same registers that control/inspect certain SoC functions, the addresses are different between the two interfaces. Namely, accessing these registers via HKSPI uses an 8-bit address only, while accessing them via the CPU uses 32-bit addresses scattered through the range 0x26000000 - 0x262FFFFF with no correlation between the addresses of the two interfaces.

| Register<br>  Address | msb<br>  7                       | 6                                          | 5 | 4          | <sub> </sub> 3             | <sub>  2</sub>       | 1         | lsb<br>  0           | comments     |
|-----------------------|----------------------------------|--------------------------------------------|---|------------|----------------------------|----------------------|-----------|----------------------|--------------|
| 0x00                  |                                  | SPI status and control                     |   |            |                            |                      |           | unused/<br>undefined |              |
| 0x01                  |                                  | unused manufacturer_ID[11:8] (= 0x4)       |   |            |                            |                      | read-only |                      |              |
| 0x02                  |                                  | manufacturer_ID[7:0] (= 0x56)              |   |            |                            |                      | read-only |                      |              |
| 0x03                  |                                  | product_ID (= 0x10)                        |   |            |                            |                      | read-only |                      |              |
| 0x04–<br>0x07         |                                  | user_project_ID (unique value per project) |   |            |                            |                      | read-only |                      |              |
| 0x08                  |                                  | unused PLL DCO enable enable               |   |            |                            |                      |           | default 0x02         |              |
| 0x09                  | unused PLL<br>bypass             |                                            |   |            |                            | default 0x01         |           |                      |              |
| 0x0A                  | unused CPU IRQ                   |                                            |   |            |                            | default 0x00         |           |                      |              |
| 0x0B                  | unused CPU reset                 |                                            |   |            |                            | default 0x00         |           |                      |              |
| 0x0C                  | unused CPU trap                  |                                            |   |            |                            | read-only            |           |                      |              |
| 0x0D-<br>0x10         | DCO trim (26 bits) (= 0x3ffefff) |                                            |   |            |                            | default<br>0x3ffefff |           |                      |              |
| 0x11                  | unused PLL outp                  |                                            |   | output div | t divider 2 PLL output div |                      |           | vider                | default 0x12 |
| 0x12                  | unused                           |                                            |   |            | PLL feedback divider       |                      |           | default 0x04         |              |

#### Housekeeping SPI register map

#### Housekeeping SPI registers

| Name            | Register<br>address                 | Description                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| manufacturer_ID | 0x01<br>(low 4<br>bits) and<br>0x02 | The 12-bit manufacturer ID for efabless is 0x456                                                                                                                                                                                                                                                                                                             |
| product_ID      | 0x03                                | The product ID for the Caravel harness chip is 0x10                                                                                                                                                                                                                                                                                                          |
| user_project_ID | 0x04 to<br>0x07                     | The 4-byte (32bit) user project ID is metal-mask programmed on each project before tapeout, with a unique number given to each user project.                                                                                                                                                                                                                 |
| PLL enable      | 0×08 bit<br>0                       | This bit enables the digital frequency-locked-loop clock multiplier. The enable should be applied prior to turning off the PLL bypass to allow the PLL time to stabilize before using it to drive the CPU clock.                                                                                                                                             |
| PLL DCO enable  | 0×08 bit                            | The PLL can be run in DCO mode, in which the feedback loop to the driving clock is removed, and the system operates in free-running mode, driven by the ring oscillator which can be tuned between approximately 90 to 200MHz by setting the trim bits ( check PLL trim ) (NEED TO UPDATE THIS TO MATCH LEO'S RECENT CHARACTERIZATION and do some more char) |
| PLL bypass      | 0x09 bit<br>0                       | When enabled, the PLL bypass switches the clock source of the CPU from the PLL output to the external CMOS clock (pin c9 ). The default value is 0x1 (CPU clock source is the external CMOS clock).                                                                                                                                                          |
| CPU IRQ         | 0x0A bit                            | This is a dedicated manual interrupt driving the CPU IRQ channel 6. The bit is not self-resetting, so while the rising edge will trigger an interrupt, the signal must be manually set to zero before it can trigger another interrupt.                                                                                                                      |

| CPU reset                 | 0×0B bit<br>0                                        | The CPU reset bit puts the entire CPU into a reset state. This bit is not self-resetting and must be set back to zero manually to clear the reset state                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU trap                  | 0x0C bit                                             | If the CPU has stopped after encountering an error, it will raise the trap signal. The trap signal can be configured to be read from a GPIO pin, but as the GPIO state is potentially unknowable, the housekeeping SPI can be used to determine the true trap state.                                                                                                                                                                                                                                                                                                                           |
| PLL trim                  | 0x0D (all<br>bits) to<br>0x10<br>(lower<br>two bits) | The 26-bit trim value can adjust the DCO frequency over a factor of about two from the slowest (trim value 0x3fffffff) to the fastest (trim value 0x0). Default value is 0x3ffefff (1 step higher than the slowest trim). Note that this is a thermometer-code trim, where each bit provides an additional (approximately) 250ps delay (on top of a fixed delay of 4.67ns). The fastest output frequency is approximately 215MHz while the slowest output frequency is approximately 90MHz (check PLL trim) (NEED TO UPDATE THIS TO MATCH LEO'S RECENT CHARACTERIZATION and do some more char) |
| PLL output<br>divider     | 0×11 bits<br>2-0                                     | The PLL output can be divided down by an integer divider to provide the core clock frequency. This 3-bit divider can generate a clock divided by 2 to 7. Values 0 and 1 both pass the undivided PLL clock directly to the core (and should not be used, as the processor does not operate at these frequencies).                                                                                                                                                                                                                                                                               |
| PLL output<br>divider (2) | 0×11 bits<br>5-3                                     | The PLL 90-degree phase output is passed through an independent 3-bit integer clock divider and provided to the user project space as a secondary clock. Values 0 and 1 both pass the undivided PLL clock, while values 2 to 7 pass the clock divided by 2 to 7, respectively.                                                                                                                                                                                                                                                                                                                 |
| PLL feedback<br>divider   | 0×12 bits<br>4-0                                     | The PLL operates by comparing the input clock (pin C9) rate to the rate of the PLL clock divided by the feedback divider value (when running in PLL mode, not DCO mode). The feedback divider must be set such that the external clock rate multiplied by the feedback divider value falls between 90 and 214 MHz (preferably centered on this range, or approximately 150 MHz) ( check PLL trim ) (NEED TO UPDATE THIS, and the calculation below, TO MATCH LEO'S                                                                                                                             |

RECENT CHARACTERIZATION and do some more char). For example, when using an 8 MHz external clock, the divider should be set to 19 ( 19 \* 8 = 152 ). The DCO range and the number of bits of the feedback divider implies that the external clock should be no slower than around 4 to 5 MHz.

# **Interrupts (IRQs)**

# **Registers and Memory Map**

### High-level memory map

# Register list

# **Analog Connections**

#### **NOTES:**

- · Allowing a pin to switch between digital and analog modes should be possible, but probably difficult. Might really only work well for OpenFrame, given how long it takes the CPU to signal everything in the GPIOs/chip.
- Comment on io\_oeb and io\_out when pads are configured for analog

### **Advanced Guides**

### Caravel CPU code execution

# Executing code from RAM

### **Custom ISRs**

### Power-on behavior

### Management Core wrapper

The Caravel "Management Core Wrapper" is designed in a way to allow the implementation of different management cores. Early versions of the Google-sponsored "Open MPW" Caravel SoCs used a PicoRV32 core, while the current version officially offered by Efabless is "Caravel V6.0" (in use since Open MPW-6) and is generated using Litex with a VexRiscv CPU core.

The common parts of the management core wrapper include:

- · Housekeeping and HKSPI.
- GPIO configuration blocks (power-on defaults and runtime-reprogrammable).
- · User Project Wrapper interface pins, namely: Logic Analyzer; IRQs; Wishbone (inc. wb\_rst\_i , and wb\_clk\_i and user\_clock2 clock sources); and power rings (for a <u>PDN</u> of up to 4 power domains).
- · Management protection.
- · Clocking module (DLL/DCO).
- · POR (Power-On Reset) module.

# **Building Caravel using Litex**

### Misc

- CPU as a testbench, e.g. using the CPU to drive **inputs** into UPW on GPIO pins.
- Reset behaviour, sources, options, e.g. is it a good idea to rely solely on wb\_rst\_i?

# Caravel Chip Bring-up and the Caravel Evaluation Board

# **Caravan Specifics**

This is a summary of all things that are common and different between Caravan and the normal Caravel.

### **Common features**

### Caravan differences

# **Caravel Mini Specifics**

This is a summary of all things that are common and different between Caravel Mini and the normal Caravel.

### **Common features**

### Caravel Mini differences

# **Supplementary Figures**

# **Specifications and Ratings**

# Absolute maximum ratings

| Туре                               | minimum                | typical | maximum | units             |
|------------------------------------|------------------------|---------|---------|-------------------|
| Supply voltage (VDDIO)             | 1.8                    | 3.3     | 5.0     | V                 |
| Core digital supply voltage (VCCD) | 1.62                   | 1.8     | 1.98    | V                 |
| Junction temperature               | -40                    | 27      | 100     | \(^{\circ}<br>C\) |
| \(V_{OH}\)                         | \(0.8 \cdot {VDDIO} \) |         | V       |                   |
| \(V_{OL}\)                         |                        |         | 0.4     | V                 |
| Management area power              |                        | TBD     |         | mW                |
| Storage area power                 |                        | TBD     |         | mW                |
| GPIO voltage                       | 0                      |         | VDDIO   | V                 |
| GPIO frequency                     | 0                      |         | 50      | MHz               |
| Management clock                   | 0                      |         | 40      | MHz               |

# **Schematics and PCB Design**

# KiCad schematic and footprint

# PCB design guidelines

### Caravel Eval Board and M.2 card

## **Glossary**

#### **Active-low**

A signal whose named intent/mode is considered to be asserted when the signal is low (i.e. logic 0, or GND), and deasserted when the signal is high (i.e. logic 1, or positive). Sometimes also referred to as "inverted logic" or "negative logic". Example: A device with an input signal name like reset\_n (note the \_n suffix) is considered to actively be in the "reset" state when the signal is low, and otherwise running normally (and not in reset) when the signal is high. A similar convention is resetb where the b suffix means "Bar".

#### Bar

Used as a suffix (e.g. "Output Enable Bar"), this typically means the signal is " active-low ". In the name of a signal, this is often indicated by a b or \_b suffix (e.g. oeb might mean "Output Enable Bar"), where the name would normally be rendered in a schematic with a horizontal line (or "bar") over the signal name.

#### bring-up

The process of getting a chip to operate for the first time after receiving it as a fabricated device. During this time, many measurements and experiments may be required, as well as debugging. This includes to verify that the core features of the frame/SoC are functioning as expected, and that your design is able to respond in a set of your own expectations.

#### **Caravel Eval Board**

#### **Caravel SoC**

Define me

#### crt0

Initial "C Runtime" bootstrapping routines. Code built into the assembly process of a C program that is executed before the main() function is called. Responsible for loading the initial system/memory state, including initializing any global/static variables and optionally loading read-only data.

#### **DLL**

Delay-Locked Loop. Very similar to a PLL . In Caravel, there is a DLL which is an all-digital SoC peripheral that can be used to generate new clock frequencies from an internal or external clock source.

#### **GDS**

Define me

#### Hardening

The process of generating a final silicon layout (and hence GDS file) from potentially multiple parts, including synthesis of higher-level descriptions of digital logic.

#### Litex

Define me

#### **Management Area**

Define me

#### **Management Core**

Define me

#### **Management Core Wrapper**

Define me

#### **Management SoC**

Define me

#### PDN

Power Delivery Network.

#### PLL

Phase-Locked Loop. A device commonly used in FPGAs and in Caravel to derive a new clock frequency/phase from a supplied clock source. Typically allows for a clock source to be multiplied in frequency by an integer value, and then divided by a second integer value to produce a new clock frequency. Sometimes may offer multiple multipliers/dividers in order to produce multiple clocks. Compare: DLL

#### **POR**

Power-On Reset. A circuit that ensures a stable reset sequence during chip power-on, thus ensuring a stable system state if a dedicated external reset is not otherwise implemented.

#### **Project ID**

Every unique silicon layout (e.g. customer project) fabricated with Efabless chipIgnite has a unique 32-bit "Project ID" assigned by Efabless and included in the silicon layout. The Project ID is accessible by the Caravel SoC (and via HKSPI) as a read-only 32-bit value, but is also present as "GDS art" text in the padring, rendered as 8 hex digits. Most Project IDs are of the pattern YYMMhhhh where hhhh is a random value assigned by Efabless at the initialization of the project, and YYMM is the shuttle number (e.g. 2409) and itself is formed

of the last two digits of the shuttle year and the month number. An example Project ID (as a hex string) is 240476A0 which is Tiny Tapeout 6 [], on the April 2024 shuttle.

Note that when using the SoC or HKSPI to read the 32-bit value of the Project ID, some shuttles had the project ID bits in reverse order, e.g. 240476A0 (which in binary is 0010\_0100\_0000\_0101\_0110\_1010\_0000 ) would be read as 056E2024 (which is the binary string in reverse: 0000\_0101\_0110\_1110\_0010\_0000\_0010\_0100 ).

#### **PVT**

Short for "Process, Voltage, Temperature" and typically used in the context "PVT-dependent", meaning that the exact behaviour/characteristics of something is affected (or otherwise likely to deviate from typical stated figures) by virtue of: variations that naturally occur in the fabrication process; variations in precise voltages in the circuit; and variations in ambient temperature.

#### **QFN**

Quad Flat No-leads IC package 🖸 . A plastic-encapsulated chip package with pin pads around all 4 sides.

#### SoC

System on a Chip. A combination of chip modules that provide a system of functionality, often including a CPU and other useful peripheral devices implemented in silicon.

#### SPI

Serial Peripheral Interface 2 . A common 4-wire interface for simple serial communication with a peripheral device, driven by a controller. Often used between chips, and capable of multi-megabit-per-second transfers.

#### **UPW**

Short for User Project Wrapper.

#### **User Project Wrapper**

The design area reserved for a user project. It has a fixed location and dimensions within the overall Caravel chip die area, and fixed pin placements around all 4 edges that a user design must connect to in order to interface with the Caravel SoC and/or GPIOs.

Typically the User Project Wrapper also has a PDN that is generated by the hardening flow.

#### VexRiscv

Define me

#### **WLCSP**

Wafer-Level redistribution Chip-Scale Package . A minimal chip package usually with a "redistribution" layer that attaches bare bond pads of a silicon die to ball grid array (BGA) solder balls via tiny wires.

#### **XIP**

Execute In Place: Code is directly loaded and executed from an external memory as needed, without the need for user-driven caching control, buffering, translation, logic, etc.

