

# *Integrating Bit-Serial SERV Core with Chipyard for Scalable, Ultra- Compact RISC-V SoCs*

Project Supervisor: Engr. Mehmoona Gul

Co-Supervisor: Dr. Aneesullah

Presented by: Humail Nawaz and Ayesha Qazi

June 30, 2025

# CONTENTS



# PROBLEM STATEMENT

Chipyard is a powerful SoC design framework, but it lacks compact, low-power cores, limiting its use in minimalist or energy-efficient systems. SERV, a bit-serial RISC-V core and the world's smallest, offers extreme area and power efficiency but uses the Wishbone protocol, which is incompatible with Chipyard's TileLink infrastructure. This project bridges that gap by adapting SERV through protocol translation and integration, enabling its use as a functional tile in Chipyard and expanding the framework's capability to support ultra-lightweight SoC designs.



# RECAP



# COMPATIBILITY CHALLENGES

Integrating SERV into Chipyard involved addressing multiple compatibility issues across communication protocols, design languages, and system architecture.

01

Being minimal, SERV does not expose interfaces. Wrappers were needed to expose Wishbone signals and enable peripheral connections

02

SERV uses the Wishbone protocol, while Chipyard relies on TileLink. The two protocols are structurally different, requiring a translation bridge.

03

SERV is implemented in Verilog, whereas Chipyard is built in Chisel/Scala. This required using BlackBoxes to connect the Verilog core to the Chisel-based SoC.



# Protocol Conversion

To enable communication between the Wishbone-based SERV core and Chipyard's TileLink ecosystem, a custom bidirectional protocol bridge was developed. This bridge translates between Wishbone and AXI4, and then Chipyard's standard adapters handle conversion between AXI4 and TileLink.

01

The bridge supports both Wishbone-to-AXI and AXI-to-Wishbone communication, enabling reads and writes from either side.

02

The conversion logic is implemented using finite state machines that track handshakes, strobes, and response signals for both protocols.

03

Signals from SERV are translated into AXI read/write transactions. AXI accesses from peripherals or the system bus are converted into Wishbone-compatible signals.

04

Designed to be modular and reusable, the bridge can support other Wishbone-based components with minimal modifications.





# AXI - WB

The AXI-to-Wishbone side of the bridge was verified by issuing AXI read and write transactions and observing correct translation into Wishbone signals.





# WB - AXI

Write verification from Wishbone to AXI was limited due to SERV design constraints, not the bridge itself; read operations and signal behavior confirm correct bridge functionality.



# BRIDGE CONNECTED TO SERVING

This diagram illustrates the bidirectional communication path between the bridge and the Serving. The bridge directly interfaces with the SERV core's Wishbone bus, enabling seamless AXI-to-Wishbone transactions for both read and write operations.



# AXI-SERVING WRITE

## Write Transaction:

This diagram illustrates a successful AXI write sequence routed through the AXI2Serving bridge. It shows the address (AW channel) and data (W channel) phases, followed by the write response (B channel), indicating a properly acknowledged write to the SERV core.



# AXI-SERVING READ

**Read Transaction:**  
This waveform demonstrates a successful AXI read operation to the SERV core via the AXI2Serving bridge. It highlights the address handshake (AR channel), the valid data response (R channel), and the coordination between AXI signals and SERV's Wishbone interface.



## Serving RAM

Comines register file, Instruction and Data Memory

## INTERFACE

Routes Wishbone access to register file or memory.

## SERVILE

### MUX

### ARBITER

### INTERFACE

## CPU

Bit-serial RV32I RISC-V processor core.  
Executes one bit per cycle for ultra-low area usage.

## SERVING

Wishbone - AXI

Wishbone - AXI

## Protocol Conversion Bridge

# INTEGRATION PROCESS

01

## BlackBox Wrapping

The complete SERV+Bridge design was wrapped in a Verilog BlackBox, allowing Chipyard's Chisel/Scala flow to reference the external Verilog module.

02

## Defining the Core & Tile

Created ServTile.scala, following Chipyard's structure. This defines the core's interface and its encapsulation in a tile.

03

## AXI-TileLink Conversion

Used Chipyard's AXI4ToTL and TLToAXI4 adapters to connect the AXI interface of the bridge to the TileLink system bus.

04

## Parameter & Config Setup

Added a ServConfigs and ConfigMixins to make the tile selectable in Chipyard's build system.

05

## Build Hookup

Linked the tile, configs, & blackbox in build.sbt and Makefiles to enable successful build with make CONFIG=ServConfig.



# BlackBoxes

## 01 BlackBox Wrapper in Scala

A BlackBox class was created in ServBlackBox.scala, mapping ports to the Verilog module and specifying the file.

## 02 Verilog Source Linking

All Verilog files (serving.v, servile.v, bridge files, etc.) were placed under vsrc/ and referenced.

## 03 Build Configuration

build.sbt was updated to include these Verilog files so they're compiled and passed correctly during elaboration and Verilator simulation.

## 04 Result

The entire SERV+Bridge unit was successfully treated as a Verilog core within a Chisel-based SoC design.

# SERV TILE

## CORE CONFIGURATION

SERV is a minimal 32-bit RISC-V core optimized for area and power. It disables complex features like debug, FPU, and atomics. Its parameters include memory size, bit-width, and CSR support, focusing on ultra-lightweight embedded use.

## TILE SETUP

The SERV tile sets the core's position in the system, disabling caches and choosing simple clock crossings. It includes basic identifiers and resource declarations to integrate cleanly into RocketChip.

## CORE INTEGRATION

ServTile instantiates the core, connects clock/reset/IRQs, and wraps it for TileLink compatibility. It uses ServTileModuleImp to handle interfacing and sets up device entries for system-level recognition.

## INTERCONNECTS

SERV uses an AXI4 master interface, converted to TileLink via adapters like AXI4ToTL. Though a slave port exists, it's unused. This setup lets the simple SERV core work within the full Chipyard fabric.





# BUILD FLOW



# RESULTS AND ACHIEVEMENTS

SERV Device Tree inside Chipyard:

```
1 /dts-v1/;
2
3 / {
4     #address-cells = <1>;
5     #size-cells = <1>;
6     compatible = "ucb-bar,chipyard-dev";
7     model = "ucb-bar,chipyard";
8     L3: aliases {
9         serial0 = &L25;
10    };
11    L17: chosen {
12        stdout-path = &L25;
13    };
14    L2: cpus [
15        #address-cells = <1>;
16        #size-cells = <0>;
17        timebase-frequency = <500000>;
18        L12: cpu@0 {
19            clock-frequency = <32000000>;
20            compatible = "OlofKindgren,serv", "riscv";
21            device_type = "cpu";
22            hardware-exec-breakpoint-count = <0>;
23            next-level-cache = <&L10>;
24            reg = <0x0>;
25            riscv,isa = "rv32izicsr_zifencei_zihpm";
26            status = "okay";
27            timebase-frequency = <500000>;
28            L11: interrupt-controller {
29                #interrupt-cells = <1>;
30                compatible = "riscv,cpu-intc";
31                interrupt-controller;
```

# SERV Core Successfully Registered in Chipyard's Core List

```
Terminal 14:12 23 Oct u20@u20-VirtualBox: ~/chipyard/sims/verilator
u20@u20-VirtualBox: ~/chipyard/sims/verilator$ make CONFIG=ServConfig
Running with RISCV=/home/u20/chipyard/.conda-env/riscv-tools
echo "Checking all submodules in generators/ are initialized. Uninitialized submodules will be displayed" ; ! git submodule status /home/u20/chipyard/generators | grep ^-
Checking all submodules in generators/ are initialized. Uninitialized submodules will be displayed
mkdir -p /home/u20/chipyard/.classpath_cache/
cd /home/u20/chipyard && java -jar /home/u20/chipyard/scripts/sbt-launch.jar -Dsbt.ivy.home=/home/u20/chipyard/.ivy2 -Dsbt.global.base=/home/u20/chipyard/.sbt -Dsbt.boot.directory=/home/u20/chipyard/.sbt/boot/ -Dsbt.color=always -Dsbt.supershell=false -Dsbt.server.forcestart=true ";project chipyard; set assembly / assemblyOutputPath := file(\"/home/u20/chipyard/.classpath_cache/chipyard.jar\"); assembly" && touch /home/u20/chipyard/.classpath_cache/chipyard.jar
Picked up JAVA_TOOL_OPTIONS: -Xmx8G -Xss8M -Djava.io.tmpdir=/home/u20/chipyard/.java_tmp
[info] welcome to sbt 1.8.2 (Temurin Java 1.8.0_345)
[info] loading settings for project chipyard-build from plugins.sbt ...
[info] loading project definition from /home/u20/chipyard/project
[info] loading settings for project chipyardRoot from build.sbt ...
[info] loading settings for project testchipip from build.sbt ...
[info] loading settings for project barf from build.sbt ...
[info] loading settings for project constellation from build.sbt ...
[info] loading settings for project icenet from build.sbt ...
[info] loading settings for project cva6 from build.sbt ...
[info] loading settings for project ibex from build.sbt ...
[info] loading settings for project serv from build.sbt ...
[info] loading settings for project sodor from build.sbt ...
[info] loading settings for project midas_target_utils from build.sbt ...
[info] resolving key references (47609 settings) ...
[info] set current project to chipyardRoot (in build file:/home/u20/chipyard/)
[info] set current project to chipyard (in build file:/home/u20/chipyard/)
[info] Defining assembly / assemblyOutputPath
[info] The new value will be used by assembly
[info] Reapplying settings...
[info] set current project to chipyard (in build file:/home/u20/chipyard/)

Warning: Tried to extract the base path for relative class tools/steps/src/main/resources/**/* from a config. To disable this warning, run the no
```

# Make successful resulting in SERV SoC Generation

```
u20@u20-VirtualBox: ~/chipyard/sims/verilator

stDriver_DigitalTop__DepSet_h33dfddee_40.o VTestDriver_DigitalTop__DepSet_h33dfddee_41.o VTestDriver_DigitalTop__DepSet_h33dfddee_42.o VTestDriver_DigitalTop__DepSet_h33dfddee_43.o VTestDriver_DigitalTop__DepSet_h33dfddee_44.o VTestDriver_DigitalTop__DepSet_h33dfddee_45.o VTestDriver_DigitalTop__DepSet_h33dfddee_46.o VTestDriver_DigitalTop__DepSet_h33dfddee_47.o VTestDriver_DigitalTop__DepSet_h33dfddee_48.o VTestDriver_DigitalTop__DepSet_h33dfddee_49.o VTestDriver_DigitalTop__DepSet_h33dfddee_50.o VTestDriver_DigitalTop__DepSet_h33dfddee_51.o VTestDriver_DigitalTop__DepSet_h33dfddee_52.o VTestDriver_TilePRCIDomain__DepSet_h1ad82fb8_0.o VTestDriver_TilePRCIDomain__DepSet_he4f7cd44_0.o VTestDriver_ServTile__DepSet_heec8f299_0.o VTestDriver_ServTile__DepSet_hc194396d_0.o VTestDriver_ServTile__DepSet_hc194396d_1.o VTestDriver_ServCore_Mz9_S1_Ac__DepSet_hf425de53_0.o VTestDriver_serving_MB2000_S1_R4d494e49__DepSet_h9bbebe1f_0.o VTestDriver_serving_MB2000_S1_R4d494e49__DepSet_h6efd994e_0.o VTestDriver_serving_ram__D2000__DepSet_h9ec8da9c_0.o VTestDriver_serving_ram__D2000__DepSet_h73cf75cf_0.o VTestDriver_main.o VTestDriver_Dpi.o VTestDriver_ConstPool_0.o VTestDriver__024root__Slow.o VTestDriver__024root__DepSet_h662e1026_0__Slow.o VTestDriver__024root__DepSet_hbb6e3b65_0__Slow.o VTestDriver_TestDriver__Slow.o VTestDriver_TestDriver__DepSet_h7cf3db4e_0__Slow.o VTestDriver_TestDriver__DepSet_he152682f_0__Slow.o VTestDriver__024unit__Slow.o VTestDriver__024unit__DepSet_h44496666_0__Slow.o VTestDriver_TestHarness__Slow.o VTestDriver_TestHarness__DepSet_hff67d21a_0__Slow.o VTestDriver_TestHarness__DepSet_ha45bb60e_0__Slow.o VTestDriver_ChipTop__Slow.o VTestDriver_ChipTop__DepSet_h09ff5f7a_0__Slow.o VTestDriver_ChipTop__DepSet_hca3ac016_0__Slow.o VTestDriver_DigitalTop__Slow.o VTestDriver_DigitalTop__DepSet_hd9c8db9a_0__Slow.o VTestDriver_DigitalTop__DepSet_hd9c8db9a_1__Slow.o VTestDriver_DigitalTop__DepSet_hd9c8db9a_2__Slow.o VTestDriver_DigitalTop__DepSet_hd9c8db9a_3__Slow.o VTestDriver_DigitalTop__DepSet_hd9c8db9a_4__Slow.o VTestDriver_DigitalTop__DepSet_hd9c8db9a_5__Slow.o VTestDriver_DigitalTop__DepSet_hd9c8db9a_6__Slow.o VTestDriver_DigitalTop__DepSet_hd9c8db9a_7__Slow.o VTestDriver_DigitalTop__DepSet_h33dfddee_0__Slow.o VTestDriver_TilePRCIDomain__Slow.o VTestDriver_TilePRCIDomain__DepSet_h1ad82fb8_0__Slow.o VTestDriver_TilePRCIDomain__DepSet_he4f7cd44_0__Slow.o VTestDriver_ServTile__Slow.o VTestDriver_ServTile__DepSet_heec8f299_0__Slow.o VTestDriver_ServTile__DepSet_hc194396d_0__Slow.o VTestDriver_ServCoreBlackbox_Ac_S1__Slow.o VTestDriver_ServCoreBlackbox_Ac_S1__DepSet_h6be5b1c3_0__Slow.o VTestDriver_ServCore_Mz9_S1_Ac__Slow.o VTestDriver_ServCore_Mz9_S1_Ac__DepSet_hf2203fa4_0__Slow.o VTestDriver_serving_MB2000_S1_R4d494e49__Slow.o VTestDriver_serving_MB2000_S1_R4d494e49__DepSet_h9bbebe1f_0__Slow.o VTestDriver_serving_MB2000_S1_R4d494e49__DepSet_h6efd994e_0__Slow.o VTestDriver_serving_ram__D2000__Slow.o VTestDriver_serving_ram__D2000__DepSet_h73cf75cf_0__Slow.o VTestDriver__Syms.o VTestDriver__Syms_1.o VTestDriver__Syms_2.o
/home/u20/chipyard/.conda-env/bin/x86_64-conda-linux-gnu-c++    SimDRAM.o SimJTAG.o SimTSI.o SimUART.o mm.o mm_dramsim2.o remote_bitbang.o testchip_htif.o testchip_tsi.o uart.o verilated.o verilated_dpi.o verilated_vpi.o verilated_timing.o verilated_threads.o VTestDriver_ALL.a -L/home/u20/chipyard/.conda-env/riscv-tools/lib -Wl,-rpath,/home/u20/chipyard/.conda-env/riscv-tools/lib -L/home/u20/chipyard/sims/verilator -L/home/u20/chipyard/tools/DRAMSim2 -lriscv -lfesvr -ldramsim -pthread -lpthread -latomic -o /home/u20/chipyard/sims/verilator/simulator-chipyard.harness-ServConfig
rm VTestDriver_ALL.verilator deplist.tmp
make[1]: Leaving directory '/home/u20/chipyard/sims/verilator/generated-src/chipyard.harness.TestHarness.ServConfig/chipyard.harness.TestHarness.ServConfig'
(/home/u20/chipyard/.conda-env) u20@u20-VirtualBox:~/chipyard/sims/verilator$
```



# IMPROVEMENT AND FUTURE WORK

All tasks are targeted for completion before the FYP Exhibition. However, even without these additions, the integration of SERV as a functioning tile in Chipyard marks the successful completion of the core objective.

01

We aim to connect SERV as a memory-mapped peripheral using an AXI4 slave interface, enabling external masters to communicate directly with the core.

02

Plan to support ELF binary loading into SERV's internal memory through Verilator simulation using Front-End Server (FESVR), as in Chipyard's communication mechanisms.

03

Explore performance benchmarking or RTL-level power analysis of the SERV core inside Chipyard.

# CONCLUSION

**This project marks the successful hybridization of the SERV bit-serial RISC-V core with the Chipyard SoC ecosystem, showcasing that even the most compact cores can be brought into advanced design environments.**

Verified core functionality through Verilator simulation and waveform inspection, confirming correct instruction execution. Demonstrated that minimalist processors like SERV can coexist with robust SoC ecosystems, paving the way for ultra-low power applications. This work sets a foundation for future expansion, including memory-mapped peripherals, ELF-based program loading, and custom system designs.