aboutsummaryrefslogtreecommitdiffstats
path: root/src/lib
diff options
context:
space:
mode:
authorDavid Carlier <[email protected]>2019-05-21 21:43:24 +0100
committerDavid Carlier <[email protected]>2019-05-21 21:43:24 +0100
commit85423f990fa216369e442661c09f900cd7a1deca (patch)
treebe13bc4449ccc12e2ee9a97a559750962222c3e8 /src/lib
parent09688b138f2cf230c2117e351179eb347ef69a80 (diff)
Providing little getauxval implementation for Android<18
tested with armv7 and ndk 16.
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/utils/os_utils.cpp26
1 files changed, 23 insertions, 3 deletions
diff --git a/src/lib/utils/os_utils.cpp b/src/lib/utils/os_utils.cpp
index 394ccf13e..2c93f31e8 100644
--- a/src/lib/utils/os_utils.cpp
+++ b/src/lib/utils/os_utils.cpp
@@ -34,14 +34,17 @@
#include <errno.h>
#include <termios.h>
#undef B0
+ extern "C" char **environ;
#endif
#if defined(BOTAN_TARGET_OS_IS_EMSCRIPTEN)
#include <emscripten/emscripten.h>
#endif
-#if defined(BOTAN_TARGET_OS_HAS_GETAUXVAL) || defined(BOTAN_TARGET_OS_HAS_ELF_AUX_INFO)
+#if defined(BOTAN_TARGET_OS_HAS_GETAUXVAL) || defined(BOTAN_TARGET_OS_IS_ANDROID) || \
+ defined(BOTAN_TARGET_OS_HAS_ELF_AUX_INFO)
#include <sys/auxv.h>
+ #include <elf.h>
#endif
#if defined(BOTAN_TARGET_OS_HAS_WIN32)
@@ -99,6 +102,23 @@ unsigned long OS::get_auxval(unsigned long id)
{
#if defined(BOTAN_TARGET_OS_HAS_GETAUXVAL)
return ::getauxval(id);
+#elif defined(BOTAN_TARGET_OS_IS_ANDROID)
+ char **p = environ;
+
+ while (*p++!=nullptr);
+
+ Elf32_auxv_t *e = reinterpret_cast<Elf32_auxv_t *>(p);
+
+ while (e!=nullptr)
+ {
+ if (e->a_type == 0)
+ continue;
+ if (e->a_type == id)
+ return e->a_un.a_val;
+ e++;
+ }
+
+ return 0;
#elif defined(BOTAN_TARGET_OS_HAS_ELF_AUX_INFO)
unsigned long auxinfo = 0;
::elf_aux_info(id, &auxinfo, sizeof(auxinfo));
@@ -111,8 +131,8 @@ unsigned long OS::get_auxval(unsigned long id)
bool OS::running_in_privileged_state()
{
-#if defined(BOTAN_TARGET_OS_HAS_GETAUXVAL) && defined(AT_SECURE)
- return ::getauxval(AT_SECURE) != 0;
+#if defined(AT_SECURE)
+ return OS::get_auxval(AT_SECURE) != 0;
#elif defined(BOTAN_TARGET_OS_HAS_POSIX1)
return (::getuid() != ::geteuid()) || (::getgid() != ::getegid());
#else