ext-cryptopp/TestScripts/cryptest-android.sh

243 lines
8.7 KiB
Bash
Raw Normal View History

2016-09-23 16:04:33 +00:00
#!/usr/bin/env bash
2021-02-05 09:49:33 +00:00
#############################################################################
#
2021-02-19 12:54:16 +00:00
# This script tests Android cross-compiles using setenv-android.sh script.
2021-02-05 09:49:33 +00:00
#
2021-03-08 22:51:48 +00:00
# Written and placed in public domain by Jeffrey Walton and Uri Blumenthal.
2021-02-05 09:49:33 +00:00
#
# Crypto++ Library is copyrighted as a compilation and (as of version 5.6.2)
# licensed under the Boost Software License 1.0, while the individual files
# in the compilation are all public domain.
2016-09-23 16:04:33 +00:00
#
# See http://www.cryptopp.com/wiki/Android_(Command_Line) for more details
2021-02-05 09:49:33 +00:00
#
2021-02-05 08:56:14 +00:00
#############################################################################
2021-02-07 08:59:34 +00:00
# Error checking
if [ -z "$(command -v ./setenv-android.sh 2>/dev/null)" ]; then
echo "Failed to locate setenv-android.sh."
exit 1
fi
# Error checking
if [ ! -d "${ANDROID_NDK_ROOT}" ]; then
2021-02-07 11:31:33 +00:00
echo "ERROR: ANDROID_NDK_ROOT is not a valid path for ${USER}. Please set it."
echo "ANDROID_NDK_ROOT is '${ANDROID_NDK_ROOT}'"
2021-02-07 08:59:34 +00:00
exit 1
fi
# Error checking
if [ ! -d "${ANDROID_SDK_ROOT}" ]; then
2021-02-07 11:31:33 +00:00
echo "ERROR: ANDROID_SDK_ROOT is not a valid path for ${USER}. Please set it."
echo "ANDROID_SDK_ROOT is '${ANDROID_SDK_ROOT}'"
2021-02-05 10:18:29 +00:00
exit 1
2018-07-30 19:32:53 +00:00
fi
2021-02-15 21:36:23 +00:00
# Error checking
if [ -z "$(command -v ndk-build 2>/dev/null)" ]; then
echo "ERROR: ndk-build is not on-path for ${USER}. Please set it."
echo "PATH is '${PATH}'"
exit 1
fi
# Temp directory
2021-02-07 16:44:15 +00:00
if [[ -z "${TMPDIR}" ]]; then
TMPDIR="$HOME/tmp"
2021-02-07 16:44:15 +00:00
mkdir -p "${TMPDIR}"
2021-02-15 21:49:26 +00:00
if [ -n "${SUDO_USER}" ]; then
chown -R "${SUDO_USER}" "${TMPDIR}"
2021-02-15 23:14:09 +00:00
fi
fi
2021-02-05 10:18:29 +00:00
# Sane default
if [[ -z "${MAKE_JOBS}" ]]; then
MAKE_JOBS=4
fi
# Cleanup old artifacts
2021-02-07 16:44:15 +00:00
rm -rf "${TMPDIR}/build.failed" 2>/dev/null
rm -rf "${TMPDIR}/build.log" 2>/dev/null
2021-02-05 10:18:29 +00:00
#############################################################################
2021-03-08 22:46:09 +00:00
# Prepare the environment
unset CXX CPPFLAGS CXXFLAGS LDFLAGS
unset ANDROID_CPPFLAGS ANDROID_CXXFLAGS ANDROID_LDFLAGS ANDROID_SYSROOT
if [[ -e TestScripts/setenv-android.sh ]]; then
cp TestScripts/setenv-android.sh .
2021-03-08 22:50:13 +00:00
chmod u+x setenv-android.sh
2021-03-08 22:46:09 +00:00
fi
#############################################################################
PLATFORMS=(armv7a aarch64 x86 x86_64)
for platform in "${PLATFORMS[@]}"
2016-09-23 16:04:33 +00:00
do
2020-03-13 20:20:17 +00:00
# setenv-android.sh reads these two variables for configuration info.
# Android 5.0 is 21. Android 6.0 is 23.
export ANDROID_API="23"
2021-02-07 16:44:15 +00:00
export ANDROID_CPU="${platform}"
2020-03-11 06:22:27 +00:00
make -f GNUmakefile-cross distclean > /dev/null 2>&1
echo
echo "===================================================================="
2021-02-07 16:44:15 +00:00
echo "Testing for Android support of ${platform}"
# Test if we can set the environment for the platform
if ! ./setenv-android.sh > /dev/null 2>&1;
then
echo
2021-02-07 16:44:15 +00:00
echo "There were problems testing ${platform}"
echo "${platform} ==> SKIPPED" >> "${TMPDIR}/build.log"
continue
fi
echo
2021-02-05 10:18:29 +00:00
echo "===================================================================="
2021-02-07 16:44:15 +00:00
echo "Building for ${platform}..."
# run in subshell to not keep any envars
(
2020-03-11 06:22:27 +00:00
source ./setenv-android.sh
2021-02-07 16:44:15 +00:00
if make -k -j "${MAKE_JOBS}" -f GNUmakefile-cross static dynamic cryptest.exe;
then
2021-02-07 16:44:15 +00:00
echo "${platform} ==> SUCCESS" >> "${TMPDIR}/build.log"
else
2021-02-07 16:44:15 +00:00
echo "${platform} ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
# Test code generation
if [[ "${platform}" == "armv7a" ]]
then
# Test NEON code generation
# In the past we looked for the vector loads, stores and shifts using vld and friends.
# It looks like objdump changed its output format on Android after Clang, so we need
# to check for statements like eor v0.16b, v2.16b, v0.16b nowadays.
count=$(${OBJDUMP} --disassemble chacha_simd.o 2>&1 | grep -c -E 'vld|vst|vshl|vshr|veor|v0\.|v1\.|v2\.|v3\.|v4\.|v5\.|v6\.|v7\.')
if [[ "${count}" -gt 64 ]]
then
echo "${platform} : NEON ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : NEON ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
elif [[ "${platform}" == "aarch64" ]]
then
# Test ASIMD code generation
# In the past we looked for the vector loads, stores and shifts using vld and friends.
# It looks like objdump changed its output format on Android after Clang, so we need
# to check for statements like eor v0.16b, v2.16b, v0.16b nowadays.
count=$(${OBJDUMP} --disassemble chacha_simd.o 2>&1 | grep -c -E 'vld|vst|vshl|vshr|veor|v0\.|v1\.|v2\.|v3\.|v4\.|v5\.|v6\.|v7\.')
if [[ "${count}" -gt 64 ]]
then
echo "${platform} : ASIMD ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : ASIMD ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
# Test AES code generation
count=$(${OBJDUMP} --disassemble rijndael_simd.o 2>&1 | grep -c -E 'aese|aesd|aesmc|aesimc')
if [[ "${count}" -gt 32 ]]
then
echo "${platform} : AES ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : AES ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
# Test PMULL code generation
count=$(${OBJDUMP} --disassemble gcm_simd.o 2>&1 | grep -c -E 'pmull|pmull2')
if [[ "${count}" -gt 16 ]]
then
echo "${platform} : PMULL ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : PMULL ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
# Test SHA1 code generation
count=$(${OBJDUMP} --disassemble sha_simd.o 2>&1 | grep -c -E 'sha1c|sha1m|sha1p|sha1h|sha1su0|sha1su1')
if [[ "${count}" -gt 32 ]]
then
echo "${platform} : SHA1 ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : SHA1 ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
# Test SHA2 code generation
count=$(${OBJDUMP} --disassemble sha_simd.o | grep -c -E 'sha256h|sha256su0|sha256su1')
if [[ "${count}" -gt 32 ]]
then
echo "${platform} : SHA2 ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : SHA2 ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
elif [[ "${platform}" == "x86" || "${platform}" == "x86_64" ]]
then
# Test AES code generation
count=$(${OBJDUMP} --disassemble rijndael_simd.o 2>&1 | grep -c -E 'aesenc|aesdec|aesenclast|aesdeclast|aesimc')
if [[ "${count}" -gt 32 ]]
then
echo "${platform} : AES ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : AES ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
2021-05-10 18:44:15 +00:00
# Test CLMUL code generation
count=$(${OBJDUMP} --disassemble gcm_simd.o 2>&1 | grep -c -E 'pclmulqdq|pclmullqlq|pclmullqhq|vpclmulqdq')
if [[ "${count}" -gt 16 ]]
then
2021-05-10 18:44:15 +00:00
echo "${platform} : CLMUL ==> SUCCESS" >> "${TMPDIR}/build.log"
else
2021-05-10 18:44:15 +00:00
echo "${platform} : CLMUL ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
# Test SHA1 code generation
count=$(${OBJDUMP} --disassemble sha_simd.o 2>&1 | grep -c -E 'sha1rnds4|sha1nexte|sha1msg1|sha1msg2')
if [[ "${count}" -gt 32 ]]
then
echo "${platform} : SHA1 ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : SHA1 ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
# Test SHA2 code generation
count=$(${OBJDUMP} --disassemble sha_simd.o | grep -c -E 'sha256rnds2|sha256msg1|sha256msg2')
if [[ "${count}" -gt 32 ]]
then
echo "${platform} : SHA2 ==> SUCCESS" >> "${TMPDIR}/build.log"
else
echo "${platform} : SHA2 ==> FAILURE" >> "${TMPDIR}/build.log"
touch "${TMPDIR}/build.failed"
fi
fi
)
2016-09-23 16:04:33 +00:00
done
2021-02-05 10:18:29 +00:00
echo
echo "====================================================="
2021-02-07 16:44:15 +00:00
cat "${TMPDIR}/build.log"
# let the script fail if any of the builds failed
2021-02-07 16:44:15 +00:00
if [ -f "${TMPDIR}/build.failed" ]; then
2021-02-05 10:18:29 +00:00
exit 1
fi
2018-04-05 22:38:43 +00:00
2021-02-05 10:18:29 +00:00
exit 0