From 2e379bf600ec29f1c398bb281174182fb347281b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc-Andr=C3=A9=20Moreau?= Date: Fri, 15 Apr 2022 15:47:19 -0400 Subject: [PATCH] build fixes for Android --- CMakeLists.txt | 29 ++++++++++++++++++++++++++++- openbsd-compat/explicit_bzero.c | 2 +- openbsd-compat/openbsd-compat.h | 2 +- src/CMakeLists.txt | 2 ++ 4 files changed, 32 insertions(+), 3 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 11a51ac5..9a13b1c9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -37,6 +37,7 @@ option(BUILD_MANPAGES "Build man pages" ON) option(BUILD_SHARED_LIBS "Build the shared library" ON) option(BUILD_STATIC_LIBS "Build the static library" ON) option(BUILD_TOOLS "Build tool programs" ON) +option(BUILD_TESTS "Build test programs" ON) option(FUZZ "Enable fuzzing instrumentation" OFF) option(LIBFUZZER "Build libfuzzer harnesses" OFF) option(USE_HIDAPI "Use hidapi as the HID backend" OFF) @@ -69,6 +70,9 @@ if(NOT MSVC) elseif(CMAKE_SYSTEM_NAME STREQUAL "Linux") set(FIDO_CFLAGS "${FIDO_CFLAGS} -D_GNU_SOURCE") set(FIDO_CFLAGS "${FIDO_CFLAGS} -D_DEFAULT_SOURCE") + elseif(CMAKE_SYSTEM_NAME STREQUAL "Android") + set(FIDO_CFLAGS "${FIDO_CFLAGS} -D_GNU_SOURCE") + set(FIDO_CFLAGS "${FIDO_CFLAGS} -D_DEFAULT_SOURCE") elseif(CMAKE_SYSTEM_NAME STREQUAL "FreeBSD" OR CMAKE_SYSTEM_NAME STREQUAL "MidnightBSD") set(FIDO_CFLAGS "${FIDO_CFLAGS} -D__BSD_VISIBLE=1") @@ -108,6 +112,11 @@ check_symbol_exists(sysconf unistd.h HAVE_SYSCONF) check_symbol_exists(timespecsub sys/time.h HAVE_TIMESPECSUB) check_symbol_exists(timingsafe_bcmp string.h HAVE_TIMINGSAFE_BCMP) +if(CMAKE_SYSTEM_NAME STREQUAL "Android") + set(HAVE_EXPLICIT_BZERO OFF) + add_definitions(-DCRYPTO_EXPLICIT_BZERO) +endif() + set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY) try_compile(HAVE_POSIX_IOCTL "${CMAKE_CURRENT_BINARY_DIR}/posix_ioctl_check.o" @@ -209,6 +218,7 @@ else() message(FATAL_ERROR "could not find zlib") endif() + set(ZLIB_LIBRARIES "zlib") set(CBOR_LIBRARIES "cbor") set(CRYPTO_LIBRARIES "crypto") @@ -226,6 +236,23 @@ else() set(BASE_LIBRARIES ${BASE_LIBRARIES} rt) endif() endif() + elseif(CMAKE_SYSTEM_NAME STREQUAL "Android") + if(UDEV_ROOT_DIR) + list(PREPEND CMAKE_FIND_ROOT_PATH ${UDEV_ROOT_DIR}) + endif() + + find_path(UDEV_INCLUDE_DIR + NAMES "libudev.h") + + find_library(UDEV_LIBRARY + NAMES libudev-zero.a libudev) + + add_library(udev STATIC IMPORTED GLOBAL) + set_target_properties(udev PROPERTIES INTERFACE_INCLUDE_DIRECTORIES "${UDEV_INCLUDE_DIR}") + set_target_properties(udev PROPERTIES IMPORTED_LOCATION "${UDEV_LIBRARY}") + + set(UDEV_INCLUDE_DIRS "${UDEV_INCLUDE_DIR}") + set(UDEV_LIBRARIES "udev") else() set(NFC_LINUX OFF) endif() @@ -414,7 +441,7 @@ if(BUILD_MANPAGES) subdirs(man) endif() -if(NOT WIN32) +if(NOT WIN32 AND BUILD_TESTS) if(CMAKE_BUILD_TYPE STREQUAL "Debug" AND NOT FUZZ) enable_testing() subdirs(regress) diff --git a/openbsd-compat/explicit_bzero.c b/openbsd-compat/explicit_bzero.c index ac64e69b..e86c5f06 100644 --- a/openbsd-compat/explicit_bzero.c +++ b/openbsd-compat/explicit_bzero.c @@ -7,7 +7,7 @@ #include "openbsd-compat.h" -#if !defined(HAVE_EXPLICIT_BZERO) && !defined(_WIN32) +#if !defined(HAVE_EXPLICIT_BZERO) && !defined(_WIN32) && !defined(CRYPTO_EXPLICIT_BZERO) #include diff --git a/openbsd-compat/openbsd-compat.h b/openbsd-compat/openbsd-compat.h index dc9acec4..b784197f 100644 --- a/openbsd-compat/openbsd-compat.h +++ b/openbsd-compat/openbsd-compat.h @@ -62,7 +62,7 @@ char *strsep(char **, const char *); void *recallocarray(void *, size_t, size_t, size_t); #endif -#if !defined(HAVE_EXPLICIT_BZERO) +#if !defined(HAVE_EXPLICIT_BZERO) || defined(CRYPTO_EXPLICIT_BZERO) void explicit_bzero(void *, size_t); #endif diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 796ec69a..a0295e3a 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -63,6 +63,8 @@ elseif(APPLE) list(APPEND FIDO_SOURCES hid_osx.c) elseif(CMAKE_SYSTEM_NAME STREQUAL "Linux") list(APPEND FIDO_SOURCES hid_linux.c hid_unix.c) +elseif(CMAKE_SYSTEM_NAME STREQUAL "Android") + list(APPEND FIDO_SOURCES hid_linux.c hid_unix.c) elseif(CMAKE_SYSTEM_NAME STREQUAL "NetBSD") list(APPEND FIDO_SOURCES hid_netbsd.c hid_unix.c) elseif(CMAKE_SYSTEM_NAME STREQUAL "OpenBSD")