FOSSi Foundation is applying as an umbrella organization for Google Summer of Code 2025. That means that we give FOSSi community projects the chance to participate in the program. Below you can find a list of ideas that community mentors had, but mentees are encouraged to propose their own ideas. These projects are mostly open-ended and can be tailored to your level of experience, assuming that you have the appropriate set of required skills for the particular project idea.
Whether you’re an aspiring mentee or mentor, feel free to contact us, either (for mentees) by directly contacting mentors or (for mentors) through the private GSoC-specific mailing list gsoc@fossi-foundation.org.
Looking forward to meet you all!
ZynqParrot RISC-V Tracer
ZynqParrot (https://github.com/black-parrot-hdk/zynq-parrot) is a framework for doing self-contained, FPGA-based "hostless" ASIC accelerator development. It is designed to be extremely general and has been used to prototype IP from individual ASIC/FPGA cores to full multicore processors. In addition, ZynqParrot has been used to bringup N=1 ASIC silicon in the lab.
RISC-V provides a trace format specification (https://github.com/riscv-non-isa/riscv-trace-spec) which can be used for diagnostic performance and debugging. This project will design and integrate a RISC-V Trace implementation into the ZynqParrot environment, requiring SystemVerilog implementation + testing, Block Diagram (Vivado IPI) design and well as writing C++ driver to work in both Co-Simulation and Co-Emulation.
Skill level: intermediate
Project length: medium (175 hours)
Mentors: Dan Petrisko
Language/Tools: SystemVerilog, C++, some knowledge of computer architecture. RISC-V knowledge preferred but not required. FPGA tools such as Vivado strongly encouraged but not required.
Surfer memory and wide array support
Surfer (https://surfer-project.org) is an open source waveform viewer designed to be snappy and extensible. Waveform viewers work well for visualizing individual signals, but for large arrays or memories users are often more interested in changes to individual elements rather than the whole array.
For this, a separate UI element where memory content can be visualized as a table would be much more useful. Beyond just visualizing the content, also having the ability to highlights elements that have changed between timestamps or around the cursor would be extra useful.
Skill level: intermediate
Project Length: medium (175 hours)
Mentors: Frans Skarman Oscar Gustafsson
Languages/Tools: Rust. Familiarity with hardware design is helpful to have some context of what the tool is used for is helpful, but the project itself is pure software. Some familiarity with egui is also helpful though certainly not required.
TL-Verilog Editor Modes
Details: TL-Verilog has support in various editors, including VSCode, GitHub, and CodeMirror (used by Makerchip). But all three could use a refresh and improvements. Grammar improvements are needed in TextMate (currently used by VSCode and GitHub), and Tree-sitter support is desired for future use in GitHub and CodeMirror.
175-hr or 350-hr projects are possible. A 175-hr project could focus on improving the existing GitHub TL-Verilog mode (which is rather broken). A 350-hr project might focus on a new grammar. A long project might also add support for the macro-preprocessor used by TL-Verilog (M5) or for JavaScript embedded in TL-Verilog.
Skill level: Medium
Language/Tools: JavaScript
Duration: 175 or 350 hrs
Repo: https://github.com/github-linguist/linguist/pull/5331/files
Mentor: Steve Hoover
cocotb v2 Code Migration Helper
The upcoming cocotb v2.x release will have quite some breaking changes (see https://docs.cocotb.org/en/latest/release_notes.html), so users and extension developers will have to actively migrate existing code.
A code migration helper tool would be helpful, even if it is not perfect.
Some links:
Skill level: Intermediate/Advanced
Duration: medium (175 hours)
Language/Tools: Python, cocotb
Mentor: Kaleb Barrett
Generate Counter Examples for Bounded Model Checks in CIRCT
The CIRCT project has its own bounded model checking tool, circt-bmc. It takes a hardware design described in CIRCT's MLIR dialects and translates it into a program that uses the Z3 SMT solver to formally prove assertions. If it finds a way how assertions can be violated, it simply terminates with an error message. This is not very useful for a user that is trying to debug a hardware design that they have written. Instead, we would like circt-bmc to produce a counter-example, essentially a signal trace that shows and example of how the assertions can be violated. The Z3 SMT solver actually provides a counter-example as part of its checking, circt-bmc just does not use that yet.
We would love you to extend circt-bmc with a counter-example feature that produces a signal trace for violated assertions, ideally a VCD waveform as a starting point. This will require you to modify the lowering pass that translates a hardware design to Z3 solver calls: in addition to the asserts that need to be checked, you will also want to translate any named ports, wires, registers into the corresponding Z3 solver expressions. The bounded model check can then take a snapshot of all these expressions in every time step. When Z3 finds a counter-example, you can go through every time step, evaluate all the solver expression for all user-visible names, and write them to a waveform.
This may also be an excellent opportunity to introduce a waveform writing library for CIRCT. Eventually, we'd want different tools in CIRCT to be able to write various waveform formats such as VCD, FST, etc. It would be great if there is a common interface for waveform writers, and if CIRCT could then provide various implementations for different waveform formats. Tools like Arcilator, circt-bmc, and circt-lec would then use this library to produce signal traces.
CIRCT is based on MLIR and LLVM, and are implemented in C++. So you'll definitely want to have some experience writing C++ code, since LLVM-based projects often follow a fairly peculiar and performance-conscious style of C++. You may also benefit from knowing a little bit about SAT and SMT solvers, and how bounded model checks can be implemented incrementally using these solvers.
Skill Level: Medium
Duration: 175 hours or 350 hours
Language/Tools: C++, CIRCT, MLIR, LLVM
Mentor: Fabian Schuiki, Martin Erhart, and others in the CIRCT community
Spike + Sim-X
The project is to interface Spike with Sim-X. Spike is a functional RISC-V ISA simulator and Sim-X is a high-level simulator for the Vortex GPGPU.
Existing work allowed us to integrate the Vortex GPGPU RTL in the OpenPiton multi-core research platform (https://cea.hal.science/cea-04772235/document). To ease programming though, we would like to test software correctness using a high-level simulator. It would be faster than relying on RTL simulation. Interfacing Spike with Sim-X would allow us to simulate functionaly our heterogeneous CPUs+GPU shared-memory architecture, hence allowing us to ease future software development.
Skill level: Intermediate
Duration: medium (175 hours)
Language/Tools: C++, RISC-V GNU Cross-compiler, Vortex LLVM compiler
Mentor: Davy Million
OpenRISC Linux Feature Development
The OpenRISC Linux kernel support is under constant development but there are certain Linux facilities that are not yet used or available on the OpenRISC platform.
This project will have the student developing, testing and sending patches up to the Linux kernel. This includes:
- Use the cacheinfo API for reporting CPU details in OpenRISC Linux.
- Add tracing facilities to OpenRISC Linux including: jump_label, ftrace, kprobes, eBPF etc.
Skill level: Advanced
Project Length: large
Language/Tools: Linux, C, Assembly, OpenRISC architecture
Mentor: Stafford Horne
Generic MinimumLinuxBoot for RTL Simulations
This project consists of booting Linux in Qemu, save the memory state, thencontinue the simulation in an RTL Simulation of OpenPiton. The first part of the project consists of understanding what states need to be saved, probably a combination of the TLB and MMU states as an starting point could be enough. Then, this state needs to be saved in a file format that the checkpoint mechanism of Verilator understand or create a synthetic benchmark that makes the proper MMU configuration. The second part of the project is adding the necessary support in OpenPiton Simulation infrastructure to continue the simulation and being able to launch some applications.
OpenPiton uses different languages like Verilog, Python, Perl, and C. Verilator C++. Additionally, some background in hardware design is useful.
Skill Level: Medium/Advanced
Duration: 350 hours
Language/Tools: Verilog, C++, SystemVerilog
Mentors: Guillem López Paradís and Jonathan Balkind
Using AI to Improve Open-Source IP
What if we could instantly improve all the existing open-source Verilog by reducing its size, improving its maintainability, making it more configurable, identifying bugs, and creating visualization for it? How could you possibly do all those things over one summer as a student? Well, you can't. But you could help to make significant strides in that direction.
Transaction-Level Verilog (TL-Verilog) models are smaller, cleaner, and less bug-prone than their Verilog counterparts. But there's not much TL-Verilog in the wild yet. If you ask ChatGPT to convert your code today, you won't be happy with the results. But with careful coaching, AI models can be trained for the job.
Since LLMs understand Verilog better than TL-Verilog, we do as much as possible with the Verilog to prepare it for conversion to TL-Verilog. An initial flow has been put in place for this. A Python program iterates through a recipe of prompts, each performing an incremental refactoring step. After each step, formal equivalence verification (FEV) is used to ensure functional correctness. Human intervention is possible and is currently needed at almost every step.
Your project will be to use and enhance this flow to refactor an open-source Verilog project like SERV. In the process, you'll contribute to the automation, and your work will become training data to improve future LLMs for this task.
Skill level: Intermediate/Advanced
Duration: 350 hours
Language/Tools: Verilog, Python, TL-Verilog
Repo: https://github.com/stevehoover/conversion-to-TLV
Mentor: Steve Hoover
Metro-MPI++
Metro-MPI is a generic methodology to distribute RTL simulation and unlock SoCs’ inherent parallelism. We partition well-defined blocks within designs into isolated simulation processes that communicate via MPI message passing. Metro-MPI works particularly well with replicated blocks of comparable size, such as manycores with NoCs. Verilator is an open-source Verilog simulator and linting tool that translates Verilog HDL code into optimized C++ or SystemC code, allowing for fast, cycle-accurate simulation of digital circuits.
Automatic partitions with Metro-MPI We want to add the automatic support of metro-MPI inside other tools, like Verilator or Essent. The idea would be to detect the top modules that are suitable to be interfaced with metro-MPI. An automatic partition algorithm would be ideal although we can start with a user-guided approach like pragmas. The project will be divided into two big milestones: the initial task is to use the methodology from Metro-MPI to speed up the simulation (e.g. using messages with MPI to communicate between partitions); the second task would be to influence the partitions of the design to ease the usage of MPI between them.
Metro-MPI @FPGA We would like to explore the same methodology that Metro-MPI introduces but to connect multiple FPGAs with MPI.
We are also open to other improvements on metro-MPI:
- Explore the support of OpenMP instead of openMPI
- Explore making the simulations faster with statistical analysis: predict values that will take the MPI messages on a certain simulation, making checkpoints and rolling back in case of predicting wrong.
- Improve current Verilator support from v4 to v5.
- Scale Simulations up to 10K cores (currently we support up to 1024 cores)
Metro-MPI uses Verilog and C++. Additionally, some background in hardware design is useful.
Skill Level: Medium/Advanced
Duration: 350 hours
Language/Tools: C++, MPI, SystemVerilog
Mentors: Guillem López Paradís and Jonathan Balkind
OpenLane Web-based Graphical User Interface
Details: OpenLane is the premier open source RTL-to-GDSII flow. Versions 2.0 or higher's modular architecture allows for constructing complex flows using nodes called "steps," Users who are adept in Python can create many such complex flows, including flows that are parallel. A web-based GUI of some kind (based on a library such as ReactFlow https://reactflow.dev) would greatly enhance the ability of novice users to create custom OpenLane-based flows with ease.
Skill level: Beginner or Intermediate
Duration: 175 hrs.
Language/Tools:: TypeScript (React), Python
Mentor: Mohamed Gaber, Mohamed Shalan
LiteX SMP SoC for OpenRISC
The LiteX project makes creating FPGA-based SoCs easy. LiteX supports creating SoCs containing OpenRISC CPU cores. Up until now however, there have been no LiteX SoCs that support running OpenRISC multicore/SMP Linux. The linux-on-litex-vexrisc project provides a good example of how to develop and document getting Linux up and running on a LiteX SoC; including multicore.
Using linux-on-litex-vexrisc
as an example, this project will have the student
creating a project to help people get up and running with OpenRISC. The final
goal shall be to have a documented multicore OpenRISC LiteX SoC running Linux
SMP.
Skill level: Advanced
Project Length: large
Language/Tools: Verilog, LiteX, Linux, Python, OpenRISC architecture
Mentor: Stafford Horne
Improve CIRCT's Verilog Frontend
The CIRCT project uses the Slang frontend to parse the SystemVerilog hardware description language. The sv-tests project runs many SystemVerilog frontends on a benchmark suite of input files to test their quality. We would love you to use the sv-tests results as a starting point to find key missing features that you can add to circt-verilog
and fix failing tests. Tests often fail for similar reasons, and fixing small things can cause large numbers of tests to start passing.
SystemVerilog is a complicated language and CIRCT builds a deep stack of intermediate representations using MLIR to process it. The Slang frontend produces an Abstract Syntax Tree which the ImportVerilog pass converts into the Moore dialect, the first IR level in circt-verilog. Various optimizations are already performed at this level. Then the MooreToCore conversion pass lowers the Moore dialect to the HW, Comb, Seq, and LLHD dialects for further processing. Finally, several optimization passed implemented on the LLHD dialect analyze the hardware design and detect common structures. If you want to sink your teeth into compiler and IR design, this is the perfect project for you!
Slang and CIRCT are based on MLIR and LLVM, and are implemented in C++. So you'll definitely want to have some experience writing C++ code, since LLVM-based projects often follow a fairly peculiar and performance-conscious style of C++.
Skill Level: Advanced
Duration: 175 hours or 350 hours
Language/Tools: C++, CIRCT, MLIR, LLVM
Mentor: Fabian Schuiki, Martin Erhart, and others in the CIRCT community
Architectural Improvements to OpenPiton+Ariane for RISC-V Profile Compliance
OpenPiton+Ariane is a permissively-licensed RISC-V manycore processor, built as a collaboration between the PULP Platform from ETH Zürich and the OpenPiton Platform from Princeton University. We would like to co-optimise OpenPiton and Ariane/CVA6 in their combined platform, to improve performance of the processor both in FPGA emulation systems and for eventual silicon chips. We are particularly interested in moving the platform toward RISC-V RVA23 profile compliance and so developing any new extension support needed for this purpose would be a great GSoC opportunity!
Skill level: Intermediate
Duration: 175 or 350 hours
Language/Tools: Verilog, SystemVerilog, RISC-V
Mentor: Jonathan Balkind, Nils Wistoff
Cohort++
Cohort is a framework designed to integrate hardware accelerators into software systems while maximizing efficiency seamlessly. It introduces Software-Oriented Acceleration (SOA), a paradigm that simplifies and optimizes interactions between software and hardware accelerators. By leveraging existing software abstractions—such as shared-memory queues—Cohort enables a streamlined, high-performance communication channel between software components and accelerators.
This project consists of improving the performance of OpenPiton memory hierarchy to better suit Cohort. For example, there is prior work on supporting wider NoCs, and cachelines in OpenPiton; we changing the Cohort engine's interaction with the coherence protocol; multiple MMU outstanding requests for higher performance.
We have other ideas to work more on Cohort software support and we are also open to new proposals. Some examples:
- Support for other data structures instead of only queues
- Connect the openMP and/or openMPI runtime library to use Cohort queues
- Add the support for PRGA to be used with Cohort
Skill Level: Medium/Advanced
Duration: 350 hours
Language/Tools: C++, SystemVerilog
Mentors: Guillem López Paradís , Davy Million and Jonathan Balkind
Seamless multi-frontend support for OpenLane
Details: OpenLane is the premier open source RTL-to-GDSII flow. Versions 2.0+ currently support handling multiple frontends for compilation:
- Yosys Default - Verilog
- Synlig - SystemVerilog
- GHDL - VHDL (x86-64-only)
However, in the cases of VHDL and Verilog specifically– there is no way to mix and match Verilog and VHDL in one design, for example, which is common when reusing IPs.
This task proposes a retool to OpenLane synthesis to, instead of having two
different flows (Classic
and VHDLClassic
), have one flow accepting a
heterogeneous list of files, which can then be inspected to determine the proper
frontend to be used.
The project may involve enhancements to one or more of the C++-based Yosys frontends, as well as the addition of more frontends for languages such as Chisel and Amaranth.
Skill level: Intermediate
Duration: 175 hrs.
Language/Tools: Python, Verilog, C++, Nix
Mentor: Kareem Farid, Mohamed Shalan
OpenRISC Benchmarking and Performance improvements
The OpenRISC CPU architecture has multiple CPU implementations including the mor1kx and marocchino. Recent testing has shown that memory access on the marocchino is slightly slower compared to the mor1kx.
This project will have the student:
- Continue from where the 2024 GSoC student left off.
- Use tools like the Embench modern benchmark suite to measure OpenRISC processor and compiler toolchain performance.
- Document the OpenRISC performance at Embench IoT results to be able to compare OpenRISC vs other popular CPUs.
- Track down and improve OpenRISC CPU performance by finding and fixing deficiencies in the verilog designed cores.
Skill level: Advanced
Project Length: large
Language/Tools: Verilog, Shell scripting, C, Assembly, Python
Mentor: Stafford Horne
OpenLane Flow Declaration GUI
Details: OpenLane is the premier open source RTL-to-GDSII flow. Versions 2.0 or higher's modular architecture allows for constructing complex flows using nodes called "steps."
Users who are adept in Python can create many such complex flows, including flows that may run multiple steps in parallel, but those who are not may face difficulty doing so.
A web-based GUI of some kind (based on a library such as ReactFlow https://reactflow.dev) would greatly enhance the ability of novice users to create custom OpenLane-based flows with ease.
Skill level: Beginner to Intermediate
Duration: 175 hrs.
Language/Tools:: TypeScript (React), Python
Mentor: Mohamed Gaber, Mohamed Shalan
Adding TL-Verilog Support to Surfer
Details: Surfer is a modern open-source waveform viewer that evolved alongside the Spade HDL. It has gained broader popularity beyond the Spade ecosystem, and adding support for other emerging HDL capabilities will benefit the community.
TL-Verilog models have higher-level knowledge that can be reflected in a waveform viewer to enhance the debugging experience. Most notably, TL-Verilog signals can be "invalid". Invalidity is, in some respects, similar to dont-care state. One distinction is that validity is compatible with two-state simulators, like Verilator.
This project will focus on two main features to enhance TL-Verilog waveforms in Surfer:
- Displaying TL-Verilog-style signal and hierarchy names in TL-Verilog standard colors.
- Reflecting validity on signal values.
These two features can currently be seen in the Makerchip IDE's waveform viewer.
Skill level: Medium/advanced
Language/Tools: Rust
Duration: 350 hrs
Repo: https://gitlab.com/surfer-project/surfer
Mentors: Frans Skarman (creator of Surfer and Spade), Oscar Gustafsson, Steve Hoover (creator of TL-Verilog & Makerchip)
Device-Under-Test Python Typing Stub Generator for cocotb tests
cocotb tests manipulate the signals of the Device-Under-Test (DUT) to verify the design, but what was the name of that signal I needed to wiggle???
If we had a Python typing stub for the DUT, we could get the Pylance VS Code extension to help us by listing the signals in the DUT in an autocomplete pop-up; we could use Python static type checkers like mypy to ensure we didn't fat-finger the name of some module; or use generated typing stubs to create abstract bus definitions that users could "mock out" when needed.
cocotb has existing DUT introspection capabilities that could be leveraged to generate Python typing stubs. However, existing features may not be enough, and additional features may need to be added, in addition to the generator itself. Perhaps even, this code could be set up for future use by a language server, like slang, to generate even more informative typing stubs.
See more information here.
Skill level: Beginner to Intermediate
Duration: medium (175 hours)
Language/Tools: Python, cocotb
Mentor: Kaleb Barrett
Visualizing Registers in Simulation
Details: PeakRDL is a free and open-source control & status register (CSR) generator toolchain that works from SystemRDL specifications. It has community-developed plugins that provide various output formats from the SystemRDL source for use in hardware simulation, verification, software simulation, and documentation as well as output to other specification formats. This project aims to create a new plugin category for simulation visualization.
The Makerchip.com platform provides a framework called "Visual Debug" (or VIZ) that uses the JavaScript Fabric.js library to visualize digital circuit simulations based on signal trace data in .vcd
format. This project aims to provide VIZ output to support visualization of CSR values in simulation. VIZ outputs can be supported for any target HDL and can be integrated with other VIZ code for the surrounding logic.
Skill level: Medium
Language/Tools: Python, JavaScript, PeakRDL, Makerchip
Duration: 350 hrs
Repo: https://github.com/SystemRDL/PeakRDL
Mentors: Alex Mykyta, Steve Hoover