Skip to main content

Utility to flash firmware blobs to tt devices

Project description

tt-flash

This is a utility to flash firmware blobs to tenstorrent devices.

Flash firmware on all devices on a system using one command:

tt-flash <firmware bundle file path>

Official Repository

https://github.com/tenstorrent/tt-flash

Getting started

Install Rust (if you don't already have it)

If Rust isn't already installed on your system, you can install it through either of the following methods:

Using Distribution packages (preferred)

  • Fedora / EL9:
    sudo dnf install cargo
  • Ubuntu / Debian:
    sudo apt install cargo

Using Rustup

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
source "$HOME/.cargo/env"

User installation

tt-flash is available on PyPI. We recommend running it with uvx, which ensures you always run the latest released version.

Install uv if you don't already have it:

curl -LsSf https://astral.sh/uv/install.sh | sh

Then run tt-flash:

uvx tt-flash@latest <firmware bundle file path>

Developer installation

Clone the repository

git clone https://github.com/tenstorrent/tt-flash.git
cd tt-flash

Install

uv sync

This creates a .venv and installs tt-flash in editable mode along with its dependencies. Run the local build with uv run tt-flash, or activate the venv (source .venv/bin/activate) and use tt-flash directly.

Help text

Use the -h argument to print the help text.

$ tt-flash -h

usage: tt-flash [-h] [-v] [--sys-config SYS_CONFIG] [--no-color] [--no-tty] {flash,verify} ...

options:
  -h, --help            show this help message and exit
  -v, --version         show program's version number and exit
  --sys-config SYS_CONFIG
                        Path to the pre generated sys-config json
  --no-color            Disable the colorful output
  --no-tty              Force disable the tty command output

command:
  {flash,verify}
    flash               Flash firmware to Tenstorrent devices on the system. Run tt-flash flash -h for further command-specific help.
    verify              Verify the contents of the SPI. Will display the currently running and flashed bundle version of the fw and checksum the fw against either what was flashed previously according
                        the the file system state, or a given fw bundle. In the case where a fw bundle or flash record are not provided the program will search known locations that the flash record
                        may have been written to and exit with an error if it cannot be found or read. Run tt-flash verify -h for further command-specific help.
$ tt-flash flash -h

usage: tt-flash flash [-h] [--sys-config SYS_CONFIG] [--fw-tar FW_TAR] [--skip-missing-fw] [--force] [--no-reset] [fwbundle]

positional arguments:
  fwbundle              Path to the firmware bundle

options:
  -h, --help            show this help message and exit
  --sys-config SYS_CONFIG
                        Path to the pre generated sys-config json
  --fw-tar FW_TAR       Path to the firmware tarball (deprecated)
  --skip-missing-fw     If the fw packages doesn't contain the fw for a detected board, continue flashing
  --force               Force update the ROM
  --no-reset            Do not reset devices at the end of flash

Typical usage

tt-flash <firmware bundle file path goes here>

Firmware files

Firmware files are licensed and distributed independently, as tt-flash solely acts as a utility to update devices with provided firmware images. You can find firmware bundles in a seperate repo at https://github.com/tenstorrent/tt-firmware.

Example output

This is an example of what you can expect to see when you flash a device.

$ tt-flash ~/tt-firmware/latest.fwbundle

Stage: SETUP
        Searching for default sys-config path
        Checking /etc/tenstorrent/config.json: not found
        Checking ~/.config/tenstorrent/config.json: not found

        Could not find config in default search locations, if you need it, either pass it in explicitly or generate one
        Warning: continuing without sys-config, galaxy systems will not be reset
Stage: DETECT
Stage: FLASH
        Sub Stage: VERIFY
                Verifying fw-package can be flashed: complete
                Verifying Blackhole[0] can be flashed
        Stage: FLASH
                Sub Stage FLASH Step 1: Blackhole[0]
                        ROM version is: (18, 10, 0, 0). tt-flash version is: (18, 12, 0, 0)
                        FW bundle version > ROM version. ROM will now be updated.
                Sub Stage FLASH Step 2: Blackhole[0] {p150a}
                        Writing new firmware... (this may take up to 1 minute)
                        Writing new firmware... SUCCESS
                        Verifying flashed firmware... (this may also take up to 1 minute)
                        Firmware verification... SUCCESS
Stage: RESET
 Starting PCI link reset on BH devices at PCI indices: 0 
 Waiting for up to 60 seconds for asic to come back after reset
 Config space reset completed for device 0 
 Finishing PCI link reset on BH devices at PCI indices: 0 
FLASH SUCCESS

Supported products

tt-flash can be used to flash Wormhole and Blackhole products. The last version that supported flashing Grayskull products was v3.4.7.

License

Apache 2.0 - https://www.apache.org/licenses/LICENSE-2.0.txt

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tt_flash-3.10.0.tar.gz (43.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tt_flash-3.10.0-py3-none-any.whl (46.2 kB view details)

Uploaded Python 3

File details

Details for the file tt_flash-3.10.0.tar.gz.

File metadata

  • Download URL: tt_flash-3.10.0.tar.gz
  • Upload date:
  • Size: 43.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tt_flash-3.10.0.tar.gz
Algorithm Hash digest
SHA256 cf9201eb2b59ffb439be2ba81cc409c0f4ec8ec6f0236312402c86c19e9ca31c
MD5 d4a12cdad37ee40eed7204294042e49d
BLAKE2b-256 53acf883d2a9e387ad0c8ad3b12e53b0089aa59554c7f589e2320394427dc2c5

See more details on using hashes here.

Provenance

The following attestation bundles were made for tt_flash-3.10.0.tar.gz:

Publisher: release.yml on tenstorrent/tt-flash

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tt_flash-3.10.0-py3-none-any.whl.

File metadata

  • Download URL: tt_flash-3.10.0-py3-none-any.whl
  • Upload date:
  • Size: 46.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tt_flash-3.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 94602a8401b57484d28faf4cec137f32241047a466a3448d266e12516968a6fe
MD5 4c24168e4998ee481fd648941ce2653f
BLAKE2b-256 9b4d4a4d9f8f9dfa1ebbf85ee8585ccc03550e5ea2b45eff7e038ca1567be216

See more details on using hashes here.

Provenance

The following attestation bundles were made for tt_flash-3.10.0-py3-none-any.whl:

Publisher: release.yml on tenstorrent/tt-flash

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page