This repository contains a set of scripts for creating, maintaining, and releasing git repositories containing minimally version-controlled Vivado and Xilinx SDK projects. These scripts have only been tested with Vivado 2018.2; they may or may not work with newer or older versions of Vivado. A Python 3.6.3 (or newer) installation is required to use these scripts. As of time of writing, no additional Python modules
A front-end script, git_vivado.py, is provided to parse command line arguments and call into Vivado at the command line. This script has three subcommands: "checkout", "checkin", and "release". Each of these subcommands has its own help menu, which explains the arguments that can be passed to the script, as well as show what the default values of each of these arguments will be. All paths passed to the script are assumed to be relative to the current working directory.
This subcommand calls into digilent_vivado_checkout.tcl in order to create a Vivado project, in the form of an XPR file, using the sources and scripts contained in the project repository. It takes up to three additional arguments: a path to the XPR file to be created ('-x'), a path to the repository to use to create the XPR ('-r'), and the version number of the Vivado installation to be used ('-v'). Use the "help" interface by calling "python git_vivado.py checkout -h" for more information and to view the script's default arguments. Note that
This subcommand calls into digilent_vivado_checkin.tcl in order to collect sources and generate needed scripts from a Vivado project into the repository structure described below. It takes up to three additional arguments: a path to the project's XPR file ('-x'), a path to the repository to check sources into ('-r'), and the version number of the Vivado installation to be used ('-v'). Use the "help" interface by calling "python git_vivado.py checkin -h" for more information and to view the script's default arguments. Note that sources do not need to be added local to a Vivado project in order to be detected by this script.
This subcommand is not fully implemented. A release Archive must be manually created, as described in the "Workflows" section below.
The digilent-vivado-scripts repository contains a file named "config.ini". This file contains several values used by the Python script to determine what the default arguments for the different subcommands should be. It has not yet been decided how this file should be managed/version-controlled. See "Known Issues" at the bottom of this document for a little more information.
In order to ensure that any changes to this repository do not break the projects that use them, it is expected that this repository will be used as a submodule of each project repository that is intended to use them.
- <project repo>/digilent-vivado-scripts: Contains the scripts described by this document.
- <project repo>/proj: Used to contain a checked-out Vivado project.
- <project repo>/release: Contains temporary files necessary to generate a release zip archive.
- <project repo>/repo: Contains local IP, IP submodules, and cached generated sources.
- <project repo>/sdk: Contains exported SDK sources.
- <project repo>/src: Contains source files for the Vivado Project.
- <project repo>/src/bd: Contains a TCL script used to re-create a block design.
- <project repo>/src/constraints: Contains XDC constraint files.
- <project repo>/src/hdl: Contains Verilog and VHDL source files.
- <project repo>/src/ip: Contains XCI files describing IP to be instantiated in non-IPI projects.
- <project repo>/src/others: Contains all other required sources, such as memory initialization files.
- <project repo>/.gitignore: File describing which sources should be version controlled. An example is generated by the checkin process.
- <project repo>/.gitmodules: File describing submodules of the repository. Automatically maintained by the "git submodule" command.
- <project repo>/project_info.tcl: Script generated by the checkin process used to save and re-apply project settings such as target board.
- <project repo>/README.md: Markdown file describing the project and the process needed to use it, from downloading the release archive, to programming the FPGA.
- Create a new Vivado project at an arbitrary location on your computer. When exporting to and launching SDK, make sure to use exported locations and workspaces that are not "Local to Project".
- Create a repository on Github for your project. Use the naming convention "<board>-<variant number>-<project name>" (for example: "Zybo-Z7-20-DMA"). Do not have Github create a gitignore file for you. Clone the repository (I do this using git bash and the "git clone ..." command).
- In a command line interface (git bash) cd into the repository directory. Call "git submodule add https://github.com/artvvb/digilent-vivado-scripts" (FIXME).
- Call "python ./digilent_vivado_scripts/git_vivado.py checkin -x <path to XPR>". This command can be called from anywhere in your filesystem, with relative paths changed as required. This will also create a gitignore file for the repository.
- If required, in Xilinx SDK, right click on your application project's src folder and select "Export". Use this to copy all of the sources from "<app>/src" to "<project repo>/sdk/appsrc".
- Create a README for the repo that specifies what the project is supposed to do and how to use a release archive for it.
- Add, commit, and push your changes.
- Create and upload a release ZIP to Github - see "Creating a Release Archive" below.
- Clone (or pull) the Vivado project to be retargeted. Use its existing version control system to generate an XPR. If relevant, make sure to call "git submodule init" followed by "git submodule update" from a command line interface (git bash) from within the repo directory.
- Open the project in Vivado and make any changes necessary (perhaps upgrading IP). When exporting to and launching SDK, make sure to use exported locations and workspaces that are not "Local to Project".
- Clone the project repository again in a different location. Remove all files from this directory.
- In a command line interface (git bash) cd into the clean repository directory. Call "git submodule add https://github.com/artvvb/digilent-vivado-scripts" (FIXME).
- Call "python ./digilent_vivado_scripts/git_vivado.py checkin -x <path to XPR>". This command can be called from anywhere in your filesystem, with relative paths changed as required. This will also create a gitignore file for the repository.
- If required, in Xilinx SDK, right click on your application project's src folder and select "Export". Use this to copy all of the sources from "<app>/src" to "<second repo>/sdk/appsrc".
- Create a README for the repo that specifies what the project is supposed to do and how to use a release archive for it.
- Add, commit, and push your changes.
- Create and upload a release ZIP to Github - see "Creating a Release Archive" below.
- Clone (or pull) the Vivado project to be changed.
- In a command line interface (git bash) cd into the repository directory.
- Call "git submodule init" followed by "git submodule update" in order to get this repositories scripts scripts.
- Call "python ./digilent_vivado_scripts/git_vivado.py checkout". This command can be called from anywhere in your filesystem, with the relative path to git_vivado. This will also create a gitignore file for the repository. Default arguments will create the XPR at "<project repo>/proj/<project name>.xpr".
- Open the project in Vivado and make any changes necessary (perhaps upgrading IP or fixing a bug). When exporting to and launching SDK, make sure to use exported locations and workspaces that are not "Local to Project".
- Call "python ./digilent_vivado_scripts/git_vivado.py checkin". This command can be called from anywhere in your filesystem, with the relative path to git_vivado changed as required.
- If required, in Xilinx SDK, right click on your application project's src folder and select "Export". Use this to copy all of the sources from "<app>/src" to "<project repo>/sdk/appsrc".
- Make sure to update the repo's README as required.
- Add, commit, and push your changes.
- Create and upload a release ZIP to Github - see "Creating a Release Archive" below.
- With an open Vivado project, make sure that a bitstream has been generated.
- Click File -> Project -> Archive. Fill in the fields in the prompt as per the table below then click "OK".
Field | Value |
---|---|
Archive name | vivado_proj |
Archive location | <project repo>/release |
Temporary location | (Default) |
Include configuration settings | unchecked |
Include run results | checked |
Include local IP cache results | checked |
- Navigate to the release subdirectory of the project repo and extract vivado_proj.xpr.zip. Rename the resulting folder "vivado_proj" then delete vivado_proj.xpr.zip.
- If required, in Xilinx SDK, right click on your application project's src folder and select "Export". Use this to copy all of the sources from "<app>/src" to "<project_repo>/release/sdk_appsrc".
- Copy README.md into the release subdirectory, and make sure that it contains project specific instructions for using the release, especially if any libraries need to be added to the BSP or if compiler settings need to be added to the application project in SDK.
- Compress the release subdirectory into a ZIP archive called "<project name>-<release version number>.zip" (for example "Zybo-Z7-20-DMA-2018.2-3.zip").
- Draft a new release on Github and upload the ZIP to it.
- Download and extract the most recent release archive from the repository's releases page.
- Open the XPR file in the version of Vivado specified by the README.
- Use Vivado's Hardware manager to connect to and program the target FPGA board with the project's bitstream.
- If the release archive contains an sdk_appsrc folder, export the project's hardware to SDK and launch SDK. Local to project is fine in this instance.
- Create a new application project (Empty Application template) and BSP, and follow any instructions in the project's README for how to configure them.
- Right click on the application project's src folder and select "Import". Import all files from <extracted location>/sdk_appsrc, overwriting anything that already exists.
- Program and Run the application on the target FPGA board.
- For both releases and checked out repositories, SDK Application and BSP projects must be manually configured in order to add any additional libraries and compiiler flags. This process is fairly error-prone.
- Each developer needs their own version of the configuration file, config.ini, for each project they are woking on. The configuration file should be moved to somewhere outside of the repo submodule to accomodate this, in a predictable location on Linux and Windows. The python script will need to be updated to accomodate this, a location and less generic name will need to be chosen for the configuration file.
- The "archive project" functionality of Vivado may include local SDK sources in the release archive. This should be avoided so that users have a clean workspace to Export and Launch SDK into. The current process requires that the project's SDK workspace is created external to the Vivado project.
- The process of creating a release archive currently must be done manually. This process can be automated further, but will require creation of an XSCT script to collect SDK application sources.
- There is some danger that modifications to Digilent's board files may break existing projects, it may be worth considering adding the vivado-boards repository as a submodule to project repositories.