

**VERONICA\_RISCV**



November 19, 2025

Jay Convertino

# Contents

|                                            |           |
|--------------------------------------------|-----------|
| <b>1 Usage</b>                             | <b>2</b>  |
| 1.1 Introduction . . . . .                 | 2         |
| 1.2 Dependencies . . . . .                 | 2         |
| 1.2.1 fusesoc_info Depenecies . . . . .    | 2         |
| <b>2 Architecture</b>                      | <b>4</b>  |
| <b>3 Building</b>                          | <b>4</b>  |
| 3.1 fusesoc . . . . .                      | 4         |
| 3.2 Source Files . . . . .                 | 4         |
| 3.2.1 fusesoc_info File List . . . . .     | 4         |
| 3.3 Targets . . . . .                      | 6         |
| 3.3.1 fusesoc_info Targets . . . . .       | 6         |
| 3.4 Directory Guide . . . . .              | 9         |
| <b>4 Simulation</b>                        | <b>10</b> |
| <b>5 Module Documentation</b>              | <b>11</b> |
| 5.1 nexys a7 100t system wrapper . . . . . | 12        |

# 1 Usage

## 1.1 Introduction

The Veronica RISCV is a base Vexriscv system. This version of the Vexriscv core emulates the E31 core in its mapping of features. Difference is that this core can generate a MMU and non-PMP enabled versions. The JTAG configuration can also be changed between the Xilinx BSCANE, or JTAG IO for external devices, or none. Each target tries to use all of the resources of the board using free IP's from the vendor, or open source IP cores intergrated into fusesoc.

## 1.2 Dependencies

The following are the dependencies of the cores.

- fusesoc 2.X
- iverilog (simulation)
- cocotb (simulation)

### 1.2.1 fusesoc\_info Dependencies

- tb\_cocotb
  - ::jtag\_vpi:0-r5
- nexys-a7-100t
  - AFRL:utility:digilent\_nexys-a7-100t\_board\_base\_constr:1.0.0
  - AFRL:utility:digilent\_nexys-a7-100t\_board\_base\_ddr\_cfg:1.0.0
  - AFRL:utility:vivado\_board\_support\_packages
- nexys-a7-100t\_bootgen
  - AFRL:utility:digilent\_veronica\_nexys\_boot\_gen:1.0.0
- genesys2
  - AFRL:utility:digilent\_genesys2\_board\_base\_constr:1.0.0
  - AFRL:utility:digilent\_genesys2\_board\_base\_ddr\_cfg:1.0.0
  - AFRL:utility:vivado\_board\_support\_packages
- NetFPGA-1G-CML
  - AFRL:utility:digilent\_NetFPGA-1G-CML\_board\_base\_constr:1.0.0
  - AFRL:utility:digilent\_NetFPGA-1G-CML\_board\_base\_ddr\_cfg:1.0.0

- AFRL/utility:vivado\_board\_support\_packages
- KC705
  - AFRL/utility:xilinx\_kc705\_board\_base\_constr:1.0.0
  - AFRL/utility:xilinx\_kc705\_board\_base\_ddr\_cfg:1.0.0
  - AFRL/utility:vivado\_board\_support\_packages
- VC707
  - AFRL/utility:xilinx\_vc707\_board\_base\_constr:1.0.0
  - AFRL/utility:xilinx\_vc707\_board\_base\_ddr\_cfg:1.0.0
  - AFRL/utility:vivado\_board\_support\_packages
- crosslink-nx\_eval
  - AFRL/utility:lattice\_crosslink-nx\_eval\_board\_base:1.0.0
- dep
  - AFRL/utility:helper:1.0.0
  - AFRL/utility:tcl\_helper\_check:1.0.0
  - AFRL/device:axi\_lite\_spi\_master:1.0.0
  - AFRL/device:axi\_lite\_uart\_lite:1.0.0
  - AFRL/device:axi\_lite\_gpio:1.0.0
  - zipcpu:axi\_lite:crossbar:1.0.0
- dep\_jtag\_io
  - spinalhdl:cpu:veronica\_jtag\_io:1.0.0
- dep\_secure\_jtag\_io
  - spinalhdl:cpu:veronica\_secure\_jtag\_io:1.0.0
- dep\_linux\_jtag\_io
  - spinalhdl:cpu:veronica\_linux\_jtag\_io:1.0.0
- dep\_jtag\_bscane
  - spinalhdl:cpu:veronica\_jtag\_xilinx\_bscane:1.0.0
- dep\_secure\_jtag\_bscane
  - spinalhdl:cpu:veronica\_secure\_jtag\_xilinx\_bscane:1.0.0
- dep\_linux\_jtag\_bscane
  - spinalhdl:cpu:veronica\_linux\_jtag\_xilinx\_bscane:1.0.0

## 2 Architecture

The project contains four wrappers

- **system\_wrapper** Contains the top level project module and contains system\_ps\_wrapper.
- **system\_ps\_wrapper** Contains the processor system IP wrappers.

Please see 5 for more information per target.

## 3 Building

The all Veronica RISCV project source files are written in Verilog 2001. They should synthesize in any modern FPGA software. The core comes as a fusesoc packaged core and can be included in any other core. Be sure to make sure you have met the dependencies listed in the previous section.

### 3.1 fusesoc

Fusesoc is a system for building FPGA software without relying on the internal project management of the tool. Avoiding vendor lock in to Vivado or Quartus. These cores, when included in a project, can be easily integrated and targets created based upon the end developer needs. The core by itself is not a part of a system and should be integrated into a fusesoc based system. Simulations are setup to use fusesoc and are a part of its targets.

### 3.2 Source Files

#### 3.2.1 fusesoc\_info File List

- tb\_cocotb
  - 'tb/tb\_cocotb.py': 'file\_type': 'user', 'copyto': '.'
  - 'tb/tb\_cocotb.v': 'file\_type': 'verilogSource'
  - 'tb/export\_fix.sh': 'file\_type': 'user', 'copyto': '.'
- common
  - 'common/system\_ps\_axi\_perf\_wrapper.v': 'file\_type': 'verilogSource'
- nexys-a7-100t

- 'nexys-a7-100t/system\_wrapper.v': 'file\_type': 'verilogSource'
- 'nexys-a7-100t/system\_constr.tcl': 'file\_type': 'SDC'
- 'nexys-a7-100t/system\_gen\_ps.tcl': 'file\_type': 'tclSource'
- 'nexys-a7-100t/system\_gen.tcl': 'file\_type': 'tclSource'
- genesys2
  - 'genesys2/system\_wrapper.v': 'file\_type': 'verilogSource'
  - 'genesys2/system\_constr.tcl': 'file\_type': 'SDC'
  - 'genesys2/system\_gen\_ps.tcl': 'file\_type': 'tclSource'
  - 'genesys2/system\_gen.tcl': 'file\_type': 'tclSource'
- NetFPGA-1G-CML
  - 'NetFPGA-1G-CML/system\_wrapper.v': 'file\_type': 'verilogSource'
  - 'NetFPGA-1G-CML/system\_constr.tcl': 'file\_type': 'SDC'
  - 'NetFPGA-1G-CML/system\_gen\_ps.tcl': 'file\_type': 'tclSource'
  - 'NetFPGA-1G-CML/system\_gen.tcl': 'file\_type': 'tclSource'
- KC705
  - 'KC705/system\_wrapper.v': 'file\_type': 'verilogSource'
  - 'KC705/system\_constr.tcl': 'file\_type': 'SDC'
  - 'KC705/system\_gen\_ps.tcl': 'file\_type': 'tclSource'
  - 'KC705/system\_gen.tcl': 'file\_type': 'tclSource'
- VC707
  - 'VC707/system\_wrapper.v': 'file\_type': 'verilogSource'
  - 'VC707/system\_constr.tcl': 'file\_type': 'SDC'
  - 'VC707/system\_gen\_ps.tcl': 'file\_type': 'tclSource'
  - 'VC707/system\_gen.tcl': 'file\_type': 'tclSource'
- crosslink-nx\_eval
  - 'crosslink-nx\_eval/system\_constr.pdc': 'file\_type': 'PDC'
  - 'crosslink-nx\_eval/system\_wrapper.v': 'file\_type': 'verilogSource'
- dep\_vivado\_jtag\_io
  - 'common/xilinx/system\_define.tcl': 'file\_type': 'tclSource'
- dep\_jtag\_io
  - 'common/system\_ps\_wrapper\_jtag.v': 'file\_type': 'verilogSource'

- dep\_secure\_jtag\_io
  - 'common/system\_ps\_wrapper\_jtag.v': 'file\_type': 'verilogSource'
- dep\_linux\_jtag\_io
  - 'common/system\_ps\_wrapper\_jtag.v': 'file\_type': 'verilogSource'
- dep\_jtag\_bscane
  - 'common/system\_ps\_wrapper.v': 'file\_type': 'verilogSource'
- dep\_secure\_jtag\_bscane
  - 'common/system\_ps\_wrapper.v': 'file\_type': 'verilogSource'
- dep\_linux\_jtag\_bscane
  - 'common/system\_ps\_wrapper.v': 'file\_type': 'verilogSource'

### 3.3 Targets

#### 3.3.1 fusesoc\_info Targets

- nexys-a7-100t
 

Info: Base for nexys-a7-100t digilent development board builds, do not use.
- nexys-a7-100t\_secure\_jtag\_io
 

Info: Build for nexys-a7-100t digilent development board with PMP enabled Veronica RISCV.
- nexys-a7-100t\_jtag\_io
 

Info: Build for nexys-a7-100t digilent development board with standard Veronica RISCV.
- nexys-a7-100t\_secure\_jtag\_bscane
 

Info: Build for nexys-a7-100t digilent development board with PMP enabled Veronica RISCV.
- nexys-a7-100t\_jtag\_bscane
 

Info: Build for nexys-a7-100t digilent development board with standard Veronica RISCV.
- nexys-a7-100t\_linux\_jtag\_bscane
 

Info: Build for nexys-a7-100t digilent development board with Linux Veronica RISCV.

- `nexys-a7-100t_linux_jtag_bscane_bootgen`  
Info: Build for nexys-a7-100t digilent development board with Linux Veronica RISCV with bootgen for uboot.
- `genesys2`  
Info: Base for genesys2 digilent development board builds, do not use.
- `genesys2_secure_jtag_io`  
Info: Build for genesys2 digilent development board with PMP enabled Veronica RISCV.
- `genesys2_jtag_io`  
Info: Build for genesys2 digilent development board with standard Veronica RISCV.
- `genesys2_secure_bscane`  
Info: Build for genesys2 digilent development board with PMP enabled Veronica RISCV.
- `genesys2_jtag_bscane`  
Info: Build for genesys2 digilent development board with standard Veronica RISCV.
- `genesys2_linux_jtag_bscane`  
Info: Build for genesys2 digilent development board with Linux Veronica RISCV.
- `NetFPGA-1G-CML`  
Info: Base for NetFPGA-1G-CML digilent development board builds, do not use.
- `NetFPGA-1G-CML_secure_jtag_io`  
Info: Build for NetFPGA-1G-CML digilent development board with PMP enabled Veronica RISCV.
- `NetFPGA-1G-CML_jtag_io`  
Info: Build for NetFPGA-1G-CML digilent development board with standard Veronica RISCV.
- `NetFPGA-1G-CML_secure_bscane`  
Info: Build for NetFPGA-1G-CML digilent development board with PMP enabled Veronica RISCV.

- NetFPGA-1G-CML\_jtag\_bscane
  - Info: Build for NetFPGA-1G-CML digilent development board with standard Veronica RISCV.
- NetFPGA-1G-CML\_linux\_jtag\_bscane
  - Info: Build for NetFPGA-1G-CML digilent development board with Linux Veronica RISCV.
- kc705
  - Info: Base for kc705 xilinx development board builds, do not use.
- kc705\_secure\_jtag\_bscane
  - Info: Build for kc705 xilinx development board with PMP enabled Veronica RISCV.
- kc705\_jtag\_bscane
  - Info: Build for kc705 xilinx development board with standard Veronica RISCV.
- kc705\_linux\_jtag\_bscane
  - Info: Build for kc705 xilinx development board with Linux Veronica RISCV.
- vc707
  - Info: Base for VC707 xilinx development board builds, do not use.
- vc707\_secure\_jtag\_bscane
  - Info: Build for vc707 xilinx development board with PMP enabled Veronica RISCV.
- vc707\_jtag\_bscane
  - Info: Build for vc707 xilinx development board with standard Veronica RISCV.
- vc707\_linux\_jtag\_bscane
  - Info: Build for vc707 xilinx development board with Linux Veronica RISCV.
- crosslink-nx\_eval
  - Info: Defaults for CrossLink NX Evaluation Board, do not use.

- crosslink-nx\_eval\_jtag\_io
  - Info: Build for crosslink-nx\_eval development board with standard Veronica RISCV.
- crosslink-nx\_eval\_secure\_jtag\_io
  - Info: Build for crosslink-nx\_eval development board with secure Veronica RISCV.
- crosslink-nx\_eval\_linux\_jtag\_io
  - Info: Build for crosslink-nx\_eval development board with Linux Veronica RISCV.
- sim\_cocotb
  - Info: Cocotb unit tests

### 3.4 Directory Guide

Below highlights important folders from the root of the directory.

1. **docs** Contains all documentation related to this project.
  - **manual** Contains user manual and github page that are generated from the latex sources.
2. **nexys-a7-100t** Contains source files for nexys-a7-100t
3. **crosslink-nx\_eval** Contains source file for crosslink-nx\_eval, a future target.

## **4 Simulation**

There is no simulation at the moment. Maybe a future addition?

## 5 Module Documentation

This project has multiple modules. The targets are the top system wrappers.

- **nexys-a7-100t**
- **crosslink-nx\_eval**

The next sections document the module in great detail.

# **system\_wrapper.v**

---

## **AUTHORS**

---

**JAY CONVERTINO**

---

## **DATES**

---

**2024/11/25**

---

## **INFORMATION**

---

### **Brief**

---

System wrapper for ps.

### **License MIT**

---

Copyright 2024 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

## **system\_wrapper**

---

```
module system_wrapper #(
parameter
    ACLK_FREQ_MHZ
    =
    50
)
`ifdef _JTAG_IO
    input
    tck,
    input
    tms,
    input
    tdi,
    output
```

```
    tdo,
`endif input
clk,
input
resetn,
inout
[12:0]
ddr2_addr,
inout
[ 2:0]
ddr2_ba,
inout
ddr2_cas_n,
inout
ddr2_ck_n,
inout
ddr2_ck_p,
inout
ddr2_cke,
inout
ddr2_cs_n,
inout
[ 1:0]
ddr2_dm,
inout
[15:0]
ddr2_dq,
inout
[ 1:0]
ddr2_dqs_n,
inout
[ 1:0]
ddr2_dqs_p,
inout
ddr2_odt,
inout
ddr2_ras_n,
inout
ddr2_reset_n,
inout
ddr2_we_n,
output
[15:0]
leds,
input
[15:0]
slide_switches,
input
ftdi_tx,
output
ftdi_rx,
input
ftdi_rts,
output
ftdi_cts,
input
sd_spi_miso,
output
sd_spi_mosi,
output
sd_spi_csn,
output
sd_spi_sclk,
output
sd_reset
)
```

System wrapper for Vexriscv Veronica RISCV ps.

## Ports

|                       |                      |
|-----------------------|----------------------|
| <b>tck</b>            | JTAG                 |
| <b>tms</b>            | JTAG                 |
| <b>tdi</b>            | JTAG                 |
| <b>tdo</b>            | JTAG                 |
| <b>clk</b>            | Master Input Clock   |
| <b>resetn</b>         | Master Reset Input   |
| <b>ddr2_addr</b>      | DDR interface        |
| <b>ddr2_ba</b>        | DDR interface        |
| <b>ddr2_cas_n</b>     | DDR interface        |
| <b>ddr2_ck_n</b>      | DDR interface        |
| <b>ddr2_ck_p</b>      | DDR interface        |
| <b>ddr2_cke</b>       | DDR interface        |
| <b>ddr2_cs_n</b>      | DDR interface        |
| <b>ddr2_dm</b>        | DDR interface        |
| <b>ddr2_dq</b>        | DDR interface        |
| <b>ddr2_dqs_n</b>     | DDR interface        |
| <b>ddr2_dqs_p</b>     | DDR interface        |
| <b>ddr2_odt</b>       | DDR interface        |
| <b>ddr2_ras_n</b>     | DDR interface        |
| <b>ddr2_reset_n</b>   | DDR interface        |
| <b>ddr2_we_n</b>      | DDR interface        |
| <b>leds</b>           | board leds           |
| <b>slide_switches</b> | board slide switches |
| <b>ftdi_tx</b>        | FTDI UART TX         |
| <b>ftdi_rx</b>        | FTDI UART RX         |

```
    output [15:0]
ftdi_rts          FTDI UART RTS
    input [15:0]
ftdi_cts          FTDI UART CTS
    output [15:0]
sd_spi_miso       SD CARD Master In Master Out SPI
    input [15:0]
sd_spi_mosi       SD CARD Master Out Master In SPI
    output [15:0]
sd_spi_csn        SD CARD Chip Select SPI
    output [15:0]
sd_spi_sclk       SD CARD clock SPI
    output [15:0]
```

## **inst\_clk\_wiz\_1**

---

Generate system clocks

## **inst\_ddr\_rstgen**

---

Generate DDR Reset

## **inst\_sys\_rstgen**

---

Generate general system resets

## **inst\_cpu\_rstgen**

---

Generate general system resets

## **inst\_axi\_ddr\_ctrl**

---

AXI DDR Controller, 200 MHz in for 50 Mhz out (200/4 = 50).

## **inst\_system\_ps\_wrapper**

---

Wraps all of the RISCV CPU core and its devices.