-
Notifications
You must be signed in to change notification settings - Fork 311
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'private/master' into secure-gpl-avoid-t…
…d-during-rd
- Loading branch information
Showing
15 changed files
with
163 additions
and
80 deletions.
There are no files selected for viewing
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,117 @@ | ||
# Report on a design prior to setting up a configuration | ||
|
||
This configuration allows running synthesis and floorplan | ||
to extract some basic information useful when setting | ||
up a config.mk file from scratch. | ||
|
||
Below, instructions are given to run synthesis, floorplan, placement and | ||
global route, then examine the results in the GUI to see what a | ||
realistic floorplan and settings might be for your Verilog files. | ||
|
||
The example below uses the designs/src/aes/*.v Verilog files, but | ||
the Verilog files do not have to be located in the OpenROAD-flow-scripts | ||
git repository, adjust the VERILOG_FILES argument to point to your Verilog | ||
files: | ||
|
||
``` | ||
make DESIGN_CONFIG=designs/asap7/minimal/config.mk DESIGN_NAME=aes_cipher_top VERILOG_FILES="$(ls designs/src/aes/*.v | xargs)" clean_synth synth gui_synth | ||
``` | ||
|
||
Where, the exploratory config.mk file to be replaced | ||
by a design specific config.mk file is: | ||
|
||
``` | ||
DESIGN_CONFIG=designs/asap7/minimal/config.mk | ||
``` | ||
|
||
Verilog files that to be investigated are specified by: | ||
|
||
``` | ||
VERILOG_FILES="$(ls designs/src/aes/*.v | xargs)" | ||
``` | ||
|
||
The Verilog top module name is specified by: | ||
|
||
``` | ||
DESIGN_NAME=aes_cipher_top | ||
``` | ||
|
||
Synthesis cleaned and re-run by: | ||
|
||
``` | ||
clean_synth synth | ||
``` | ||
|
||
The GUI is opened by the makefile target: | ||
|
||
``` | ||
gui_synth | ||
``` | ||
|
||
## `make gui_synth` OpenROAD GUI information | ||
|
||
data:image/s3,"s3://crabby-images/e6c5a/e6c5af24872e3161e61b78170123b7ed4238c923" alt="Alt text" | ||
|
||
The module hierarchy can here be examined to give a sense of | ||
area required for the default placement density. | ||
|
||
## `make gui_floorplan` OpenROAD GUI information | ||
|
||
Next to iterate on floorplan settings: | ||
|
||
``` | ||
make DESIGN_CONFIG=designs/asap7/minimal/config.mk DESIGN_NAME=aes_cipher_top VERILOG_FILES="$(ls designs/src/aes/*.v | xargs)" clean_floorplan floorplan gui_floorplan | ||
``` | ||
|
||
A few more things can be learned from looking at this minimal floorplan: | ||
|
||
- The pins are placed randomly on the edges and at least there | ||
is enough space on the edges to fit the top level pins | ||
- Check that the floorplan size is not completely unreasonable and | ||
at least there is a chance that this design could go through | ||
placement with this density. | ||
|
||
data:image/s3,"s3://crabby-images/5be49/5be49c55eea05d3b93301015f4fef1f5298a80c8" alt="Alt text" | ||
|
||
## `make gui_place` OpenROAD GUI information | ||
|
||
Next to iterate on placement settings: | ||
|
||
``` | ||
make DESIGN_CONFIG=designs/asap7/minimal/config.mk DESIGN_NAME=aes_cipher_top VERILOG_FILES="$(ls designs/src/aes/*.v | xargs)" clean_place place gui_place | ||
``` | ||
|
||
data:image/s3,"s3://crabby-images/84775/847755c0e8e92fb4e97440e8cab32d819d291161" alt="Alt text" | ||
|
||
data:image/s3,"s3://crabby-images/b768e/b768ecc8ecc5a296d5b0263ffae810d3e4a31b98" alt="Alt text" | ||
|
||
From placement more information about how to set up the config.mk | ||
file can be learned: | ||
|
||
- Examine estimated routing congestion to get a sense if there | ||
is a chance that the design can be routed. | ||
- Get a sense of size and location of modules | ||
|
||
## CTS(Clock tree Synthesis) | ||
|
||
After placement, CTS (clock tree synthesis is run). However the minimal design does | ||
not have a clock, so CTS runs quickly, but does nothing. | ||
|
||
## `make gui_grt` OpenROAD GUI information | ||
|
||
For non-trivial designs, some more work will need to be done in floorplan and | ||
placement before there is a chance that global routing will complete: | ||
|
||
``` | ||
make DESIGN_CONFIG=designs/asap7/minimal/config.mk DESIGN_NAME=aes_cipher_top VERILOG_FILES="$(ls designs/src/aes/*.v | xargs)" clean_place place gui_place | ||
``` | ||
|
||
data:image/s3,"s3://crabby-images/455c4/455c48ecd4c3c7184239cee1c04406cd0737780e" alt="Alt text" | ||
|
||
Global routing congestion heatmap can be examined in the GUI. | ||
|
||
## Next steps | ||
|
||
Start creating a config.mk file for your design, write an .sdc file to | ||
examine timing and find reasonable values for the CORE_UTILIZATION | ||
and PLACE_DENSITY for your design considering routing congestion. |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
export DESIGN_NICKNAME = minimal | ||
export SDC_FILE = $(FLOW_HOME)/designs/asap7/minimal/empty.sdc | ||
export PLATFORM = asap7 | ||
# Faster build and more information in GUI with hierarchical synthesis | ||
export SYNTH_HIERARCHICAL ?= 1 | ||
# Keep all modules so we can examine the full hierarchy | ||
export MAX_UNGROUP_SIZE ?= 0 | ||
|
||
# Set the core utilization to 10% for the minimal design to | ||
# maximize chances of getting an initial floorplan. This | ||
# provides a generous area, yet not so big as to make making | ||
# floorplan problematic | ||
export CORE_UTILIZATION ?= 10 | ||
# Low placement density to maximize chances of getting a floorplan | ||
export PLACE_DENSITY ?= 0.20 | ||
|
||
# This won't work with an empty .sdc file | ||
export SKIP_REPORT_METRICS = 1 | ||
|
||
# Faster build, remove these in your own config.mk | ||
export SKIP_CTS_REPAIR_TIMING = 1 | ||
export REMOVE_ABC_BUFFERS = 1 | ||
export SKIP_INCREMENTAL_REPAIR = 1 |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
# Creating a basic .sdc file is beyond the scope of | ||
# simple configuration, much as writing Verilog is. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
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
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
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
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
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
#!/bin/bash | ||
# | ||
# deltaDebug.py integration smoke-test, run from ORFS/flow folder. | ||
# | ||
# Exit with error if anything is amiss, including evaluation of | ||
# variable names such as $(false), unused variables, etc. | ||
set -x -ue -o pipefail | ||
|
||
cd "$(dirname "$0")/.." | ||
rm -rf results/outoftree/ | ||
mkdir -p results/outoftree/ | ||
cd results/outoftree/ | ||
cp ../../designs/src/aes/* . | ||
make --file=../../Makefile DESIGN_CONFIG=../../designs/asap7/minimal/config.mk DESIGN_NAME=aes_cipher_top VERILOG_FILES="$(ls *.v | xargs)" grt |