(Once dependencies are installed, see Compiling.md)
On Windows there are no dependencies - you can always compile the latest version just by downloading the code and compiling the solution in Visual Studio. If you want to modify the Qt UI with a WYSIWYG editor you will need a version of Qt installed - at least version 5.6.
RenderDoc only supports building on 64-bit x86 linux. 32-Bit x86 and any ARM/other platforms are not supported.
Requirements for the core library and renderdoccmd are libx11
, libxcb
, libxcb-keysyms
and libGL
. The exact are packages for these vary by distribution.
For qrenderdoc you need Qt5 >= 5.6 along with the 'svg' and 'x11extras' packages. You also need python3-dev
for the python integration, and bison
, autoconf
, automake
and libpcre3-dev
for building the custom SWIG tool for generating bindings.
On any distribution if you find qmake isn't available under its default name, or if qmake -v
lists a Qt4 version, make sure you have qtchooser installed in your package manager and use it to select Qt5. This might be done by exporting QT_SELECT=qt5
, but check with your distribution for details.
For some distributions such as CentOS and Fedora, the Qt5 qmake command is qmake-qt5
. To select this explicitly, pass -DQMAKE_QT5_COMMAND=qmake-qt5
when invoking cmake
.
Below are specific per-distribution instructions. If you know the required packages for another distribution, please share (or pull request this file!)
For Ubuntu 14.04 or above you'll need:
sudo apt-get install libx11-dev libx11-xcb-dev mesa-common-dev libgl1-mesa-dev libxcb-keysyms1-dev cmake python3-dev bison autoconf automake libpcre3-dev
For the base dependencies. On Ubuntu 18.04 and above Qt is available in the default repositories:
sudo apt-get install qt5-qmake libqt5svg5-dev libqt5x11extras5-dev
For older versions of Ubuntu they might not include a recent enough Qt version, so you can use Stephan Binner's ppas to install a more recent version of Qt. At least 5.6.2 is required. If you choose to instead install an official Qt release or build Qt from source, add -DQMAKE_QT5_COMMAND=/path/to/qmake
to your cmake arguments.
For Archlinux (as of 2019.04.12) you'll need:
sudo pacman -S libx11 libxcb xcb-util-keysyms mesa libgl qt5-base qt5-svg qt5-x11extras cmake python3 bison autoconf automake pcre make pkg-config
For Gentoo (as of 2017.04.18), you'll need:
sudo emerge --ask x11-libs/libX11 x11-libs/libxcb x11-libs/xcb-util-keysyms dev-util/cmake dev-qt/qtcore dev-qt/qtgui dev-qt/qtwidgets dev-qt/qtsvg dev-qt/qtx11extras sys-devel/bison sys-devel/autoconf sys-devel/automake dev-lang/python dev-libs/libpcre
Checking that at least Qt 5.6 installs.
On CentOS 7 (as of 2018.01.18), you'll need to install from several repos:
# Dependencies in default repo
yum install libX11-devel libxcb-devel mesa-libGL-devel xcb-util-keysyms-devel cmake qt5-qtbase-devel qt5-qtsvg-devel qt5-qtx11extras-devel bison autoconf automake pcre-devel
# python3 via EPEL
yum install epel-release
yum install python34-devel
# Newer GCC via SCL's devtoolset-7
yum install centos-release-scl
yum install devtoolset-7
Then when building, you must first set up the devtoolset-7 from SCL:
scl enable devtoolset-7 bash
And build within the resulting bash shell, which has the tools first in PATH.
On Fedora 33 (as of 2020.11.05), you'll need:
sudo yum install libX11-devel libxcb-devel mesa-libGL-devel xcb-util-keysyms-devel cmake qt5-qtbase-devel qt5-qtsvg-devel qt5-qtx11extras-devel bison autoconf automake pcre-devel python3-devel
Debian 9+ (stretch):
sudo apt-get install libx11-dev libx11-xcb-dev mesa-common-dev libgl1-mesa-dev libxcb-keysyms1-dev cmake python3-dev bison autoconf automake libpcre3-dev qt5-qmake libqt5svg5-dev libqt5x11extras5-dev
Mac requires Xcode version 12.2 or newer, CMake version 3.20 or newer, and Qt5 version 5.15.2 or newer. If you're using homebrew then this will do the trick:
brew install cmake qt5
brew link qt5 --force
You will also need autotools
. That is usually available by default but might need to be explicitly installed with brew install autoconf automake
.
To build for Android, you must download components of the Android SDK, the Android NDK, and Java Development Kit.
RenderDoc is currently known to build with NDK 14b, SDK tools 3859397, SDK build-tools 26.0.1, SDK platform android-23, Java 8 (also known as 1.8). If you use different versions of any of these it is up to you to ensure you have compatible versions of all as otherwise build failures may occur as versions of some components may not be compatible with different (even newer) versions of other components.
If you've already got the tools required, simply set the following three environment variables:
export ANDROID_SDK=<path_to_sdk_root>
export ANDROID_NDK=<path_to_ndk_root>
export JAVA_HOME=<path_to_jdk_root>
Otherwise, below are steps to acquire the tools for each platform. These steps download specifically the versions listed above, other versions may work but are not guaranteed.
JDK 8 can be installed from the following link.
set JAVA_HOME=<path_to_jdk_root>
Android NDK and SDK:
# Set up the Android SDK
set ANDROID_SDK=<path_to_desired_setup>
cd %ANDROID_SDK%
wget https://dl.google.com/android/repository/sdk-tools-windows-3859397.zip
unzip sdk-tools-windows-3859397.zip
cd tools\bin
sdkmanager --sdk_root=%ANDROID_SDK% "build-tools;26.0.1" "platforms;android-23"
# Accept the license
# Set up the Android NDK
cd %ANDROID_SDK%
wget http://dl.google.com/android/repository/android-ndk-r14b-windows-x86_64.zip
unzip android-ndk-r14b-windows-x86_64.zip
set ANDROID_NDK=%ANDROID_SDK%\android-ndk-r14b
The JDK 8 can be installed with:
sudo apt-get install openjdk-8-jdk
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
The Android SDK and NDK can be set up with the following steps.
SDK links are pulled from here (older versions are no longer linked from the android site, but the downloads still work).
NDK links are pulled from here.
# Set up Android SDK
export ANDROID_SDK=<path_to_desired_setup>
pushd $ANDROID_SDK
wget http://dl.google.com/android/repository/sdk-tools-linux-3859397.zip
unzip sdk-tools-linux-3859397.zip
cd tools/bin/
./sdkmanager --sdk_root=$ANDROID_SDK "build-tools;26.0.1" "platforms;android-23"
# Accept the license
# Set up Android NDK
pushd $ANDROID_SDK
wget http://dl.google.com/android/repository/android-ndk-r14b-linux-x86_64.zip
unzip android-ndk-r14b-linux-x86_64.zip
export ANDROID_NDK=$ANDROID_SDK/android-ndk-r14b
JDK can be installed with brew:
brew cask install java
export JAVA_HOME="$(/usr/libexec/java_home)"
Android NDK and SDK:
# Set up Android SDK
export ANDROID_SDK=<path_to_desired_setup>
pushd $ANDROID_SDK
wget https://dl.google.com/android/repository/sdk-tools-darwin-3859397.zip
unzip sdk-tools-darwin-3859397.zip
cd tools/bin/
./sdkmanager --sdk_root=$ANDROID_SDK "build-tools;26.0.1" "platforms;android-23"
# Accept the license
# Set up Android NDK
pushd $ANDROID_SDK
wget https://dl.google.com/android/repository/android-ndk-r14b-darwin-x86_64.zip
unzip android-ndk-r14b-darwin-x86_64.zip
export ANDROID_NDK=$ANDROID_SDK/android-ndk-r14b