EDA container wrapper is a work-in-progress generic wrapper tool around open source EDA tools. The tools are executed in Docker containers and this tool wraps this execution and keeps an inventory of tools.
It supports three use cases:
- Run
eda-container-wrapperto execute the wrapper with given parameters - Let
eda-container-wrappercreate a wrapper script (in an executable path for example) with pre-defined settings - Run tools from python using the
edacontainerwrappermodule
The settings can be set in the following way in precedence order:
- As parameters to the
eda-container-wrappertool or to the respective functions ofedacontainerwrapper - As environment variables
- As default settings in the wrapper scripts
$ pip3 install eda-container-wrapperSets the version of the tool to use.
Runs the Docker container in interactive mode (allowing to terminate it easily
for example) with the Docker -ti flags. Some non-interactive environments such
as CI don't support that (missing tty). Note the difference in logic, the
default is interactive mode which is disabled with the --non-interactive
switch. ECW_INTERACTIVE keeps it interactive when set to true or 1 and it
will be non-interactive otherwise.
If not empty this is a colon-separated pair of a leading path of the cwd where
the tool was called from and a replacement for this path. This is in particular
useful when called from inside a Docker container, such as in CI. The syntax is:
<actual path>:<cwd path>.
When mapping the current working directory, this setting actually maps the path up the hierarchy by the given value. This is in particular useful when you need to access data relative to the current working directory that is in upper and sibbling folders.
For example, when started from the following folder:
CWD=/path/to/my/project/build
Setting --split-cwd-tail=1 the split is into /path/to/my/project and
build. Each tool has a "project path" that is the volume where the tool is
executed in then by setting the working directory. For a tool with the project
path /project it will then mount /path/to/my/project to /project and the
workdir will be /project/build.
This split is executed after processing the cwd base.
As described above there are different ways to run a tool, that are described in the following.
The program is called with the parameters as described and the toolname.
Following a -- parameters to the tool can be supplied.
Example:
$ eda-container-wrapper verilator -- --versionTo create a verilator script that by default executes version 4.100:
$ eda-container-wrapper --write-script=/usr/local/bin/verilator --tool-version 4.100 verilatorand then execute it:
$ verilator --version
Verilator 4.100 2020-09-07 rev v4.100Setting the environment setting ECW_TOOL_VERSION changes the defualt behavior:
$ ECW_TOOL_VERSION=4.102 verilator --version
Verilator 4.102 2020-10-15 rev v4.102It can be useful to create the script in your virtual environment:
$ eda-container-wrapper --write-script=$VIRTUAL_ENV/verilator --tool-version 4.100 verilator