2024-01-12 12:35:53 -08:00
[](https://opensource.org/licenses/MIT)
2024-01-31 17:51:10 -08:00
<p align="center"><img width="70%" src="docs/data/AMD_rocDecode_Logo.png" /></p>
2023-11-21 11:08:36 -07:00
2024-02-27 14:42:03 -07:00
rocDecode is a high-performance video decode SDK for AMD GPUs. Using the rocDecode API, you can
access the video decoding features available on your GPU.
2024-09-18 12:00:55 -04:00
> [!NOTE]
2024-11-20 13:32:22 -05:00
> The published documentation is available at [rocDecode](https://rocm.docs.amd.com/projects/rocDecode/en/latest/index.html) in an organized, easy-to-read format, with search and a table of contents. The documentation source files reside in the `rocDecode/docs` folder of this repository. As with all ROCm projects, the documentation is open source. For more information on contributing to the documentation, see [Contribute to ROCm documentation](https://rocm.docs.amd.com/en/latest/contribute/contributing.html).
2024-09-18 12:00:55 -04:00
2024-11-20 13:32:22 -05:00
## Supported codecs
* H.265 (HEVC) - 8 bit, and 10 bit
* H.264 (AVC) - 8 bit
* AV1 - 8 bit, and 10 bit
2024-12-06 14:46:30 -05:00
* VP9 - 8 bit, and 10 bit
2023-10-12 14:08:12 -07:00
2024-11-20 13:32:22 -05:00
## Prerequisites
2024-01-24 11:11:14 -07:00
2025-01-27 12:45:31 -08:00
### Operating Systems
* Linux
2024-11-20 13:32:22 -05:00
* Ubuntu - `22.04` / `24.04`
2025-01-27 12:45:31 -08:00
* RedHat - `8` / `9`
* SLES - `15-SP5`
### Hardware
* **GPU**: [AMD Radeon™ Graphics ](https://rocm.docs.amd.com/projects/install-on-linux/en/latest/reference/system-requirements.html ) / [AMD Instinct™ Accelerators ](https://rocm.docs.amd.com/projects/install-on-linux/en/latest/reference/system-requirements.html )
2024-11-20 13:32:22 -05:00
> [!IMPORTANT]
2025-01-27 12:45:31 -08:00
> * `gfx908` or higher GPU required
2024-11-20 13:32:22 -05:00
2025-08-01 15:24:37 -04:00
* Install ROCm `6.3.0` or later with `amdgpu-install` and usecase:`rocm`
2024-11-20 13:32:22 -05:00
> [!IMPORTANT]
> `sudo amdgpu-install --usecase=rocm`
2025-01-27 12:45:31 -08:00
### Compiler
* AMD Clang++ Version 18.0.0 or later - installed with ROCm
### Libraries
* CMake Version `3.10` or later
```shell
sudo apt install cmake
` ``
2024-11-20 13:32:22 -05:00
* [Video Acceleration API](https://en.wikipedia.org/wiki/Video_Acceleration_API) - ` libva-amdgpu-dev` is an AMD implementation for VA-API
2024-02-27 14:42:03 -07:00
` ``shell
2024-11-20 13:32:22 -05:00
sudo apt install libva-amdgpu-dev
` ``
> [!NOTE]
> * RPM Packages for ` RHEL`/` SLES` - ` libva-amdgpu-devel`
> * ` libva-amdgpu` is strongly recommended over system ` libva` as it is used for building mesa-amdgpu-va-driver
* AMD VA Drivers
` ``shell
sudo apt install libva2-amdgpu libva-amdgpu-drm2 libva-amdgpu-wayland2 libva-amdgpu-x11-2 mesa-amdgpu-va-drivers
` ``
> [!NOTE]
> RPM Packages for ` RHEL`/` SLES` - ` libva-amdgpu mesa-amdgpu-va-drivers`
2025-10-02 14:24:12 -07:00
* HIP
` ``shell
sudo apt install hip-dev
` ``
2024-11-20 13:32:22 -05:00
* [pkg-config](https://en.wikipedia.org/wiki/Pkg-config)
` ``shell
sudo apt install pkg-config
` ``
2025-01-02 06:42:31 -08:00
* [FFmpeg](https://github.com/FFmpeg/FFmpeg) libraries and headers:
* ` libavcodec` - provides implementation of a wider range of codecs.
* ` libavformat` - implements streaming protocols, container formats and basic I/O access.
* ` libavutil` - includes hashers, decompressors and miscellaneous utility functions.
> [!NOTE]
> FFmpeg libraries are used in samples and tests
2024-11-20 13:32:22 -05:00
` ``shell
2025-01-02 06:42:31 -08:00
sudo apt install libavcodec-dev libavformat-dev libavutil-dev
2023-10-12 14:08:12 -07:00
` ``
2023-11-06 08:51:47 -08:00
2025-01-27 12:45:31 -08:00
> [!IMPORTANT]
> * Required compiler support
> * C++17
> * Threads
> * On Ubuntu 22.04 - Additional package required: libstdc++-12-dev
2024-11-20 13:32:22 -05:00
> ` ``shell
> sudo apt install libstdc++-12-dev
> ` ``
>[!NOTE]
> * All package installs are shown with the ` apt` package manager. Use the appropriate package manager for your operating system.
### Prerequisites setup script
For your convenience, we provide the setup script, [rocDecode-setup.py](https://github.com/ROCm/rocDecode/blob/develop/rocDecode-setup.py), which installs all required dependencies. Run this script only once.
` ``shell
python3 rocDecode-setup.py --rocm_path [ ROCm Installation Path - optional (default:/opt/rocm)]
--runtime [ Setup runtime requirements - optional (default:ON) [options:ON/OFF]]
--developer [ Setup Developer Options - optional (default:OFF) [options:ON/OFF]]
` ``
## Installation instructions
The installation process uses the following steps:
* [ROCm-supported hardware](https://rocm.docs.amd.com/projects/install-on-linux/en/latest/reference/system-requirements.html) install verification
2025-08-01 15:24:37 -04:00
* Install ROCm ` 6.3.0` or later with ` amdgpu-install` and ` --usecase=rocm`:
` ``
sudo amdgpu-install --usecase=rocm
` ``
2024-11-20 13:32:22 -05:00
>[!IMPORTANT]
> Use **either** [package install](#package-install) **or** [source install](#source-install) as described below.
### Package install
To install rocDecode runtime, development, and test packages, run the line of code for your operating
system.
* Runtime package - ` rocdecode` only provides the rocdecode library ` librocdecode.so`
* Development package - ` rocdecode-dev`/` rocdecode-devel` provides the library, header files, and samples
2025-11-14 13:23:51 -08:00
* Host package - ` rocdecode-host` provides rocdecode host decode
2024-11-20 13:32:22 -05:00
* Test package - ` rocdecode-test` provides CTest to verify installation
#### Ubuntu
` ``shell
2025-11-14 13:23:51 -08:00
sudo apt install rocdecode rocdecode-dev rocdecode-test rocdecode-host
2024-11-20 13:32:22 -05:00
` ``
#### RHEL
` ``shell
2025-11-14 13:23:51 -08:00
sudo yum install rocdecode rocdecode-devel rocdecode-test rocdecode-host
2024-11-20 13:32:22 -05:00
` ``
#### SLES
` ``shell
2025-11-14 13:23:51 -08:00
sudo zypper install rocdecode rocdecode-devel rocdecode-test rocdecode-host
2024-11-20 13:32:22 -05:00
` ``
>[!NOTE]
2025-11-14 13:23:51 -08:00
> * Package install auto installs all dependencies.
> * ` rocdecode-host` package is optional package use in host video decode
2024-11-20 13:32:22 -05:00
> [!IMPORTANT]
> ` RHEL`/` SLES` package install requires manual ` FFMPEG` dev install
### Source install
To build rocDecode from source and install, run:
` ``shell
git clone https://github.com/ROCm/rocDecode.git
cd rocDecode
python3 rocDecode-setup.py
mkdir build && cd build
cmake ../
make -j8
sudo make install
` ``
#### Run tests
` ``shell
make test
` ``
> [!IMPORTANT]
> make test requires ` FFMPEG` dev install
>[!NOTE]
> To run tests with verbose option, use ` make test ARGS="-VV"`.
#### Make package
` ``shell
sudo make package
` ``
## Verify installation
The installer copies:
* Libraries into ` /opt/rocm/lib`
* Header files into ` /opt/rocm/include/rocdecode`
* Samples folder into ` /opt/rocm/share/rocdecode`
* Documents folder into ` /opt/rocm/share/doc/rocdecode`
### Using sample application
To verify your installation using a sample application, run:
2024-02-27 14:42:03 -07:00
` ``shell
mkdir rocdecode-sample && cd rocdecode-sample
cmake /opt/rocm/share/rocdecode/samples/videoDecode/
make -j8
2025-04-21 15:57:15 -04:00
./videodecode -i /opt/rocm/share/rocdecode/video/AMD_driving_virtual_20-H265.mp4
2024-02-27 14:42:03 -07:00
` ``
2024-01-12 12:35:53 -08:00
2024-11-20 13:32:22 -05:00
### Using test package
To verify your installation using the ` rocdecode-test` package, run:
` ``shell
mkdir rocdecode-test && cd rocdecode-test
cmake /opt/rocm/share/rocdecode/test/
ctest -VV
` ``
## Samples
You can access samples to decode your videos in our
[GitHub repository](https://github.com/ROCm/rocDecode/tree/develop/samples). Refer to the
2024-02-27 14:42:03 -07:00
individual folders to build and run the samples.
2023-11-06 08:51:47 -08:00
2024-11-20 13:32:22 -05:00
[FFmpeg](https://ffmpeg.org/about.html) is required for sample applications and ` make test`. To install
FFmpeg, refer to the instructions listed for your operating system:
* Ubuntu:
2024-01-24 11:11:14 -07:00
2023-11-21 11:08:36 -07:00
` ``shell
2025-01-02 06:42:31 -08:00
sudo apt install libavcodec-dev libavformat-dev libavutil-dev
2023-11-06 08:51:47 -08:00
` ``
2024-02-27 14:42:03 -07:00
2024-11-20 13:32:22 -05:00
* RHEL/SLES:
Install ffmpeg development packages manually or use ` rocDecode-setup.py` script
## Docker
You can find rocDecode Docker containers in our
[GitHub repository](https://github.com/ROCm/rocDecode/tree/develop/docker).
## Tested configurations
* Linux
* Ubuntu - ` 22.04` / ` 24.04`
* RHEL - ` 8` / ` 9`
2025-09-16 20:09:59 -04:00
* SLES - ` 15 SP7`
2025-06-24 14:39:49 -07:00
* ROCm: ` 7.0.0`
2024-11-20 13:32:22 -05:00
* libva-amdgpu-dev - ` 2.16.0`
* mesa-amdgpu-va-drivers - ` 1:24.3.0`
* FFmpeg - ` 4.4.2` / ` 6.1.1`
2025-01-02 06:42:31 -08:00
* rocDecode Setup Script - ` V2.5.0`