diff options
author | Martin Braun <martin.braun@ettus.com> | 2014-10-01 17:39:50 -0700 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2014-10-06 10:42:14 +0200 |
commit | 29a4693b11cbfa3f2a4c3c517d54cbc155018ee8 (patch) | |
tree | c92d1f3d533552b9fa63b7aadc26ad7546048d59 /images/README.md | |
parent | 57e6930fef096b1af0fc23e59a777f57b39bf2aa (diff) | |
download | uhd-29a4693b11cbfa3f2a4c3c517d54cbc155018ee8.tar.gz uhd-29a4693b11cbfa3f2a4c3c517d54cbc155018ee8.tar.bz2 uhd-29a4693b11cbfa3f2a4c3c517d54cbc155018ee8.zip |
uhd: Added infrastructure for maintaining images directory
Diffstat (limited to 'images/README.md')
-rw-r--r-- | images/README.md | 64 |
1 files changed, 56 insertions, 8 deletions
diff --git a/images/README.md b/images/README.md index b9e3232aa..6c96fde7b 100644 --- a/images/README.md +++ b/images/README.md @@ -3,11 +3,16 @@ UHD Firmware and FPGA Images Builder The images directory contains the following: * A Makefile for building firmware and FPGA images -* A CMake file for building an images package +* Scripts to load all the binaries for this current commit, as + well as create a new images package from the images in subdir + images/ This provides a clean and organized way to build all of the firmware and FPGA images, the source code for which is in the `firmware` and `fpga` directories -one level above this. +one level above this, and also maintains a linkage between images and git commits. + +Building the binaries +--------------------- The Makefile and build systems for the images are *probably* Unix-specific. It's best to build the images on a Unix system with standard build tools. The @@ -18,7 +23,55 @@ __To build the images (unix):__ 1. `make clean` 2. `make images` -__To build the package (unix):__ +__Fedora note:__ + +The sdcc binaries are prefixed with "sdcc-" which breaks the build. +However, /usr/libexec/sdcc contains properly named sdcc binaries. +`export PATH=${PATH}:/usr/libexec/sdcc` + + +Updating binaries +----------------- + +This goes two ways: + +1. Loading the correct binaries for this commit +2. Updating the binary package on this branch + + +### Loading the correct binaries ### + +If you check out a branch or commit, you might want to use the exact same +binaries that were used when this branch or commit was generated. +To do this, run `populate_images.py`. This will either download the correct +images package from a web server or from a local directory if +`UHD_IMAGES_BASE_URL` is set. + +### Updating the binaries ### + +If you have commited changes to this branch that require new images, you +should probably update those. +Simply copy the new image binaries into images/. If necessary, run +`populate_images.py` before you do any of this, so all the untouched +images are the correct version. Then, run `create_imgs_package.py --commit "COMMIT MSG"` +to create a new ZIP file and commit the info. +If `UHD_IMAGES_BASE_URL` is set and is a local directory, it will move +the ZIP file to this directory after creating it. + +### Updating the binaries ### + +Typical workflow: + +1. Check out a branch or commit (git checkout FOO) +2. Update the images/ subdir (`populate_images.py`) +3. Do some coding, and commit those changes (`git commit`) +4. Copy new binaries to images/ +5. Commit the new binaries: `create_imgs_package.py --commit "Updated images on branch X"` + +### The CPack system ### + +Underlying `create_imgs_package.py` is a CPack system, which can be manually +invoked by: 1. `mkdir build` 2. `cd build` @@ -28,8 +81,3 @@ __To build the package (unix):__ The package generator types are described here: http://www.cmake.org/Wiki/CMake:CPackPackageGenerators -__Fedora note:__ - -The sdcc binaries are prefixed with "sdcc-" which breaks the build. -However, /usr/libexec/sdcc contains properly named sdcc binaries. -`export PATH=${PATH}:/usr/libexec/sdcc` |