#!/bin/bash
set -e
SCRIPT_DIR=$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)
HITLS_ROOT_DIR=$(cd "${SCRIPT_DIR}/../.." && pwd)
hitls_compile_option=()
paramList=$@
paramNum=$#
feature_options="-DHITLS_BUILD_GEN_INFO=ON"
add_options=""
del_options=""
add_link_flags=""
get_arch=`arch`
executes="OFF"
LIB_TYPE="static shared"
enable_sctp="--enable-sctp"
BITS=64
subdir="CMVP"
libname=""
build_crypto_module_provider=false
debug_mode=false
case "$(uname)" in
Linux)
SHARED_LIB_EXT=".so"
;;
Darwin)
SHARED_LIB_EXT=".dylib"
;;
FreeBSD|OpenBSD|NetBSD)
SHARED_LIB_EXT=".so"
;;
*)
echo "Warning: Unknown platform '$(uname)', assuming .so extension"
SHARED_LIB_EXT=".so"
;;
esac
usage()
{
printf "%-50s %-30s\n" "Build openHiTLS Code" "sh build_hitls.sh"
printf "%-50s %-30s\n" "Build openHiTLS Code With Gcov" "sh build_hitls.sh gcov"
printf "%-50s %-30s\n" "Build openHiTLS Code With Debug" "sh build_hitls.sh debug"
printf "%-50s %-30s\n" "Build openHiTLS Code With Asan" "sh build_hitls.sh asan"
printf "%-50s %-30s\n" "Build openHiTLS Code With Pure C" "sh build_hitls.sh pure_c"
printf "%-50s %-30s\n" "Build openHiTLS Code With X86_64" "sh build_hitls.sh x86_64"
printf "%-50s %-30s\n" "Build openHiTLS Code With Armv8_be" "sh build_hitls.sh armv8_be"
printf "%-50s %-30s\n" "Build openHiTLS Code With Armv8_le" "sh build_hitls.sh armv8_le"
printf "%-50s %-30s\n" "Build openHiTLS Code With Add Options" "sh build_hitls.sh add-options=xxx"
printf "%-50s %-30s\n" "Build openHiTLS Code With No Provider" "sh build_hitls.sh no-provider"
printf "%-50s %-30s\n" "Build openHiTLS Code With No Sctp" "sh build_hitls.sh no_sctp"
printf "%-50s %-30s\n" "Build openHiTLS Code With Bits" "sh build_hitls.sh bits=xxx"
printf "%-50s %-30s\n" "Build openHiTLS Code With Lib Type" "sh build_hitls.sh shared"
printf "%-50s %-30s\n" "Build openHiTLS Code With command line" "sh build_hitls.sh exe"
printf "%-50s %-30s\n" "Build openHiTLS Code With Iso Provider" "sh build_hitls.sh iso"
printf "%-50s %-30s\n" "Build openHiTLS Code With Help" "sh build_hitls.sh help"
}
clean()
{
rm -rf ${HITLS_ROOT_DIR}/build
mkdir ${HITLS_ROOT_DIR}/build
}
build_hitls_code()
{
cd ${HITLS_ROOT_DIR}/build
feature_options="${feature_options} -DHITLS_BUILD_PROFILE=full"
feature_options="${feature_options} -DHITLS_CRYPTO_RAND_CB=ON"
feature_options="${feature_options} -DHITLS_EAL_INIT_OPTS=9 -DHITLS_CRYPTO_ASM_CHECK=ON"
feature_options="${feature_options} -DHITLS_CRYPTO_ENTROPY=ON -DHITLS_CRYPTO_ENTROPY_DEVRANDOM=ON -DHITLS_CRYPTO_ENTROPY_GETENTROPY=ON -DHITLS_CRYPTO_ENTROPY_SYS=ON -DHITLS_CRYPTO_ENTROPY_HARDWARE=ON"
feature_options="${feature_options} -DHITLS_CRYPTO_DRBG_GM=ON"
feature_options="${feature_options} -DHITLS_CRYPTO_ACVP_TESTS=ON"
feature_options="${feature_options} -DHITLS_CRYPTO_DSA_GEN_PARA=ON"
feature_options="${feature_options} -DHITLS_TLS_FEATURE_SM_TLS13=ON"
feature_options="${feature_options} -DHITLS_CRYPTO_LMS=ON -DHITLS_CRYPTO_HSS=ON"
if [[ $executes = "ON" ]]; then
feature_options="${feature_options} -DHITLS_BUILD_EXE=ON -DHITLS_CRYPTO_CMVP=ON"
fi
if [[ "$(uname)" != "Darwin" ]]; then
add_link_flags="${add_link_flags} -ldl"
else
add_options="${add_options} -fno-inline"
fi
if [[ $enable_sctp = "--enable-sctp" ]]; then
feature_options="${feature_options} -DHITLS_BSL_UIO_SCTP=ON"
else
feature_options="${feature_options} -DHITLS_BSL_UIO_SCTP=OFF"
fi
[[ "$LIB_TYPE" == *"static"* ]] && feature_options="${feature_options} -DHITLS_BUILD_STATIC=ON"
[[ "$LIB_TYPE" == *"shared"* ]] && feature_options="${feature_options} -DHITLS_BUILD_SHARED=ON"
if [[ $get_arch = "x86_64" ]]; then
echo "Compile: env=x86_64, c, little endian, 64bits"
feature_options="${feature_options} -DHITLS_CRYPTO_SP800_STRICT_CHECK=ON"
feature_options="${feature_options} -DHITLS_SM2_PRECOMPUTE_512K_TBL=OFF"
feature_options="${feature_options} -DHITLS_ASM_X8664=ON -DHITLS_PLATFORM_ENDIAN=little"
if [[ $debug_mode = false ]]; then
add_options="${add_options} -O3"
fi
del_options="${del_options} -O2"
elif [[ $get_arch = "armv8_be" ]]; then
echo "Compile: env=armv8, asm + c, big endian, 64bits"
feature_options="${feature_options} -DHITLS_ASM_ARMV8=ON -DHITLS_PLATFORM_ENDIAN=big"
elif [[ $get_arch = "armv8_le" ]]; then
echo "Compile: env=armv8, asm + c, little endian, 64bits"
feature_options="${feature_options} -DHITLS_ASM_ARMV8=ON -DHITLS_PLATFORM_ENDIAN=little"
if [[ $debug_mode = false ]]; then
add_options="${add_options} -O3"
fi
del_options="${del_options} -O2"
else
echo "Compile: env=$get_arch, c, little endian, 64bits"
feature_options="${feature_options} -DHITLS_PLATFORM_ENDIAN=little"
fi
for option in ${add_options}; do
if [[ $option == -DHITLS* ]]; then
feature_option="${option#-D}"
if [[ $feature_option == *=* ]]; then
feature_options="${feature_options} -D${feature_option}"
else
feature_options="${feature_options} -D${feature_option}=ON"
fi
add_options="${add_options//$option/}"
fi
done
if [[ "$(uname)" = "Darwin" ]]; then
cmake .. ${feature_options} \
-DCMAKE_C_FLAGS="${add_options}" \
-D_HITLS_COMPILE_OPTIONS_DEL="${del_options}" \
-DCMAKE_SHARED_LINKER_FLAGS="${add_link_flags} -flat_namespace -undefined dynamic_lookup -Wl,-interposable" \
-DCMAKE_EXE_LINKER_FLAGS="${add_link_flags} -flat_namespace -undefined dynamic_lookup"
else
cmake .. ${feature_options} \
-DCMAKE_C_FLAGS="${add_options}" \
-D_HITLS_COMPILE_OPTIONS_DEL="${del_options}" \
-DCMAKE_SHARED_LINKER_FLAGS="${add_link_flags}" \
-DCMAKE_EXE_LINKER_FLAGS="${add_link_flags}"
fi
make -j
}
build_hitls_provider()
{
cd ${HITLS_ROOT_DIR}/build
rm -f CMakeCache.txt
if [[ $libname = "libhitls_sm${SHARED_LIB_EXT}" ]] && [[ $get_arch = "armv8_le" ]]; then
config_file="${HITLS_ROOT_DIR}/testcode/config/cmake/${subdir}/${get_arch}/${subdir}_sm_feature_config.cmake"
else
if [[ $get_arch = "C" ]]; then
config_file="${HITLS_ROOT_DIR}/cmake/presets/iso19790.cmake"
else
config_file="${HITLS_ROOT_DIR}/testcode/config/cmake/${subdir}/${get_arch}/${subdir}_feature_config.cmake"
fi
fi
feature_options="${feature_options//-DHITLS_TLS_FEATURE_SM_TLS13=ON/}"
echo "Building provider with config: ${config_file}"
cmake .. -DCMAKE_SKIP_RPATH=TRUE -DCMAKE_INSTALL_PREFIX=../output/${subdir}/${get_arch} \
-C ${config_file} \
-D_HITLS_COMPILE_OPTIONS_DEL="${del_options}" \
-DCMAKE_C_FLAGS="${add_options}" \
-DHITLS_BUNDLE_LIB=ON \
${feature_options}
make -j
make install
cd ../output/${subdir}/${get_arch}/lib
if [ ! -f "$libname" ]; then
echo "Error: $libname not found in $(pwd)"
echo "Available files:"
ls -la
exit 1
fi
echo "Successfully built $libname in $(pwd)"
}
parse_option()
{
for i in $paramList
do
key=${i%%=*}
value=${i#*=}
case "${key}" in
"add-options")
add_options="${add_options} ${value}"
;;
"add-feature-options")
feature_options="${feature_options} ${value}"
;;
"no-provider")
feature_options="${feature_options} -DHITLS_TLS_FEATURE_PROVIDER=OFF -DHITLS_CRYPTO_PROVIDER=OFF -DHITLS_CRYPTO_CODECS=OFF -DHITLS_CRYPTO_KEY_DECODE_CHAIN=OFF"
;;
"gcov")
debug_mode=true
add_options="${add_options} -fno-omit-frame-pointer -fprofile-arcs -ftest-coverage -fdump-rtl-expand"
del_options="${del_options} -O3"
;;
"debug")
debug_mode=true
add_options="${add_options} -O0 -g3 -gdwarf-2"
del_options="${del_options} -O2 -O3 -D_FORTIFY_SOURCE=2"
;;
"asan")
debug_mode=true
add_options="${add_options} -fsanitize=address -fsanitize-address-use-after-scope -O0 -g3 -fno-stack-protector -fno-omit-frame-pointer -fgnu89-inline"
del_options="${del_options} -fstack-protector-strong -fomit-frame-pointer -O2 -O3 -D_FORTIFY_SOURCE=2"
;;
"x86_64")
get_arch="x86_64"
;;
"armv8_be")
get_arch="armv8_be"
;;
"armv8_le")
get_arch="armv8_le"
;;
"riscv64")
get_arch="riscv64"
;;
"pure_c")
get_arch="C"
;;
"no_sctp")
enable_sctp=""
;;
"bits")
BITS="$value"
;;
"static")
LIB_TYPE="static"
;;
"shared")
LIB_TYPE="shared"
;;
"exe")
executes="ON"
add_options="${add_options} -fno-plt"
;;
"iso")
if [[ "$(uname)" = "Darwin" ]]; then
echo "Warning: ISO provider build is not supported on macOS, due to sw-entropy skipping..."
else
feature_options="${feature_options} -DHITLS_CRYPTO_CMVP_ISO19790=ON"
libname="libhitls_iso${SHARED_LIB_EXT}"
build_crypto_module_provider=true
fi
;;
"sm")
if [[ "$(uname)" = "Darwin" ]]; then
echo "Warning: SM provider build is not supported on macOS, due to sw-entropy skipping..."
else
feature_options="${feature_options} -DHITLS_CRYPTO_CMVP_SM=ON"
libname="libhitls_sm${SHARED_LIB_EXT}"
build_crypto_module_provider=true
fi
;;
"help")
usage
exit 0
;;
*)
echo "${i} option is not recognized, Please run <sh build_hitls.sh help> get supported options."
usage
exit 0
;;
esac
done
}
clean
parse_option
build_hitls_code
if [[ $build_crypto_module_provider == true ]]; then
build_hitls_provider
fi