In many projects, some of the VHDL code is generated in one way or another. For instance, many projects manage their register map in one master file and generate their VHDL packages and C headers using some kind of tool (either commercial or an in house script).
This article deals with integrating such a script in the Sigasi Pro development environment, so that your generated files are always up to date. In order to make it easy for you to reproduce this, we have created a demo project that you can download or clone from Github. The demo project already contains a working “Builder” that runs the generator script each time you change the values in the script.
But first: this video shows you what it looks like in real life. As soon as I change the generator script (and save), the generated code is updated.
We assume that you have the project, and a script that generates VHDL code (or C header files, or any other source code).
Running it by hand
First, run the script by hand, so that you have one set of your generated files.
Marking the generate files as “derived”
Next, for each of the generate files, right-click > Properties then select Derived. If you have a lot of generated files, and they are nicely placed in a single directory, you can instead mark that directory as derived.
Set up the Builder
Select the project, then: right-click > Properties > Builders > New… > Program.
Choose a name, for example “Address Map Generator”.
Fill out the location of the generator script. If the script is inside your project, you can use the environment variable ${build_project}
to indicate your project’s path.
Also fill out the working directory. Most likely this is the project directory, indicated by ${build_project}
.
The tools needs to know when to trigger this builder, so we have to give it a little more information:
- For Build Options, I like to enable build During auto builds in addition to the defaults.
- Select Specify working set of relevant resources and then click Specify Resources…. Now select all the source files that your script will use in order to generate VHDL code and C headers. In this example, only the generator script itself is a relevant resource.
After the extra files are generated, we want the rest of the build process to use our newly generated files:
- In the Refresh tab, select Refresh resources upon completion and Specific resources. Then press the Specific Resources… button and select all of the files that will be generated (or updated) by your script.
- Press OK to close the Edit Configuration dialog, and re-order the builders so that your newly created builder is listed before the Xtext Project Builder. Use the Up and Down buttons for this.
Try it out
I’m testing the builder by placing my source file and generated file next to each other and editing the source file. Each time I save, the generated VHDL package is update.
Version control
If you are using a version control system, make sure you add the new .externalToolBuilders
directory, and the changes to .project
On Windows
A friendly customer pointed out that Windows cannot execute Python scripts directly, even if Python is installed. If you try the the above setup, an error shows up saying “no valid win32 program”.
A workaround is to have a batch script generate.bat
, as shown below, besides the python script generate.py
.
In the Location field in the Builders section of the Project Properties, enter generate.bat
instead of generate.py
.
REM this is generate.bat
python ./generate.py
What do you think?
Did this work for you? Do you have a tool that you can recommend for generating the address map?
See also
- "Use" and "Library" in VHDL (blog post)
- How to set up the UVM Library in Sigasi Visual HDL (knowledge)
- How to set up the UVVM Library in Sigasi Visual HDL (knowledge)
- VHDL 2019: Conditional Analysis (blog post)
- VHDL 2019 Conditional Analysis (screencast)