Skip to content

Latest commit

 

History

History
167 lines (117 loc) · 5.54 KB

INSTALLING.md

File metadata and controls

167 lines (117 loc) · 5.54 KB

Install

These instructions will guide you through the installation of Tenstorrent system tools and drivers, followed by the installation of TT-Metalium and TT-NN.

Important

If you are using a release version of this software, please check the installation instructions packaged with that version. You can find them in either the release assets for that version, or in the source files for that version tag.


Installation Steps

Step 1. Driver & Firmware

Follow the Software Setup instructions for your specific board or system provided on our general docs.

If you have purchased a Grayskull card, you will find the instructions here.

Note the current compatability matrix:

Device OS Python Driver (TT-KMD) Firmware (TT-Flash) TT-SMI TT-Topology
Grayskull Ubuntu 20.04 3.8.10 v1.27.1 fw_pack-80.9.0.0 (v80.9.0.0) v2.2.0 or above N/A
Wormhole Ubuntu 20.04 3.8.10 v1.27.1 fw_pack-80.10.0.0 (v80.10.0.0) v2.2.0 or above N/A
T3000 (Wormhole) Ubuntu 20.04 3.8.10 v1.27.1 fw_pack-80.10.0.0 (v80.10.0.0) v2.2.0 or above v1.1.3 or above, mesh config

Step 2. System-level dependencies

sudo apt update
sudo apt install software-properties-common=0.99.9.12 build-essential=12.8ubuntu1.1 python3.8-venv libhwloc-dev graphviz patchelf cmake=3.16.3-1ubuntu1.20.04.1 ninja-build

wget https://apt.llvm.org/llvm.sh
chmod u+x llvm.sh
sudo ./llvm.sh 17
sudo apt install libc++-17-dev libc++abi-17-dev

Step 3. Hugepages

  1. Download latest setup_hugepages.py script.
wget https://raw.githubusercontent.com/tenstorrent/tt-metal/main/infra/machine_setup/scripts/setup_hugepages.py
  1. Run first setup script.
sudo -E python3 setup_hugepages.py first_pass
  1. Reboot
sudo reboot now
  1. Run second setup script & check setup.
sudo -E python3 setup_hugepages.py enable && sudo -E python3 setup_hugepages.py check

Step 4. Install and start using TT-NN and TT-Metalium!

Note

You may choose to install from either source or a Python wheel.

However, no matter your method, in order to use our pre-built models or to follow along with the documentation and tutorials to get started, you will still need the source code.

If you do not want to use the models or follow the tutorials and want to immediately start using the API, you may install just the wheel.

  1. Install git and git-lfs.
sudo apt install git git-lfs
  1. Clone the repo.
git clone https://github.com/tenstorrent/tt-metal.git --recurse-submodules
cd tt-metal
git submodule foreach 'git lfs fetch --all && git lfs pull'
  1. Install either from source, or from our release wheel. Note that if you are going to try using the model demos, we highly recommend you install from source.

Option 1: From source

We use CMake for our build flows.

Set up the environment variables and invoke our build scripts. Note that for source builds, you must set these environment variables every time.

export ARCH_NAME=<ARCH_NAME>
export TT_METAL_HOME=$(pwd)
export PYTHONPATH=$(pwd)
./build_metal.sh

# If you would like an out-of-the-box virtual environment to use,
./create_venv.sh
source python_env/bin/activate

Note

Note about Python environments: You do not have to use create_venv.sh. If you are less familiar with Python and its various environment tools, just use create_venv.sh as shown above and the pre-built environment.

If you do choose to manage your own environment, please note that you must use Pip 20.1.1 or lower to install this project. This is the highest version of Pip that supports editable installs in the way that we use it.

Option 2: From wheel

Download the latest wheel from our releases page for the particular Tenstorrent card architecture that you have installed on your system. (ie. Grayskull, Wormhole, etc)

Install the wheel using your Python environment manager of choice. For example, to install with pip:

pip install <wheel_file.whl>

If you are going to try our pre-built models in models/, then you must also further install their required dependencies and environment variables:

export PYTHONPATH=$(pwd)
pip install -r tt_metal/python_env/requirements-dev.txt
  1. Start coding

You are all set! Visit the TT-NN Basic examples page or get started with simple kernels on TT-Metalium.


Step 5. (Optional) Software dependencies for codebase contributions

Please follow the next additional steps if you want to contribute to the codebase.

  1. Install dependencies
sudo apt install pandoc libtbb-dev libcapstone-dev pkg-config
  1. Download and install Doxygen, (v1.9 or higher, but less than v1.10)