Using Spack to install ROCm packages#

2025-10-23

14 min read time

Applies to Linux

Spack is a package management tool designed to support multiple software versions and configurations on a wide variety of platforms and environments. It was designed for large supercomputing centers, where many users share common software installations on clusters with exotic architectures using libraries that do not have a standard ABI. Spack is non-destructive: installing a new version does not break existing installations, so many configurations can coexist on the same system.

Most importantly, Spack is simple. It offers a simple spec syntax, so users can concisely specify versions and configuration options. Spack is also simple for package authors: package files are written in pure Python, and specs allow package authors to maintain a single file for many different builds of the same package.

See the official Spack documentation for more information.

Installing prerequisites for Spack#

Note

You must install all prerequisites before installing Spack.

# Install some essential utilities:
apt-get update
apt-get install make patch bash tar gzip unzip bzip2 file gnupg2 git gawk
apt-get update -y
apt-get install -y xz-utils
apt-get install build-essential
apt-get install vim
apt-get install libpci-dev
# Install Python:
apt-get install python3
apt-get upgrade python3-pip
# Install Compilers:
apt-get install gcc
apt-get install gfortran
# Install some essential utilities:
zypper update
zypper install make patch bash tar gzip unzip bzip xz file gnupg2 git awk
zypper in -t pattern
zypper install vim
# Install Python:
zypper install python3
zypper install python3-pip
# Install Compilers:
zypper install gcc
zypper install gcc-fortran
zypper install gcc-c++

Building ROCm components using Spack#

  1. To use the Spack package manager, clone the Spack project from spack/spack.

    git clone https://github.com/spack/spack.git
    
  2. Initialize Spack.

    The setup-env.sh script initializes the Spack environment.

    cd spack
    . share/spack/setup-env.sh
    

    Spack commands are available once the above steps are completed. To list the available commands, use help.

    spack help
    

After running setup-env.sh, the develop branch of the Spack packages repository will be cloned and used.

Note

To use your own local version of spack packages execute the following command:

spack repo set --destination /path/to/local/spack-packages builtin

ROCm packages in Spack#

Note

The supported ROCm components and their versions listed below were accurate as of the time of initial ROCm release. For the most up-to-date information, see the latest version of this information at ROCm packages in Spack.

Component

Spack package name

Minimum supported version

Latest supported version

AMD SMI

amdsmi

5.6.0

7.0.0

aqlprofile

hsa-amd-aqlprofile

7.0.0

7.0.0

comgr

comgr

5.6.0

7.0.0

Composable Kernel

composable-kernel

5.6.0

7.0.0

devicelibs

rocm-device-libs

5.6.0

7.0.0

HIP (hip_in_vdi)

hip

5.6.0

7.0.0

hipBLAS

hipblas

5.6.0

7.0.0

hipBLASLt

hipblaslt

6.0.0

7.0.0

HIPCC

hipcc

5.7.0

7.0.0

hipCUB

hipcub

5.6.0

7.0.0

hipFFT

hipfft

5.6.0

7.0.0

hipfort

hipfort

5.6.0

7.0.0

HIPIFY

hipify-clang

5.6.0

7.0.0

hipRAND

hiprand

5.6.0

7.0.0

hipSOLVER

hipsolver

5.6.0

7.0.0

hipSPARSE

hipsparse

5.6.0

7.0.0

hipSPARSELt

hipsparselt

6.0.0

7.0.0

hipTensor

hip-tensor

5.7.0

7.0.0

HIP Tests

hip-tests

6.1.0

7.0.0

lightning

llvm-amdgpu

5.6.0

7.0.0

MIOpen (HIP)

miopen-hip

5.6.0

7.0.0

MIGraphX

migraphx

5.6.0

7.0.0

MIVisionX

mivisionx

5.6.0

7.0.0

OpenCL

rocm-opencl

5.6.0

7.0.0

openmp-extras

rocm-openmp-extras

5.6.0

7.0.0

RCCL

rccl

5.6.0

7.0.0

rocAL

rocal

6.2.0

7.0.0

rocALUTION

rocalution

5.6.0

7.0.0

rocBLAS

rocblas

5.6.0

7.0.0

ROCdbgapi

rocm-dbgapi

5.6.0

7.0.0

rocDecode

rocdecode

6.1.0

7.0.0

rocFFT

rocfft

5.6.0

7.0.0

rocJPEG

rocjpeg

6.3.0

7.0.0

rocm-core

rocm-core

5.6.0

7.0.0

rocminfo

rocminfo

5.6.0

7.0.0

rocMLIR

rocmlir

5.4.0

7.0.0

ROCm Bandwidth Test

rocm-bandwidth-test

5.6.0

7.0.0

rocm-cmake

rocm-cmake

5.6.0

7.0.0

ROCm Compute Profiler

rocprofiler-compute

6.3.2

7.0.0

ROCm Data Center Tool (RDC)

rdc

5.6.0

7.0.0

ROCm Debug Agent

rocm-debug-agent

5.6.0

7.0.0

ROCm Debugger (ROCgdb)

rocm-gdb

5.6.0

7.0.0

ROCm Examples

rocm-examples

6.2.0

7.0.0

ROCm SMI Library

rocm-smi-lib

5.6.0

7.0.0

ROCm Systems Profiler

rocprofiler-systems

6.3.0

7.0.0

ROCm Validation Suite

rocm-validation-suite

5.6.0

7.0.0

rocPRIM

rocprim

5.6.0

7.0.0

ROCProfiler

rocprofiler-dev

5.6.0

7.0.0

rocprofiler-register

rocprofiler-register

6.1.0

7.0.0

ROCprofiler-SDK

rocprofiler-sdk

6.2.4

7.0.0

rocPyDecode

rocpydecode

6.2.0

7.0.0

rocRAND

rocrand

5.6.0

7.0.0

ROCr Runtime

hsa-rocr-dev

5.6.0

7.0.0

rocSHMEM

rocshmem

6.4.0

7.0.0

rocSOLVER

rocsolver

5.6.0

7.0.0

rocSPARSE

rocsparse

5.6.0

7.0.0

rocThrust

rocthrust

5.6.0

7.0.0

ROCTracer

roctracer-dev

5.6.0

7.0.0

roctracer-dev-api

roctracer-dev-api

5.6.0

7.0.0

rocWMMA

rocwmma

5.6.0

7.0.0

ROCm Performance Primitives (RPP)

rpp

5.7.0

7.0.0

Tensile

rocm-tensile

5.6.0

7.0.0

TransferBench

transferbench

6.3.0

7.0.0

aqlprofile (old)

aqlprofile

5.6.0

6.4.3 (final)

clang-ocl

rocm-clang-ocl

5.6.0

6.1.2 (final)

Omniperf

omniperf

6.2.0

6.3.1 (final)

Omnitrace

omnitrace

rocm-6.2.0

rocm-6.3.0 (final)

ROCT Thunk Interface

hsakmt-roct

5.6.0

6.2.4 (final)

Installing ROCm components using Spack#

  1. rocm-cmake

    Install the default variants and the latest version of rocm-cmake.

    spack install rocm-cmake
    

    To install a specific version of rocm-cmake, use:

    spack install rocm-cmake@<version number>
    

    For example, spack install [email protected]

  2. info

    The info command displays basic package information. It shows the preferred, safe, and deprecated versions, in addition to the available variants. It also shows the dependencies with other packages.

    spack info mivisionx
    

    For example:

    $ spack info mivisionx
    CMakePackage:   mivisionx
    
    Description:
        MIVisionX toolkit is a set of comprehensive computer vision and machine
        intelligence libraries, utilities, and applications bundled into a
        single toolkit.
    
    Homepage: https://github.com/ROCm/MIVisionX
    
    Preferred version:
        7.0.0    https://github.com/ROCm/MIVisionX/archive/rocm-7.0.0.tar.gz
    
    Safe versions:
        6.4.3    https://github.com/ROCm/MIVisionX/archive/rocm-6.4.3.tar.gz
        6.4.3    https://github.com/ROCm/MIVisionX/archive/rocm-6.4.3.tar.gz
        6.4.2    https://github.com/ROCm/MIVisionX/archive/rocm-6.4.2.tar.gz
        6.4.1    https://github.com/ROCm/MIVisionX/archive/rocm-6.4.1.tar.gz
        6.4.0    https://github.com/ROCm/MIVisionX/archive/rocm-6.4.0.tar.gz
        6.3.3    https://github.com/ROCm/MIVisionX/archive/rocm-6.3.3.tar.gz
        6.3.2    https://github.com/ROCm/MIVisionX/archive/rocm-6.3.2.tar.gz
        6.3.1    https://github.com/ROCm/MIVisionX/archive/rocm-6.3.1.tar.gz
        6.3.0    https://github.com/ROCm/MIVisionX/archive/rocm-6.3.0.tar.gz
        6.2.4    https://github.com/ROCm/MIVisionX/archive/rocm-6.2.4.tar.gz
        6.2.1    https://github.com/ROCm/MIVisionX/archive/rocm-6.2.1.tar.gz
        6.2.0    https://github.com/ROCm/MIVisionX/archive/rocm-6.2.0.tar.gz
        6.1.2    https://github.com/ROCm/MIVisionX/archive/rocm-6.1.2.tar.gz
        6.1.1    https://github.com/ROCm/MIVisionX/archive/rocm-6.1.1.tar.gz
        6.1.0    https://github.com/ROCm/MIVisionX/archive/rocm-6.1.0.tar.gz
        6.0.2    https://github.com/ROCm/MIVisionX/archive/rocm-6.0.2.tar.gz
        6.0.0    https://github.com/ROCm/MIVisionX/archive/rocm-6.0.0.tar.gz
        5.7.1    https://github.com/ROCm/MIVisionX/archive/rocm-5.7.1.tar.gz
        5.7.0    https://github.com/ROCm/MIVisionX/archive/rocm-5.7.0.tar.gz
    
    Deprecated versions:
        5.6.1    https://github.com/ROCm/MIVisionX/archive/rocm-5.6.1.tar.gz
        5.6.0    https://github.com/ROCm/MIVisionX/archive/rocm-5.6.0.tar.gz
    
    Variants:
        add_tests [false]           false, true
            add tests and samples folder
        asan [false]                false, true
            Build with address-sanitizer enabled or disabled
        build_system [cmake]        cmake
            Build systems supported by the package
        hip [true]                  false, true
            Use HIP as backend
    
        when build_system=cmake
          build_type [Release]      Debug, MinSizeRel, RelWithDebInfo, Release
              CMake build type
          generator [make]          none
              the build system generator to use
    
        when build_system=cmake ^[email protected]:
          ipo [false]               false, true
              CMake interprocedural optimization
    
    Build Dependencies:
        cmake  ffmpeg  hip           libjpeg-turbo  lmdb      miopen-hip  opencv   protobuf   py-google-api-python-client  py-protobuf  py-pytz        py-wheel  rapidjson  rpp
        cxx    gmake   hsa-rocr-dev  llvm-amdgpu    migraphx  ninja       openssl  py-future  py-numpy                     py-pybind11  py-setuptools  python    rocm-core
    
    Link Dependencies:
        hip  hsa-rocr-dev  llvm-amdgpu  lmdb  migraphx  miopen-hip  openssl  py-future  py-google-api-python-client  py-numpy  py-pybind11  py-pytz  py-setuptools  py-wheel  rapidjson  rocm-core  rpp
    
    Run Dependencies:
        py-protobuf
    
    Licenses:
        MIT
    

Installing variants for ROCm components#

The variants listed above indicate that the mivisionx package is built by default with build_type=Release and the hip backend, and without the opencl backend. build_type=Debug and RelWithDebInfo, with opencl and without hip, are also supported.

For example:

spack install mivisionx build_type=Debug #Backend will be hip since it is the default one
spack install mivisionx+opencl build_type=Debug #Backend will be opencl and hip will be disabled as per the conflict defined in recipe
  • spack spec command

    To display the dependency tree, the spack spec command can be used with the same format.

    For example:

    $ spack spec mivisionx
    
    -   [email protected]~add_tests~asan+hip~ipo build_system=cmake build_type=Release generator=make platform=linux os=ubuntu22.04 target=zen2 %[email protected]
    -       ^[email protected]~doc+ncurses+ownlibs~qtgui build_system=generic build_type=Release platform=linux os=ubuntu22.04 target=zen2 %c,[email protected]
    -           ^[email protected]~gssapi~ldap~libidn2~librtmp~libssh~libssh2+nghttp2 build_system=autotools libs:=shared,static tls:=openssl platform=linux os=ubuntu22.04 target=zen2 %c,[email protected]
    -               ^[email protected] build_system=autotools platform=linux os=ubuntu22.04 target=zen2 %c,[email protected]
    ...
    

Creating an environment#

You can create an environment with all the required components of your version.

  1. In the root folder, create a new folder when you can create a .yaml file. This file is used to create an environment.

    mkdir /localscratch
    cd /localscratch
    vi sample.yaml
    
  2. Add all the required components in the sample.yaml file. For example:

  3. Once you’ve created the .yaml file, you can use it to create an environment.

    spack env create -d /localscratch/MyEnvironment /localscratch/sample.yaml
    
  4. Activate the created environment.

    spack env activate /localscratch/MyEnvironment
    
  5. Before installing, verify that you want all the component versions.

    spack find # this command will list out all components been in the environment (and 0 installed )
    
  6. Install all the components in the .yaml file.

    cd /localscratch/MyEnvironment
    spack install -j 50
    
  7. Check that all components are successfully installed.

    spack find
    
  8. If any modification is made to the .yaml file, you must deactivate the existing environment and create a new one in order for the modifications to be reflected.

    To deactivate, use:

    spack env deactivate
    

Creating and applying a patch before installation#

Spack installs ROCm packages after pulling the source code from GitHub and building it locally. In order to build a component with any modification to the source code, you must generate a patch and apply it before the build phase.

To generate a patch and build with the changes:

  1. Stage the source code. For example:

    spack stage [email protected]
    # (This will pull the 7.0.0 release version source code of hip and display the path to spack-src directory where entire source code is available)
    

    You should see something like this:

    ==> Using cached archive: /data/root/temp/rocm-7.0.0/spack/var/spack/cache/_source-cache/archive/d8/d8dba8cdf05463afb7879de2833983cafa6a006ba719815a35b96d9b92fc7fc4.tar.gz
    ==> Using cached archive: /data/root/temp/rocm-7.0.0/spack/var/spack/cache/_source-cache/archive/82/829e61a5c54d0c8325d02b0191c0c8254b5740e63b8bfdb05eec9e03d48f7d2c.tar.gz
    ==> Using cached archive: /data/root/temp/rocm-7.0.0/spack/var/spack/cache/_source-cache/archive/80/8081d4ab1a43ffa1cebd646668d83008b799ab98c14daf7b455922355a439c8a.tar.gz
    ==> Moving resource stage
            source: /tmp/root/spack-stage/resource-clr-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src/
            destination: /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src/clr
    ==> Moving resource stage
            source: /tmp/root/spack-stage/resource-hip-tests-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src/
            destination: /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src/hip-tests
    ==> Staged hip in /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46
    
  2. Change directory to spack-src inside the staged directory.

    /spack$ cd /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46
    /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46$ cd spack-src/
    
  3. Create a new Git repository.

    /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src$ git init
    
  4. Add the entire directory to the repository.

    /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src$ git add .
    
  5. Make the required changes to the source code.

    /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src# vi hipamd/CMakeLists.txt
    # Make required changes in the source code
    
  6. Generate the patch using the git diff command.

    diff > /spack/var/spack/repos/builtin/packages/hip/0001-modifications.patch
    /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src$ git diff > /spack/var/spack/repos/builtin/packages/hip/0001-modifications.patch
    
  7. Update the recipe with the patch file name and any conditions you want to apply.

    /tmp/root/spack-stage/spack-stage-hip-7.0.0-zo53ondw3tevsr3gmoofbhre7asvis46/spack-src$ spack edit hip
    
  8. Provide the patch file name and the conditions for the patch to be applied in the hip recipe as follows.

    patch("0001-modifications.patch", when="@7.0.0")
    

    Spack will apply 0001-modifications.patch on the 7.0.0 release code before starting the hip build.

  9. After each modification, you must update the recipe. If there is no change to the recipe, run

    touch /spack/var/spack/repos/builtin/packages/hip/package.py