-
Notifications
You must be signed in to change notification settings - Fork 401
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[WIP] Tileable Routing Resource Graph Builder #2135
Open
tangxifan
wants to merge
516
commits into
master
Choose a base branch
from
openfpga
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
github-actions
bot
added
libarchfpga
Library for handling FPGA Architecture descriptions
libvtrutil
VPR
VPR FPGA Placement & Routing Tool
labels
Aug 16, 2022
github-actions
bot
added
external_libs
build
Build system
lang-make
CMake/Make code
labels
Sep 26, 2022
github-actions
bot
added
infra
Project Infrastructure
scripts
Utility & Infrastructure scripts
lang-shell
Shell scripts (bash etc.)
libpugiutil
labels
Aug 27, 2023
…orting multiple ptc
Add bend wires
[WIP] VIB Upgrades for Tileable Routing Resource Graph on OpenFPGA
…-routing into openfpga
…to-routing into openfpga
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Labels
build
Build system
docs
Documentation
external_libs
infra
Project Infrastructure
lang-cpp
C/C++ code
lang-make
CMake/Make code
lang-netlist
lang-shell
Shell scripts (bash etc.)
libarchfpga
Library for handling FPGA Architecture descriptions
libpugiutil
libvtrutil
scripts
Utility & Infrastructure scripts
VPR
VPR FPGA Placement & Routing Tool
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
Bring the tileable routing resource graph builder from OpenFPGA to VPR.
Full details about the tileable routing resource graph builder can be found at
X. Tang, E. Giacomin, A. Alacchi and P. Gaillardon, "A Study on Switch Block Patterns for Tileable FPGA Routing Architectures," 2019 International Conference on Field-Programmable Technology (ICFPT), 2019, pp. 247-250, doi: 10.1109/ICFPT47387.2019.00039.
fpt2019_final.pdf
https://ieeexplore.ieee.org/document/8977869
Related Issue
Motivation and Context
The tileable routing resource graph builder is an alternative routing resource graph builder than the existing one in VTR.
Being compatible with existing data structures (RRGraphView and RRGraphBuilder), this new feature enables VTR to support FPGA devices created by OpenFPGA.
User Interface
The tileable routing resource graph builder can be enabled through XML syntax in architecture description langauge
The tileable rr_graph generator also supports mixed switch block pattern: The wires which start and end in a switch block have a switch bock pattern, while the wires which pass through a switch block can have another switch block pattern.
SIGSTKSZ
in libcatch2 which is not supported in Ubuntu 21.04+VTR_ENABLE_VERSION
(by default is on), which allows developers to skip version build when integrating VTR as a submoduleis_real_param()
in read_blif.cpp (borrowed from another feature branch of Antmicro)Known Limitations
Checklist
Bugs/Issues found
num_class
intype_descriptor
is not used. It is always set to 0 regardless the list size ofclass_inf
. Suggest to remove it.resize_node()
. It may mistakenly resetnode_lookup()
when calling it incrementally. When callingreserve_node
to pre-allocate memory, such bugs can be bypassed.--write_block_usage
is enabled, the block usage is only shown instd:cout
or an external file. As a result, the information is not included in thevpr_stdout.log
since it is not usingVTR_LOG
vtr-verilog-to-routing/vpr/src/base/ShowSetup.cpp
Lines 174 to 179 in 50b56f3
How Has This Been Tested?
Here are a list of regression tests to added, in order to support existing features/options in customizing routing resource graphs.
Types of changes
Checklist: