Skip to content

KULeuven-MICAS/HeMAiA

This branch is 125 commits ahead of, 8 commits behind pulp-platform/occamy:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

2976df3 · Apr 3, 2025
Mar 18, 2025
Sep 3, 2024
Apr 1, 2025
Apr 3, 2025
Apr 3, 2025
Aug 19, 2023
Aug 19, 2023
Aug 29, 2024
Mar 25, 2024
Nov 25, 2024
Apr 1, 2025
Dec 7, 2020
Jan 8, 2025
Nov 2, 2024
Mar 25, 2024
Aug 19, 2023
Aug 19, 2023

Repository files navigation

CI License

Occamy

This repository hosts the hardware and software for the Occamy system-on-chip and its generator. Occamy is a high-efficiency system-on-chip coupling a CVA6 Linux-capable manager core with a many-core accelerator for compute-intensive floating-point workloads, building on the Snitch cluster architecture. It is developed as part of the PULP project, a joint effort between ETH Zurich and the University of Bologna.

Getting Started

To get started, check out the getting started guide.

Content

What can you expect to find in this repository?

  • The Occamy system-on-chip generator and hardware sources.
  • A runtime and example applications for Occamy.
  • An RTL simulation environment for Questa Advanced Simulator.

This code was previously hosted in the Snitch monorepo and was spun off into its own repository to simplify maintenance and dependency handling. The Snitch cluster, on which the Occamy accelerator is based upon, has also moved to its own repo.

License

Occamy is being made available under permissive open source licenses.

The following files are released under Apache License 2.0 (Apache-2.0) see LICENSE:

  • sw/
  • util/

The following files are released under Solderpad v0.51 (SHL-0.51) see hw/LICENSE:

  • hw/

Getting start for SNAX platform simulation & prototyping

⚠️Tips: All commands is made at the root dir of the Occamy repo.

Prototype the system on FPGA:

Option 1: Occamy configuration on VCU128 (Bootrom and DRAM from Xilinx IP)

@ SNAX Docker: make bootrom CFG_OVERRIDE=target/rtl/cfg/...
@ SNAX Docker: make sw
@ SNAX Docker: make -C target/fpga/sw [APP=???] (Which binary file you want to use)
@ SNAX Docker: make rtl CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make occamy_system_vivado_preparation
@ Barnard3: make occamy_system_vcu128
@ Barnard3: make occamy_system_vcu128_gui

Option 2: HeMAiA configuration on VPK180 (Tapeout configuration, everything is internal)

@ SNAX Docker: make bootrom CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make sw CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make -C target/fpga/sw [APP=???] (Which binary file you want to use)
@ SNAX Docker: make rtl CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make hemaia_system_vivado_preparation TARGET_PLATFORM=[vpk180|vcu128]
@ Barnard3: make hemaia_system_vivado TARGET_PLATFORM=[vpk180|vcu128]
@ Barnard3: make hemaia_system_vivado_gui

Simulate the system:

Option 1: Simulate with Verilator

@ SNAX Docker: make bootrom CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make sw CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make rtl CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make occamy_system_vlt
@ SNAX Docker: target/sim/bin/occamy_top.vlt [Elf location] [--vcd]

Option 2: Simulate with Questasim

@ SNAX Docker: make bootrom CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make sw CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make rtl CFG_OVERRIDE=target/rtl/cfg/...hjson
@ SNAX Docker: make occamy_system_vsim_preparation
@ Barnard3: make occamy_system_vsim
@ Barnard3: target/sim/bin/occamy_top.vsim[.gui] [Elf location]

About

The warm and cozy house for SNAX Cluster 🏠

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Tcl 47.2%
  • Python 15.7%
  • C 13.5%
  • Smarty 10.0%
  • Makefile 6.6%
  • SystemVerilog 4.2%
  • Other 2.8%