===============================================
UHD - Firmware and FPGA Image Application Notes
===============================================
.. contents:: Table of Contents
---------------
Images Overview
---------------
Every USRP device must be loaded with special firmware and FPGA images.
The methods of loading images into the device vary among devices:
* **USRP1:** The host code will automatically load the firmware and FPGA at runtime.
* **USRP2:** The user must manually write the images onto the USRP2 SD card.
* **USRP-N Series:** The user programs an image into on-board storage, which
then is automatically loaded at runtime.
* **USRP-E Series:** The host code will automatically load the FPGA at runtime.
* **USRP-B Series:** The host code will automatically load the FPGA at runtime.
* **USRP-X Series:** The user programs an image into on-board storage, which
then is automatically loaded at runtime.
----------------
Pre-built Images
----------------
Pre-built images are available for download.
* `Master Branch images `_
* `Maint Branch images `_
The pre-built images come in two forms:
* bundled with UHD software in a platform-specific installer
* stand-alone platform-independent archive files
^^^^^^^^^^^^^^^^^^^^^
UHD Images Downloader
^^^^^^^^^^^^^^^^^^^^^
The UHD images downloader downloads UHD images compatible with the host code
and places them in the default images directory.
By default, it can be found at: **/lib/uhd/utils/uhd_images_downloader.py**
By default, it installs images to: **/share/uhd/images**
^^^^^^^^^^^^^^^^^^^
Platform installers
^^^^^^^^^^^^^^^^^^^
The UNIX-based installers will install the images into **/usr/share/uhd/images**.
The Windows installers will install the images into **C:/Program Files/UHD/share/uhd/images**.
^^^^^^^^^^^^^^^
Archive install
^^^^^^^^^^^^^^^
When installing images from an archive, there are two options:
**Option 1:**
Unpack the archive into the UHD installation prefix.
UHD software will always search **/share/uhd/images** for image files.
Where **** was set by the **CMAKE_INSTALL_PREFIX** at configure-time.
**Option 2:**
Unpack the archive anywhere and set the **UHD_IMAGES_PATH** environment variable.
**UHD_IMAGES_PATH** may contain a list of directories to search for image files.
---------------
Building Images
---------------
The UHD source repository comes with the source code necessary to build
both firmware and FPGA images for all supported devices.
The build commands for a particular image can be found in **/images/Makefile**.
^^^^^^^^^^^^^^^^^^
Xilinx FPGA builds
^^^^^^^^^^^^^^^^^^
USRP Xilinx FPGA images are built with two different versions of ISE, depending
on the device.
The build requires that you have a UNIX-like environment with **Make**.
Make sure that **xtclsh** from the Xilinx ISE bin directory is in your **$PATH**.
**Xilinx ISE 14.7**
* USRP X3x0 Series
* USRP B2x0
See **/fpga/usrp3/top/**.
**Xilinx ISE 12.2**
* USRP N2x0
* USRP B1x0
* USRP E1x0
* USRP2
See **/fpga/usrp2/top/**.
^^^^^^^^^^^^^^^^^^^
ZPU firmware builds
^^^^^^^^^^^^^^^^^^^
The ZPU GCC compiler is required to build the ZPU firmware images.
The build requires that you have a UNIX-like environment with **CMake** and **Make**.
Make sure that **zpu-elf-gcc** is in your **$PATH**.
See **/firmware/zpu**.
^^^^^^^^^^^^^^^^^^
Altera FPGA builds
^^^^^^^^^^^^^^^^^^
Quartus is required to build the Altera FPGA image for the USRP1.
Pre-built images can also be found in **/fpga/usrp1/rbf**.
See **/fpga/usrp1/toplevel/***.
^^^^^^^^^^^^^^^^^^^
FX2 firmware builds
^^^^^^^^^^^^^^^^^^^
The SDCC compiler is required to build the FX2 firmware images.
The build requires that you have a UNIX-like environment with **CMake** and **Make**.
See **/firmware/fx2**.