-
Notifications
You must be signed in to change notification settings - Fork 484
Customizing liboqs
Various options can be passed to cmake during the build file generation process that can be used to customize the way liboqs is built, and what its functionality is. This page lists and explains each of these options.
- CMAKE_BUILD_TYPE
- OQS_BUILD_TYPE
- USE_SANITIZER
- OQS_KEM_DEFAULT
- OQS_SIG_DEFAULT
- OQS_USE_OPENSSL
- OQS_ENABLE_KEM_<ALG>
It can take the following values:
-
Debug
: This will turn off all optimizations and compile the code with debug information included. For this value, when the compiler is Clang, the USE_SANITIZER flag can also be passed in to enable a Clang Sanitizer build. This value only has effect when the compiler is GCC or Clang. -
Generic
: This enables code to built with theO3
optimization level, and other flags are set that reduce the binary size. This does not enable CPU extensions such as AVX2, SSE, etc., so as to preserve the resulting binary's portability, since such feature detection is not done during runtime. This value only has effect when the compiler is GCC or Clang. -
Optimized
: This, along with all the flags enabled by theGeneric
value, adds the-march=native
flag to enable the use of CPU features. The resulting binary will not be portable. This value only has effect when the compiler is GCC or Clang. -
Dependency
: This is for third-party software that use liboqs as a dependency. When specified, onlyliboqs
is built, and targets such asrun_tests
,gen_docs
are not made available to the build system. This can prevent name collisions, for example, whenadd_subdirectory()
is used to incorporate liboqs into the build process.
This is identical to CMAKE_BUILD_TYPE. It is a separate option so that third-party software can use add_subdirectory()
to incorporate liboqs into the build process, and can set the CMAKE_BUILD_TYPE
for their projects as desired.
This has effect when the compiler is Clang and when CMAKE_BUILD_TYPE is Debug
. Then, it can take the following values:
-
Address
: This enables Clang's AddressSanitizer -
Memory
: This enables Clang's MemorySanitizer -
MemoryWithOrigins
: This enables Clang's MemorySanitizer with the added functionality of being able to track origins of uninitialized values -
Undefined
: This enables Clang's UndefinedBehaviorSanitizer. Here, theBLACKLIST_FILE
option can be specified additionally to specify a path to a file listing the entities Clang should ignore -
Thread
: This enables Clang's ThreadSanitizer -
Leak
: This enables Clang's LeakSanitizer
liboqs exposes OQS_KEM_alg_default
as part of it's API. This represents the default
key-exchange algorithm and can be set at compile-time through the OQS_KEM_DEFAULT
option. For example: to set the default KEM to Frodo 976 AES, the option -DOQS_KEM_DEFAULT="OQS_KEM_alg_frodokem_976_aes"
can be passed in. The full list of the possible identifiers that can be specified can be found in src/kem/kem.h.
liboqs exposes OQS_SIG_alg_default
as part of it's API. This represents the default
digital signature algorithm and can be set at compile-time through the OQS_SIG_DEFAULT
option. For example: to set the default SG to Dilithium 2, the option -DOQS_SIG_DEFAULT="OQS_SIG_alg_dilithium_2"
can be passed in. The full list of the possible identifiers that can be specified can be found in src/sig/sig.h.
This can be set to ON
or OFF
. When ON
, the further options OQS_USE_AES_OPENSSL
, OQS_USE_SHA2_OPENSSL
, and OQS_USE_SHA3_OPENSSL
are made available and set to ON
by default: they control whether liboqs uses OpenSSL's AES, SHA-2, and SHA-3 implementations.
When set to ON
, CMake also scans the filesystem to find a version of OpenSSL that satisfies liboqs' requirements (which happens to be 1.1.1). The OPENSSL_ROOT_DIR
option can be passed to aid CMake in its search.