CodeXL has several submodules. Clone with the --recursive
flag to download all the source code required to build. For example:
git clone --recursive https://github.com/GPUOpen-Tools/CodeXL
To initialize the submodules after cloning the main repository run the following commands:
git submodule init
git submodule update
CodeXL uses
- Radeon Compute Profiler for profiling OpenCL and HSA (Linux only) compute applications. See https://github.com/GPUOpen-Tools/RCP.
- Radeon Graphics Analyzer for analyzing Shaders and OpenCL Kernels. See https://github.com/GPUOpen-Tools/RGA. To fetch these command line tools run the following command:
python CodeXL/Scripts/FetchDependencies.py
- Latest AMD Radeon Software from http://support.amd.com/en-us/download
- Microsoft Visual Studio 2015 Community Edition or higher + Update 1
- Windows 10 SDK Version 10.0.10586.0 from https://developer.microsoft.com/en-US/windows/downloads/windows-10-sdk
- JDK from http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
- CodeXL requires the Java JDK for CPU Profiling support of Java applications
- Open the following solution in Visual Studio: CodeXL\AllProjectsBuild\CodeXL-AllProjects.sln
- Build 64 bit configuration
- Build 32 bit configuration
- Most of project configurations are defined in dedicated property sheets
- In order to alter windows SDK installation directory use "Global-WindowsSDK" property sheet and change user macro "WindowsSDKDir"
- CodeXL uses the SCons build system on Linux.
- CodeXL require GCC version 4.8.5 or higher.
sudo apt-get install gcc-multilib g++-multilib
sudo apt-get install libglu1-mesa-dev mesa-common-dev libgtk2.0-dev
sudo apt-get install zlib1g-dev libx11-dev:i386
sudo apt-get install scons
sudo apt-get install libjpeg9-dev
sudo apt-get install libfltk1.3-dev
sudo apt-get install libboost-all-dev
Go to the Building the JAVA Agent section
wget http://prdownloads.sourceforge.net/scons/scons-2.5.0-1.noarch.rpm
sudo rpm -ivh scons-2.5.0-1.noarch.rpm
sudo yum install libX11-devel mesa-libGL-devel mesa-libGLU-devel
sudo yum install zlib-devel gtk2-devel libpng12
sudo yum install fltk-devel libjpeg-turbo-devel
yum -y install glibc-devel.i686 libstdc++-static.i686
- Install Java JDK (version 1.7.x or higher) from Linux distribution (for example:
sudo yum install java-1.8.0-openjdk-devel
\sudo apt-get install openjdk-8-jdk-headless
). - Or download and install latest JDK for linux Oracle site: http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
- Before build please define JAVA_HOME variable for example : export JAVA_HOME=/opt/java/jdk1.8.0_77
- If JAVA_HOME variable is not defined the build will skip the Java agent project.
- CD to local copy of /CodeXL/Util/linux/
- Run
./buildCodeXLFullLinuxProjects
- all SCons general switches, like -c for clean , more info at http://scons.org/doc/HTML/scons-man.html
- -j specify the number of concurrent jobs (-j6).
- CXL_build=[debug|release] - build type. If not stated default value is release.
- CXL_build_verbose=1 - verbose output
- CXL_boost_lib_dir=[path to boost libraries] - override the bundled boost libraries with files in given path
- CXL_boost_include_dir=[path to boost headers] - override the bundled boost headers with files in given path
- CXL_hsa=[true|false] - define if to build HSA parts. If not stated default value is false (skip HSA)
- -c - performs a "clean" of all build targets.
- Since Ubuntu 16.04 comes with gcc 5.3, use the installed system boost libraries. example - ./backend_build.sh boostlibdir /usr/lib/x86_64-linux-gnu ./buildCodeXLFullLinuxProjects -j5 CXL_build=debug CXL_boost_lib_dir=/usr/lib/x86_64-linux-gnu CXL_boost_include_dir=/usr/include/boost
The folder containing the CodeXL binaries can be found in the root folder of CodeXL (Output_x86_64). If a license agreement is not displayed, copy the file CodeXL/Setup/Legal/Public/EndUserLicenseAgreement-Linux.htm to the Legal subdirectory in the CodeXL binaries folder (Output_x86_64/release/bin/Legal) If CodeXL displays an error indicating that it is unable to establish a connection with the CodeXL remote agent, copy the CodeXLRemoteAgentConfig.xml file into your CodeXL binary folder. The source file is in the folder CodeXL/CodeXL/Remote/AMDTRemoteAgent/CodeXLRemoteAgentConfig.xml
- For some Steam games the default injection technique used by CodeXL may not work. In most cases this can be fixed by using Detours Express 3.0.
- Download Detours Express 3.0
- Download the Detours express package from Microsoft: https://www.microsoft.com/en-us/download/details.aspx?id=52586
- Or, by searching for "Detours express 3.0 download".
- Install Detours Express 3.0
- We assume the Detours Express is installed in the following location: "CodeXL\Common\Lib\Ext\Detours Express 3.0"
- The detours files that are used are included by the following file: "\CodeXL\Common\Src\AMDTInterceptor\mhook-dllInjector\dllInjectorDetours.inl"
- Detours can be installed elsewhere but the paths for the included detours files (creatwth.cpp and modules.cpp) will need modifying in dllInjectorDetours.inl
- Edit "CodeXL\Common\Lib\Ext\Detours Express 3.0\src\creatwth.cpp"
- Change the line: "DETOUR_EXE_RESTORE der;" to: "static DETOUR_EXE_RESTORE der;". This struct is quite large and can a cause stack overflow on some systems.
- Replace both occurrences of '#1' in creatwth.cpp with 'InjectDLL'
- Uncomment the #define USE_DETOURS line below and rebuild the solution.