A Network Generator for FlooNoC
Project description
FlooGen: The NoC Generation Framework
FlooGen is the Python-based configuration and generation framework bundled with FlooNoC. While FlooNoC provides the efficient hardware IP blocks (mainly routers and network interfaces), FlooGen acts as the system architect that assembles them into a functional Network-on-Chip.
It transforms a high-level, human-readable description of your network (topology, routing rules, protocols) into fully connected, verified, and synthesizable SystemVerilog RTL.
Why use a Generator?
Designing a Network-on-Chip manually is tedious and error-prone. Connecting hundreds of router ports, calculating deadlock-free routing tables, and maintaining consistent global address maps becomes unmanageable as system complexity grows.
FlooGen solves this by raising the abstraction level. Instead of writing Verilog wire connections, you define endpoints, routers and their connections. FlooGen handles the low-level implementation details, ensuring that:
- Protocol conversion: Network interfaces are automatically instantiated to bridge different endpoint protocols to the NoC link protocol.
- Routing is correct: Paths are calculated automatically based on the topology.
- Configuration is consistent: Address maps and endpoint IDs are allocated globally without overlaps.
Key Capabilities
- Topology Agnostic: Generate standard topologies (Mesh, Ring, Tree) or completely custom irregular graphs based on your system constraints.
- Automatic Routing: Built-in engines to calculate routing tables for different routing algorithms.
- Protocol Abstraction: Define endpoints using high-level protocols (e.g., AXI4). FlooGen automatically manages the conversion to the internal NoC link protocol.
- Network Visualization: Generate visual graphs of your network topology to inspect connections and routing paths before simulation.
- Validation: The internal graph model checks for errors such as overlapping address regions, isolated nodes, or invalid port assignments before a single line of RTL is generated.
The Generation Flow
FlooGen operates in four distinct stages to turn your configuration into hardware:
- Parse & Elaborate: Reads the YAML configuration file to understand the requested nodes, links, and system parameters.
- Graph Construction: Builds an internal Network Graph representation of the system.
- Routing & Mapping:
- Runs routing algorithms on the graph.
- Allocates Endpoint IDs.
- Computes the global system address map.
- Render: Generates the final SystemVerilog code using validated templates.
Generated Artifacts
When you run FlooGen, it produces two primary outputs:
- The NoC Top-Level (
floo_<name>_noc.sv): A structural SystemVerilog module that instantiates all routers and network interfaces and connects them according to the topology. - The NoC Package (
floo_<name>_noc_pkg.sv): A SystemVerilog package containing all the necessary metadata, including:- Typedefs for flits and links.
- Routing tables and rules.
- System address maps and endpoint ID enumerations.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file floogen-0.8.0.tar.gz.
File metadata
- Download URL: floogen-0.8.0.tar.gz
- Upload date:
- Size: 43.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.1 {"installer":{"name":"uv","version":"0.11.1","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ddc9d1a4e971e0414b8bb076abd917cbe1bf6da2d0b5f8af08f87a5de3c3a966
|
|
| MD5 |
5757626e061fc418feee34dc6c61f5ac
|
|
| BLAKE2b-256 |
7612b25d1a561b86f5e3d4522197089d065d7c81076f6fe758aa7a9fb6277730
|
File details
Details for the file floogen-0.8.0-py3-none-any.whl.
File metadata
- Download URL: floogen-0.8.0-py3-none-any.whl
- Upload date:
- Size: 61.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.1 {"installer":{"name":"uv","version":"0.11.1","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
089bfb492d009714bb98de3744a6961140fbe3fa412f2d7488e52592d7ca5fca
|
|
| MD5 |
bf220e32f0466e8947ff0510b96c9660
|
|
| BLAKE2b-256 |
764b03506e966eff81e89cc0d0dc7003bb08612c7b92d85cf152cde5bc69f798
|