Skip to content

Latest commit

 

History

History
152 lines (95 loc) · 4.64 KB

INSTALL.markdown

File metadata and controls

152 lines (95 loc) · 4.64 KB

Requirements

Requirements common for all platforms:

  • Python version 2.7

    • Python Image Library
  • CMake version 2.8.8 or higher (tested with version 2.8.12.2)

The GUI also dependends on:

  • Qt version 5.2.1 or higher (tested with version 5.4.0 and 5.3.0; use the 6.1 release, if you must build with Qt4)

Qt will be required if -DENABLE_GUI=TRUE is passed to CMake, and never used if -DENABLE_GUI=FALSE is passed instead. The implicit default is -DENABLE_GUI=AUTO, which will build the GUI if Qt is available.

The code also depends on zlib, libpng, and snappy libraries, but the bundled sources are always used regardless of system availability, to make the wrapper shared-objects/DLL self contained, and to prevent symbol collisions when tracing.

Linux

Additional optional dependencies:

  • libprocps (procps development libraries)

  • libdwarf

Build as:

cmake -H. -Bbuild -DCMAKE_BUILD_TYPE=RelWithDebInfo
make -C build

Other possible values for CMAKE_BUILD_TYPE Debug, Release, RelWithDebInfo, and MinSizeRel.

You can also build the 32-bits GL wrapper on a 64-bits distribution, provided you have a multilib gcc and 32-bits X11 libraries, by doing:

cmake \
    -H. -Bbuild32 \
    -DCMAKE_C_FLAGS=-m32 \
    -DCMAKE_CXX_FLAGS=-m32 \
    -DCMAKE_EXE_LINKER_FLAGS=-m32 \
    -DCMAKE_SYSTEM_LIBRARY_PATH=/usr/lib32 \
    -DENABLE_GUI=FALSE
make -C build32 glxtrace

The /usr/lib32 refers to the path where the 32-bits shared objects are may differ depending on the actual Linux distribution.

Mac OS X

Build as:

cmake -H. -Bbuild -DCMAKE_BUILD_TYPE=RelWithDebInfo -DCMAKE_PREFIX_PATH=~/QtX.Y.Z/X.Y/clang_64
make -C build

Android

Additional requirements:

Build as:

export ANDROID_NDK=/path/to/your/ndk
cmake -H. -Bbuild -DCMAKE_TOOLCHAIN_FILE=cmake/toolchain/android.toolchain.cmake -DANDROID_API_LEVEL=9
make -C build

You can also choose a particular ABI by passing ANDROID_ABI variable to cmake, e.g., -DANDROID_ABI=x86. Currently, when targeting AArch64 you must build with GCC, by invoking CMake as:

cmake \
    -H. -Bbuild \
    -DCMAKE_TOOLCHAIN_FILE=cmake/toolchain/android.toolchain.cmake \
    -DANDROID_API_LEVEL=9 \
    -DANDROID_TOOLCHAIN_NAME=aarch64-linux-android-4.9 \
    -DANDROID_ABI=arm64-v8a

FirefoxOS

Put Apitrace source tree into B2GROOT/external/apitrace/ and the Android.mk file (B2GROOT/external/apitrace/Android.mk) will do the needful to compile and install apitrace appropriately into the system image as part of FirefoxOS build process. It expects a linaro-type of Android NDK to be present in ../../prebuilt/ndk/android-ndk-r7 (ie B2GROOT/prebuilt/ndk/android-ndk-r7).

Windows

Microsoft Visual Studio

Additional requirements:

  • Microsoft Visual Studio (tested with 2013 version)

  • Windows 8.1 SDK for D3D11.2 headers.

  • Microsoft DirectX SDK is now part of Microsoft Visual Studio (from version 2012), but D3D8 headers are not included, so if you want D3D8 support you'll need to donwload and install the August 2007 release of DirectX SDK

To build with Visual Studio first invoke CMake GUI as:

cmake-gui -H. -Bbuild -DCMAKE_PREFIX_PATH=C:\Qt\QtX.Y.Z\X.Y\msvc2013

and press the Configure button.

It will try to detect most required/optional dependencies automatically. When not found automatically, you can manually specify the location of the dependencies from the CMake GUI.

After you've successfully configured, you can start the build by opening the generated build\apitrace.sln solution file, or invoking CMake as:

cmake --build build --config MinSizeRel

The steps to build 64-bits version are similar, but choosing Visual Studio xx Win64 instead of Visual Studio xx.

By default, binaries generated by recent builds of Visual Studio will not work on Windows XP. If you want to obtain binaries that on Windows XP then pass the -T v110_xp or -T v120_xp options to cmake when building with Visual Studio 2012 or 2013 respectively.

MinGW

Additional requirements:

It's also possible to cross-compile Windows binaries from Linux with MinGW cross compilers.