Skip to content

Latest commit

 

History

History
executable file
·
121 lines (95 loc) · 6.19 KB

BUILD.md

File metadata and controls

executable file
·
121 lines (95 loc) · 6.19 KB

CodeXL build instructions

Cloning

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

python CodeXL/Scripts/FetchDependencies.py

Windows

Installations

Building CodeXL

  • Open the following solution in Visual Studio: CodeXL\AllProjectsBuild\CodeXL-AllProjects.sln
  • Build 64 bit configuration
  • Build 32 bit configuration

CodeXL property sheets

  • 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"

Linux

  • CodeXL uses the SCons build system on Linux.
  • CodeXL require GCC version 4.8.5 or higher.

Building on Ubuntu 15.04 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
Ubuntu 16.04 specific
  • sudo apt-get install libboost-all-dev

Go to the Building the JAVA Agent section

Building on CENTOS 7.X

Install SCons
  • wget http://prdownloads.sourceforge.net/scons/scons-2.5.0-1.noarch.rpm
  • sudo rpm -ivh scons-2.5.0-1.noarch.rpm
Install additional dependencies
  • 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
Install x86 dependencies
  • yum -y install glibc-devel.i686 libstdc++-static.i686

Building the JAVA Agent:

  • 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.

Building CodeXL

  • CD to local copy of /CodeXL/Util/linux/
  • Run ./buildCodeXLFullLinuxProjects

Build Switches

  • 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.

Specific build instructions Ubuntu 16.04

  • 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

Running CodeXL

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

Using Detours Express 3.0 for graphics backend injection with Windows builds of CodeXL

  • 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
  • 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.