See our online documentation for installation instructions:
For step-by-step compiling instructions for each major operating system and distribution, see:
You can find additional tips for development builds in our online documentation.
Tip: If you have a source tarball from an official release, you can find a copy of the online documentation in the
docs/html
directory.
The rest of this document serves as a reference, detailing each of the build configuration options.
Table Of Contents
- Installing ClamAV
- Known Issues / To-do's:
- Build Requirements
- Getting Started
- CMake Basics
- Custom CMake Config Options
- External Library Depedency Configuration Options
- Compiling For Multiple Architectures (Cross-Compiling)
- Un-install
-
Complete the
MAINTAINER_MODE
option to generate jsparse files with GPerf. -
The test suite will fail to run if you have
pytest
from Python2 installed and you don't havepytest
from Python3 installed. If this happens, run:python3 -m pip install pytest
and then delete your build directory before recompiling clamav and trying again. -
The documentation generated using Doxygen isn't very good.
As of ClamAV 0.104, CMake is required to build ClamAV.
The Windows Visual Studio and Autotools build systems have been removed.
You will need:
- CMake (3.14+ for Unix/Linux; 3.16+ for Windows)
- A C compiler toolchain such as
gcc
,clang
, or Microsoft Visual Studio. - The Rust compiler toolchain.
Recommended tools:
- pkg-config
- Python 3 (to run the test suite)
For Maintainer-mode only (not recommended):
- Flex
- Bison
- Gperf
On systems with multiple implementations of build-time tools it may be desirable to select a specific implementation to use rather than relying on CMake's logic. See Custom CMake Config Options for information on this topic.
For installation instructions, see our online documentation:
Important: Linux users will need the "-dev" or "-devel" package variants which include C headers. For macOS, Homebrew doesn't separate the headers.
App developers that only need libclamav can use the -D ENABLE_LIBCLAMAV_ONLY
option to bypass the libfreshclam and program dependencies.
libclamav requires these library dependencies:
libbz2
/bzip2
libz
/zlib
libxml2
libpcre2
openssl
json-c
libjson-c
/json-c
libmspack
(built-in by default, enable withENABLE_EXTERNAL_MSPACK=ON
)libiconv
(built-in tolibc
99% of the time, not requires on Windows)pthreads
(provided by Linux/Unix; requirespthreads-win32
on Windows)llvm
(optional, see: Bytecode Runtime, below)libcheck
(default, disable withENABLE_TESTS=OFF
)
If you are building an app and need libclamav and libfreshclam but don't need
to build the ClamAV programs, configure the build with -D ENABLE_APP=OFF
.
libfreshclam adds these additional library dependencies:
libcurl
For regular folk who want the ClamAV apps, you'll also need:
libmilter
(Unix/Linux-only, disable withENABLE_MILTER=OFF
)ncurses
orpdcurses
, for ClamDTop.
Optionally, if on a Linux distro with SystemD:
systemd
, so ClamD, FreshClam, ClamOnAcc SystemD service.libsystemd
, so ClamD will support theclamd.ctl
socket.
Important: The following instructions assume that you have created a
build
subdirectory and that subsequent commands are performed from said
directory, like so:
mkdir build && cd build
CMake isn't actually a build system. It is a meta-build system. In other words, CMake is a build system generator.
On Unix systems, CMake generates Makefiles by default, just like Autotools. On Windows, it generates Visual Studio projects by default.
The process for using CMake is very similar to Autotools:
- Configure: Generate the build system.
- Build: Compile the project.
- Install: Install to the "prefix" directory.
You can choose to use a different generator using the -G
option.
For example, on macOS you can generate Xcode projects.
Ninja is a popular build system, available on both Unix and Windows. If you want to use Ninja, you could configure the project with:
cmake .. -G Ninja
For more information about generators, refer to the CMake documentation
CMake provides four build types. These are:
Release
: Optimized for speed, with no debugging info, code or asserts.Debug
: No optimization, asserts enabled, debugging info included.RelWithDebInfo
: LikeRelease
, but with debug info, but no asserts.MinSizeRel
: LikeRelease
but optimizing for size rather than speed.
There are two basic types of generators. How you select the build type for your build will depend on which type of generator you're using:
- Single-config generators (Unix Makefiles, Ninja)
These generate a build system that can only build a single build type.
With a single-config generator, you need to specify the build type up
front. You can do this using the -G
option. For example:
# Configure
cmake .. -G Ninja -D CMAKE_BUILD_TYPE=RelWithDebInfo
# Build
cmake --build .
- Multi-config generators (Xcode, Visual Studio, Ninja Multi-Config)
These generate a build system capable of building more than one build type.
With a multi-config generator, the generated build system can build all
of CMake's different build types. It's up to you to decide which type, or
"config" you want to build at build time instead of at configuration time.
You can do that with the --config
option. For example:
# Configure
cmake .. -G "Ninja Multi-Config"
# Build
cmake --build . --config RelWithDebInfo
Tip:
RelWithDebInfo
is probably the best option for open source projects. It will have the speed optimizations you need. And, if a crash occurs, the crash backtrace you obtain with with a debugger will significantly help in identifying the bug.
For multi-config generators, you will also need to specify the config when
you use ctest
to run the test suite, or if using cpack
to build a package.
Tip: When using the default generator on Unix operating systems, you can also simply call
make
after the firstcmake
command, like so:# Configure cmake .. # Build make -j12 # Install sudo make installSimilarly, if using Ninja, you could call
ninja
directly instead.# Configure cmake .. -G Ninja # Build ninja # Install sudo ninja installAnd for Windows & Mac developers, if generating Visual Studio or Xcode projects, you're free to open those project solutions in Visual Studio or Xcode after the configure step, to use for compiling AND debugging, which may be very useful.
A default from-source install on a Unix system will go in /usr/local
, with:
- applications in
bin
, - daemons in
sbin
, - libraries in
lib
, - headers in
include
, - configs in
etc
, - and databases in
share/clamav
.
Use the following variables to customize the install paths:
CMAKE_INSTALL_PREFIX
: Customize the install prefix.APP_CONFIG_DIRECTORY
: Customize the config directory, may be relative.DATABASE_DIRECTORY
: Customize the database directory, may be relative.SYSTEMD_UNIT_DIR
: Install SystemD service files to a specific directory.
This example configuration should be familiar if you've used the ClamAV packages provided by Debian, Ubuntu, Alpine, and some other distributions:
# Configure
cmake .. \
-D CMAKE_BUILD_TYPE=RelWithDebInfo \
-D CMAKE_INSTALL_PREFIX=/usr \
-D CMAKE_INSTALL_LIBDIR=/usr/lib \
-D APP_CONFIG_DIRECTORY=/etc/clamav \
-D DATABASE_DIRECTORY=/var/lib/clamav \
-D ENABLE_JSON_SHARED=OFF # require libjson-c to be static
# Build
cmake --build .
# Install
sudo cmake --build . --target install
ClamAV has a couple other important paths you can configure. At this time,
these are only configureable through the clamd.conf
application config file:
-
LocalSocket
: You may configure ClamD to listen on a TCP socket or on a "local" socket (a Unix socket). A local socket is probably best, for safety. But that means you'll need to select a path for the local socket. The sample configu sugegsts using the/tmp
directory, but you may wish to select a directory like/var/run/clamav
. -
TemporaryDirectory
: ClamAV creates a lot of temp files when scanning. By default, ClamD and ClamScan will use the system's default temp directory, which is typically/tmp
or/var/tmp
. But it may be best to give ClamAV it's own directory. Maybe/var/lib/clamav-tmp
.
The option to build so that you can run run the tests is enabled by default.
It requires that you provide python3
and libcheck
.
If you're building with ENABLE_LIBCLAMAV_ONLY=ON
or ENABLE_APP=OFF
, then
libcheck
will still be required and you can still run the tests, but it will
skip all app tests and only run the libclamav unit tests.
To run the tests, first build ClamAV, then run ctest
.
Use the following options as needed:
-
-V
: VerboseThis option will show the test output. You may wish to use Pip (
pip3
) to installpytest
as well. If detected at configure-time,pytest
will be used to run the tests and will make it so you only see output from failed tests. -
-C <config>
: Specify which build type to test (e.g.RelWithDebInfo
).This option is only required if using a multi-config generator, such as "Visual Studio", "Xcode", or "Ninja Multi-Config".
On a typical Linux system, you'll probably just run this:
# Configure
cmake .. -D CMAKE_BUILD_TYPE=RelWithDebInfo #... other options snipped
# Build
cmake --build .
# Test
ctest
On Windows, you may run something like this:
# Configure
cmake .. #... other options snipped
# Build
cmake --build . --config RelWithDebInfo
# Test
ctest -C RelWithDebInfo -V
If you encounter a test failure, please re-run ctest
with -V
enabled and
submit the output in a bug report
on GitHub Issues.
The test output is also saved to log files in the unit_tests
directory.
You can zip those up and attach those instead.
Tip: You can configure with
-D ENABLE_TESTS=OFF
to disable test support. This will also remove the dependency on Python and libcheck.
The following is a complete list of CMake options unique to configuring ClamAV:
-
APP_CONFIG_DIRECTORY
: Program config directory. Relative to theCMAKE_INSTALL_PREFIX
unless an absolute path is given.Default: Windows:
.
, POSIX:etc
-
DATABASE_DIRECTORY
: Database directory. Relative to theCMAKE_INSTALL_PREFIX
unless an absolute path is given.Default: Windows:
database
, POSIX:share/clamav
-
CLAMAV_USER
: ClamAV User (POSIX-only).Default:
clamav
-
CLAMAV_GROUP
: ClamAV Group (POSIX-only).Default:
clamav
-
MMAP_FOR_CROSSCOMPILING
: Force MMAP support for cross-compiling.Default:
OFF
-
DISABLE_MPOOL
: Disable mpool support entirely.Default:
OFF
-
BYTECODE_RUNTIME
: Bytecode Runtime, may be:llvm
,interpreter
,none
.Default:
interpreter
-
OPTIMIZE
: Allow compiler optimizations (eg.-O3
). Set toOFF
to disable them (-O0
).Default:
ON
-
ENABLE_WERROR
: Compile time warnings will cause build failures (i.e.-Werror
)Default:
OFF
-
ENABLE_ALL_THE_WARNINGS
: By default we use-Wall -Wextra -Wformat-security
for ClamAV libraries and programs. This option enables a whole lot more.Default:
OFF
-
ENABLE_DEBUG
: Turn on extra debug output. Disclaimer: Does nothing in the current version.Default:
OFF
-
ENABLE_FUZZ
: Build statically linked fuzz targets and nothing else. This feature is for fuzzing with OSS-Fuzz and reproducing fuzz bug reports and requires the following environment variables to be set:- CC =
which clang
- CXX =
which clang++
- SANITIZER = "address" or "undefined" or "memory"
Default:
OFF
- CC =
-
ENABLE_EXTERNAL_MSPACK
: Use external mspack instead of internal libclammspack.Default:
OFF
-
ENABLE_JSON_SHARED
: Prefer linking with libjson-c shared library instead of static.Important: Please set this to
OFF
if you're an application developer that uses a different JSON library in your app OR if you provide libclamav that others may use in their apps. If you link libclamav with the json-c shared library then downstream applications which use a different JSON library may crash!This option is default "ON" only because the libjson-c static library is not available on many systems by default.
Default:
ON
-
ENABLE_APP
: Build the ClamAV programs (clamscan, clamd, clamdscan, sigtool, clambc, clamdtop, clamsubmit, clamconf).Default:
ON
-
ENABLE_CLAMONACC
: (Linux-only) Build the ClamOnAcc on-access scanning daemon. Requires:ENABLE_APP
ClamOnAcc will not compile on MUSL-based Linux distros such as Alpine.
Default:
ON
-
ENABLE_MILTER
: (Posix-only) Build the clamav-milter Sendmail filter daemon. Requires:ENABLE_APP
Default:
OFF
for Mac & Windows,ON
for Linux/Unix -
ENABLE_UNRAR
: Build & install libclamunrar (UnRAR) and libclamunrar_iface.Default:
ON
-
ENABLE_MAN_PAGES
: Generate man pages.Default:
ON
for Linux/Unix,OFF
for Windows -
ENABLE_DOXYGEN
: Generate Doxygen HTML documentation forclamav.h
, andlibfreshclam.h
. Requires Doxygen. To-do: Needs work.Default:
OFF
-
ENABLE_EXAMPLES
: Build the example programs.Default:
OFF
-
ENABLE_TESTS
: Enable support for running the test suite withctest
.Default:
ON
-
ENABLE_LIBCLAMAV_ONLY
: Build libclamav only.Tip: This Excludes libfreshclam too! Use
ENABLE_APP=OFF
instead if you want libclamav and libfreshclam.Default:
OFF
-
ENABLE_STATIC_LIB
: Build libclamav and/or libfreshclam static libraries.Tip: If you wish to build
clamscan
and the other programs statically, you must also setENABLE_SHARED_LIB=OFF
.Default:
OFF
-
ENABLE_SHARED_LIB
: Build libclamav and/or libfreshclam shared libraries.Default:
ON
-
ENABLE_SYSTEMD
: Install SystemD service files if SystemD is found.Default:
ON
-
MAINTAINER_MODE
: Generate Yara lexer and grammar C source with Flex & Bison. Generate Rust bindings (libclamav_rust/src/sys.rs
). To-do: Also generate JS parse source with Gperf.Default:
OFF
-
SYSTEMD_UNIT_DIR
: Install SystemD service files to a specific directory. This will fail the build if SystemD not found.Default: not set
-
PYTHON_FIND_VER
: Select a specific implementation of Python that will be called during the test phase.Default: not set
-
RUST_COMPILER_TARGET
: Use a custom target triple to build the Rust components. Needed for cross-compiling. You must also have installed the target toolchain. See: https://doc.rust-lang.org/nightly/rustc/platform-support.htmlDefault: not set
The CMake tooling is good about finding installed dependencies on POSIX systems
provided that you have pkg-config installed, and the dependencies are installed
in the standard locations (i.e. /usr
and /usr/local
).
But if you:
- have custom install paths for the dependencies,
- want to target static libraries, or
- are building on Windows...
... you may need to use the following build configuration options.
-D LIBCHECK_ROOT_DIR="_path to libcheck install root_"
-D LIBCHECK_INCLUDE_DIR="_filepath of libcheck header directory_"
-D LIBCHECK_LIBRARY="_filepath of libcheck library_"
-D BZIP2_INCLUDE_DIR="_filepath of bzip2 header directory_"
-D BZIP2_LIBRARY_RELEASE="_filepath of bzip2 library_"
-D ZLIB_INCLUDE_DIR="_filepath of zlib header directory_"
-D ZLIB_LIBRARY="_filepath of zlib library_"
-D LIBXML2_INCLUDE_DIR="_filepath of libxml2 header directory_"
-D LIBXML2_LIBRARY="_filepath of libxml2 library_"
-D PCRE2_INCLUDE_DIR="_filepath of libpcre2 header directory_"
-D PCRE2_LIBRARY="_filepath of libcpre2 library_"
-D OPENSSL_ROOT_DIR="_path to openssl install root_"
-D OPENSSL_INCLUDE_DIR="_filepath of openssl header directory_"
-D OPENSSL_CRYPTO_LIBRARY="_filepath of libcrypto library_"
-D OPENSSL_SSL_LIBRARY="_filepath of libssl library_"
Tip: You're strongly encouraged to link with the a static json-c library.
-D JSONC_INCLUDE_DIR="_path to json-c header directory_"
-D JSONC_LIBRARY="_filepath of json-c library_"
These options only apply if you use the -D ENABLE_EXTERNAL_MSPACK=ON
option.
-D MSPack_INCLUDE_DIR="_path to mspack header directory_"
-D MSPack_LIBRARY="_filepath of libmspack library_"
On POSIX platforms, iconv might be part of the C library in which case you would not want to specify an external iconv library.
-D Iconv_INCLUDE_DIR="_path to iconv header directory_"
-D Iconv_LIBRARY="_filepath of iconv library_"
On POSIX platforms, pthread support is detected automatically. On Windows, you need to specify the following:
-D PThreadW32_INCLUDE_DIR="_path to pthread-win32 header directory_"
-D PThreadW32_LIBRARY="_filepath of pthread-win32 library_"
Set:
-D BYTECODE_RUNTIME="llvm"
Options for a custom LLVM install path, or to select a specific version if you have multiple LLVM installations:
-D LLVM_ROOT_DIR="_path to llvm install root_"
-D LLVM_FIND_VERSION="3.6.0"
-D CURL_INCLUDE_DIR="_path to curl header directory_"
-D CURL_LIBRARY="_filepath of curl library_"
-D NCURSES_INCLUDE_DIR="_path to ncurses header directory_"
or:
-D PDCURSES_INCLUDE_DIR="_path to pdcurses header directory_"
and:
-D CURSES_LIBRARY="_filepath of curses library_"
Bytecode signatures are a type of executable plugin that provide extra detection capabilities.
ClamAV has two bytecode runtimes:
-
Interpreter: The bytecode interpreter evaluates and executes bytecode instructions one by one.
With the interpreter, signature database (re)loads are faster, but execution time for scans that make use of the bytecode sigantures is slower.
-
LLVM: LLVM can be used to Just-in-Time (JIT) compile bytecode signatures at database load time.
With LLVM, signature database loading is slower, but bytecode signature execution should be faster. Not all scans will run bytecode signatures, so performance testing will depend heavily depending on what files are tested.
We ran out of time in 0.104 development to update to support newer versions of LLVM. LLVM 3.6.2 is the newest version supported in ClamAV 0.104.
At the moment, the interpreter is the default runtime, while we work out compatibility issues with newer versions of libLLVM. This default equates to:
cmake .. -D BYTECODE_RUNTIME="interpreter"
If you wish to build using LLVM JIT for the bytecode runtime instead of the bytecode interpreter, you will need to install the LLVM development libraries. ClamAV currently supports LLVM versions 8.0 through 12.0.
To build with LLVM for the bytecode runtime, build with this option:
cmake .. \
-D BYTECODE_RUNTIME="llvm"
If you have multiple LLVM installations, or have a custom path for the LLVM
installation, you may also set LLVM_ROOT_DIR
and LLVM_FIND_VERSION
options
to help CMake find the right LLVm installation. For example:
-D LLVM_ROOT_DIR="/opt/llvm/8.0"
-D LLVM_FIND_VERSION="8.0.1"
If the build fails to detect LLVM or linking with LLVM fails using the above options, you may try adding this CMake parameter to enable CMake's package-config feature:
-D CMAKE_FIND_PACKAGE_PREFER_CONFIG=TRUE
Normally, ClamAV would use the FindLLVM.cmake
module in our <src>/cmake
directory to find LLVM. With this option enabled, it will instead try to use
<LLVM_ROOT_DIR>/lib/cmake/llvm/LLVMConfig.cmake
to determine the LLVM package
configuration.
Known Issues: Known issues building with LLVM:
- Enabling
CMAKE_FIND_PACKAGE_PREFER_CONFIG
may fail to build with some LLVM packages that are missing thelibPolly.a
library. This includes some LLVM packages distributed by Debian, Ubuntu, and OpenSUSE.- Not enabling
CMAKE_FIND_PACKAGE_PREFER_CONFIG
may fail to build with some LLVM packages usinggcc
when RTTI was disabled for the LLVM build, but is enabled for the ClamAV build. Usingclang
instead ofgcc
may have better results.- Building ClamAV in Debug-mode with a Release-LLVM build may fail, and building ClamAV in Release-mode with a Debug-LLVM build may fail.
- The unit tests may fail in Debug-mode builds on the
libclamav
"bytecode" test due to an assertion/abort.- Windows-only: CMake fails to collect library dependencies when building with LLVM. That is, the tests will fail because it can't load libssl.dll and other DLL dependencies. This issue only applies when not using VCPkg.
To disable bytecode signature support entirely, you may build with this option:
cmake .. -D BYTECODE_RUNTIME="none"
Cross-compiling in ClamAV with CMake & Rust is experimental at this time. If you have a need to cross-compile, your help and feedback testing and validating cross-compilation support would be appreciated.
The CMake cross-compiling documentation can be found here: CMake Manual
For a cross-build, the library dependencies must have also been built for the target platform, and the CMake options set to target these libraries.
ClamAV's Rust toolchain integration also complicates the build. In addition to specifying the toolchain for C/C++ through the CMake options described in the CMake Manual, you will need to also select the target triple for the Rust compiler toolchain. If you have a mismatch of targets between the C and Rust toolchains, it will fail to compile properly.
The ClamAV project provides a CMake option -D RUST_COMPILER_TARGET=<triple>
that mimics the CMake option when using Clang to cross-compile.
Rust installations typically only come with the target for your current system.
So you will need to install the desired toolchain using rustup target add
.
Run rustup target add --help
for help.
For a list of available target triples, see:
https://doc.rust-lang.org/nightly/rustc/platform-support.html
CMake doesn't provide a simple command to uninstall. However, CMake does build
an install_manifest.txt
file when you do the install. You can use the
manifest to remove the installed files.
You will find the manifest in the directory where you compiled ClamAV. If you
followed the recommendations (above), then you will find it at
<clamav source directory>/build/install_manifest.txt
.
Feel free to inspect the file so you're comfortable knowing what you're about to delete.
Open a terminal and cd
to that <clamav source directory>/build
directory.
Then run:
xargs rm < install_manifest.txt
This will leave behind the directories, and will leave behind any files added after install including the signature databases and any config files. You will have to delete these extra files yourself.
Tip: You may need to use
sudo
, depending on where you installed to.