-
CMake v3.10 or later
-
libjpeg-turbo SDK v1.2 or later
- The libjpeg-turbo SDK binary packages can be downloaded from https://github.com/libjpeg-turbo/libjpeg-turbo/releases.
- The VirtualGL build system will search for the TurboJPEG header and
library under /opt/libjpeg-turbo on Un*x, but you can override this by
setting the
TJPEG_INCLUDE_DIR
CMake variable to the directory containing turbojpeg.h and theTJPEG_LIBRARY
CMake variable to either the full path of the TurboJPEG library against which you want to link or a set of link flags needed to link with the TurboJPEG library (for instance,-DTJPEG_LIBRARY="-L/opt/libjpeg-turbo/lib64 -lturbojpeg"
.)
-
G++ or Clang
-
X11 and OpenGL development libraries:
- libX11, libXext, libXtst, libGL, and libGLU
- libEGL, libxcb, and libxcb-keysyms (if building the VirtualGL Faker)
- libXv (if building VirtualGL with X Video support)
- On Mac platforms, these are distributed with XQuartz.
- The OpenGL and GLX headers must be reasonably modern (generally Mesa 9 or later, or the equivalent.)
- libX11, libXext, libXtst, libGL, and libGLU
-
OpenCL development libraries [if building the VirtualGL Faker with the OpenCL interposer enabled]
- On Red Hat Enterprise Linux 6-7 (and work-alikes), these are located in the EPEL repository.
-
Some requisite development libraries are located in the CRB (Code Ready Builder) or PowerTools repository on Red Hat Enterprise Linux 8+ and derivatives, which is not enabled by default.
In order to run 32-bit OpenGL applications using VirtualGL on a 64-bit Linux platform, it is necessary to build both 32-bit and 64-bit versions of the VirtualGL server components. However, most recent x86-64 Linux distributions do not ship with the 32-bit libraries necessary to build a 32-bit version of VirtualGL. To build 32-bit VirtualGL components on an x86-64 Linux system, you will need, at minimum, the following 32-bit development libraries:
- glibc and libstdc++
- X11 and OpenGL (see above)
Instructions for installing these on specific distributions:
-
Execute the following command as root:
yum install libXv-devel.i686 libXext-devel.i686 libXtst-devel.i686 libX11-devel.i686 libxcb-devel.i686 xcb-util-keysyms-devel.i686 mesa-libGLU-devel.i686 mesa-libGL-devel.i686 mesa-libEGL-devel.i686 glibc-devel.i686 libstdc++-devel.i686 libstdc++-static.i686
- Replace
yum
withdnf
on Fedora 23+ or RHEL 8+. - Add
ocl-icd-devel.i686
to the command line if building the VirtualGL Faker with the OpenCL interposer enabled.
- Replace
-
Execute the following command as root:
apt-get install g++-multilib libxv-dev:i386 libxtst-dev:i386 libx11-xcb-dev:i386 libxcb-keysyms1-dev:i386 libegl1-mesa-dev:i386 libglu1-mesa-dev:i386
- Add
ocl-icd-opencl-dev:i386
to the command line if building the VirtualGL Faker with the OpenCL interposer enabled.
- Add
Binary objects, libraries, and executables are generated in the directory from which CMake is executed (the "binary directory"), and this directory need not necessarily be the same as the VirtualGL source directory. You can create multiple independent binary directories, in which different versions of VirtualGL can be built from the same source tree using different compilers or settings. In the sections below, {build_directory} refers to the binary directory, whereas {source_directory} refers to the VirtualGL source directory. For in-tree builds, these directories are the same.
The following procedure will build the VirtualGL Client and, on Linux and other Un*x variants (except Mac), the VirtualGL Server components. On most 64-bit systems (Solaris being a notable exception), this will build a 64-bit version of VirtualGL. See "Build Recipes" for specific instructions on how to build a 32-bit or 64-bit version of VirtualGL on systems that support both.
cd {build_directory}
cmake -G"Unix Makefiles" [additional CMake flags] {source_directory}
make
Replace make
with ninja
and Unix Makefiles
with Ninja
if using Ninja.
Add -DCMAKE_BUILD_TYPE=Debug
to the CMake command line.
Use export/setenv to set the following environment variables before running CMake:
CFLAGS=-m32
CXXFLAGS=-m32
LDFLAGS=-m32
Use export/setenv to set the following environment variables before running CMake:
CFLAGS=-m64
CXXFLAGS=-m64
LDFLAGS=-m64
On Un*x systems, prior to running CMake, you can set the CC
environment
variable to the command used to invoke the C compiler and the CXX
environment
variable to the command used to invoke the C++ compiler.
To list and configure other CMake options not specifically mentioned in this guide, run
ccmake {source_directory}
or
cmake-gui {source_directory}
from the build directory after initially configuring the build. CCMake is a text-based interactive version of CMake, and CMake-GUI is a GUI version. Both will display all variables that are relevant to the VirtualGL build, their current values, and a help string describing what they do.
You can use the build system to install VirtualGL (as opposed to creating an
installer package.) To do this, run make install
or ninja install
.
Running make uninstall
or ninja uninstall
will uninstall VirtualGL.
The CMAKE_INSTALL_PREFIX
CMake variable can be modified in order to install
VirtualGL into a directory of your choosing. If you don't specify
CMAKE_INSTALL_PREFIX
, then the default is /opt/VirtualGL. The default
value of CMAKE_INSTALL_PREFIX
causes the VirtualGL files to be installed with
a directory structure resembling that of the official VirtualGL binary
packages. Changing the value of CMAKE_INSTALL_PREFIX
(for instance, to
/usr/local) causes the VirtualGL files to be installed with a directory
structure that conforms to GNU standards.
The CMAKE_INSTALL_BINDIR
, CMAKE_INSTALL_DATAROOTDIR
,
CMAKE_INSTALL_DOCDIR
, CMAKE_INSTALL_INCLUDEDIR
, and CMAKE_INSTALL_LIBDIR
CMake variables allow a finer degree of control over where specific files in
the VirtualGL distribution should be installed. These directory variables can
either be specified as absolute paths or as paths relative to
CMAKE_INSTALL_PREFIX
(for instance, setting CMAKE_INSTALL_DOCDIR
to doc
would cause the documentation to be installed in
${CMAKE_INSTALL_PREFIX}/doc.) If a directory variable contains the name
of another directory variable in angle brackets, then its final value will
depend on the final value of that other variable. For instance, the default
value of CMAKE_INSTALL_DOCDIR
if installing under /opt/VirtualGL is
<CMAKE_INSTALL_DATAROOTDIR>/doc.
The following commands can be used to create various types of distribution
packages (replace make
with ninja
if using Ninja):
make rpm
Create Red Hat-style binary RPM package. Requires RPM v4 or later.
make deb
Create Debian-style binary package. Requires dpkg.
make dmg
Create Mac package/disk image. This requires pkgbuild and productbuild, which are installed by default on OS X/macOS 10.7 and later.