The purpose of VPM is to manage a verilog project. In a project, keeping track of IP versions is a challenging task. Package manager tools like apt, yum, dnf, pacman, ..., provide an easy interface for the user to maintain and keep up to date softwares and the distro. In many ways, a project can benefit from such tools adapted for verilog.
VPM is one of these. An IP can be stored on a remote repository (github, gitlab, cvs, svn, ...), on a remote disk mounted (nfs, ...), or locally.
The installation is rather simple:
# checked in regression as is
# update pip in case of
pip install --upgrade pip
# the lonely dependency
pip install pyyaml
# the package
pip install git+git://github.com/LudwigCRON/vpm.git#egg=vpm
From now on, on can call vpm
in any terminal.
If a python environment is needed, just load your environment first:
# with pyenv installed
pyenv activate <vpm-env>
# or with virtualenv
source <vpm-env>/bin/activate
vpm is focused on the simplicity and relies on two files:
-
vpm.config
vpm.config corresponds to the list of repositories'url to inspect. This configuration file also contains information for dispatching files inside a project
-
package.yml
package.yml list important information on a package such as dependencies, files to export, ...
Their format description will be presented later on.
vpm create config
the command line above generates a template of the configuration file to precise the list of repositories'url or repositories'path to look on.
vpm create package
this command line creates the blank package.yml file if there is none in current directory. This files will defines the files to export and their roles (design/testcase/model/assertions/...)
install a package from either its url or its name. The name of a package and the version of the package can be specified.
In that case, the command will be
vpm install my-package=3.4.1
In fact, the one can select to install any version more recent the version specified by using the operator ">" or ">=".
To compare two version, vpm assumes a 3-number numeration system of the version as major
.minor
.release
.
list installed packages and their version number. It does not display the status of a package (healthy/outdated/corrupted)
list installed packages where a newer version exists in the list of repositories specified by the user.
list packages availabled in the repositories enumerated in sources.list
list packages whose checksum does not match the one of the repository with the same version number. It is sometime useful to spot customized block.
update to the most recent version the package specified.
remove the package from the project
one single file with one line per repository in the following format
[driver name]@[repository url]
if no driver is provided, we assume it is a local repository such that in the example below, ./
and ../resync
are considered locally while
git@github.com/LudwigCRON/vpm/tests/sar
is a url pointing to an IP on a github.com repository using the git
driver.
[default]
# default variables to dispatch files
# during IP installations
DESIGNS_DIR=${PLATFORM}/design
MODELS_DIR=${PLATFORM}/model
LIBRARY_DIR=${PLATFORM}/library
TESTCASES_DIR=${PLATFORM}/testcases
DOCUMENTATION_DIR=${PLATFORM}/documents
CONSTRAINTS_DIR=${PLATFORM}/constraints
[repositories]
# at least have the current directory
sources = ./
../resync
git@github.com/LudwigCRON/vpm/tests/sar
TBD
For the current version of VPM, the project structure is:
platform
|
+--> constraints
| |
| +--> sdc
| +--> tcl
| +--> ...
+--> documents
+--> designs
| |
| +--> verilog files
| +--> assertions files
+--> libraries
| |
| +--> technology files
| +--> pdk files
+--> models
|
+--> simulation files only
However, this is not mainstream. So one can edit where files are dispatched in its project by adding more information in the vpm.config file.
the default is the following:
[default]
# default variables to dispatch files
# during IP installations
DESIGNS_DIR=${PLATFORM}/design
MODELS_DIR=${PLATFORM}/model
LIBRARY_DIR=${PLATFORM}/library
TESTCASES_DIR=${PLATFORM}/testcases
DOCUMENTATION_DIR=${PLATFORM}/documents
CONSTRAINTS_DIR=${PLATFORM}/constraints
the environment variable ${PLATFORM}
is generated by the tool and corresponds to the path where the vpm.config is.
By editing the *_DIR
variables, one change the dispatching for only its project.
Let's suppose the project structure is:
platform
|
+--> customs
| |
| +--> sdc
| +--> tcl
| +--> verilog
| +--> ...
+--> documents
+--> vendors
| |
| +--> verilog files
| +--> assertions files
+--> techno
| |
| +--> technology files
| +--> pdk files
+--> verification
|
+--> models
+--> testbenches
+--> testcases
the vpm.config file can be adapted to:
[default]
# default variables to dispatch files
# during IP installations
DESIGNS_DIR=${PLATFORM}/vendors
MODELS_DIR=${PLATFORM}/verification/models
LIBRARY_DIR=${PLATFORM}/techno
TESTCASES_DIR=${PLATFORM}/verification/testcases
DOCUMENTATION_DIR=${PLATFORM}/documents
CONSTRAINTS_DIR=${PLATFORM}/customs