From ccc31fe4e8958ff591c24fa307b261f7d8ed1a5e Mon Sep 17 00:00:00 2001 From: Pawel Czarnecki Date: Thu, 25 Apr 2024 12:42:56 +0200 Subject: [PATCH] README: expand the instructions about using the local flow Signed-off-by: Pawel Czarnecki --- README.md | 44 ++++++++++++++++++++++++++++++++++++-------- 1 file changed, 36 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 04c95964..8f6e8d81 100644 --- a/README.md +++ b/README.md @@ -224,14 +224,6 @@ The runfiles library is used for accessing script dependencies stored in `runfil Attribute `srcs` of the genrule contains dependencies required for running the script (e.g.: `orfs` script, make target patterns, configs). Those dependencies don't include results of previous flow stages and because of that, it is required to build those before running the generated script. In the second rule (`sh_binary`) the `runfiles` directory for the script is created and filled with dependencies so that the script can be executed straight from the output directory. -It is important to remember that, by default, bazel output directory is not writeable so running the ORFS flow with generated script will fail unless correct permissions are set for the directory. -Example usage of `Make` targets can look like this: - -``` -bazel build $(bazel query "deps(L1MetadataArray_test_floorplan) except L1MetadataArray_test_floorplan") -bazel build L1MetadataArray_test_floorplan_make -./bazel-bin/L1MetadataArray_test_floorplan_make do-floorplan -``` #### Mock Area Targets @@ -305,6 +297,42 @@ bazel build L1MetadataArray_test_cts bazel run L1MetadataArray_test_cts_gui ``` +### Using the local flow + +The local flow allows testing the build with locally built OpenROAD-flow-scripts. +It is based on bazel `Make` targets, for more information on those, please refer to relevant [implementation](https://github.com/The-OpenROAD-Project/bazel-orfs?tab=readme-ov-file#make-targets) paragraph. +Example usage of `Make` targets can look like this: + +Let's assume we want to perform a `floorplan` stage for the `L1MetadataArray` design using the locally built ORFS. + +1. Provide all the dependencies for running the target. +``` +bazel build $(bazel query "deps(L1MetadataArray_test_floorplan) except L1MetadataArray_test_floorplan" --noimplicit_deps) +``` + +2. Generate the shell script. +``` +bazel build L1MetadataArray_test_floorplan_make +``` + +3. Source `env.sh` of your local ORFS installation or set the `FLOW_HOME` environment variable to the path to your local `OpenROAD-flow-scripts/flow` directory. +``` +source /env.sh +# or +export FLOW_HOME=/flow +``` + +4. Execute the shell script with ORFS make target relevant to given stage of the flow. +The script is capable of running all make targets that have the same requirements as e.g. `do-floorplan` target +``` +./bazel-bin/L1MetadataArray_test_floorplan_make do-floorplan +``` + +5. After the build is complete, it is possible to view the results in GUI. +``` +./bazel-bin/L1MetadataArray_test_floorplan_make gui_floorplan +``` + ### Tweaking aspect ratio of a floorplan Notice how the `CORE_ASPECT_RATIO` parameter is associated with