From bd1a7be7eef7d3d9aa3aab7af0cb5efc6a980dd5 Mon Sep 17 00:00:00 2001 From: Daniel Bevenius Date: Tue, 2 Jun 2020 05:33:25 +0200 Subject: [PATCH] src: use getauxval in node_main.cc This commit suggests using getauxval in node_main.cc. The motivation for this is that getauxval was introduced in glibc 2.16 and looking at BUILDING.md, in the 'Platform list' section, it looks like we now support glibc >= 2.17 and perhaps this change would be alright now. Refs: https://github.com/nodejs/node/pull/12548 --- src/node_main.cc | 18 ++---------------- 1 file changed, 2 insertions(+), 16 deletions(-) diff --git a/src/node_main.cc b/src/node_main.cc index 9f4ea22d12c6e8..6bac1075932587 100644 --- a/src/node_main.cc +++ b/src/node_main.cc @@ -89,13 +89,7 @@ int wmain(int argc, wchar_t* wargv[]) { #else // UNIX #ifdef __linux__ -#include -#ifdef __LP64__ -#define Elf_auxv_t Elf64_auxv_t -#else -#define Elf_auxv_t Elf32_auxv_t -#endif // __LP64__ -extern char** environ; +#include #endif // __linux__ #if defined(__POSIX__) && defined(NODE_SHARED_MODE) #include @@ -124,15 +118,7 @@ int main(int argc, char* argv[]) { #endif #if defined(__linux__) - char** envp = environ; - while (*envp++ != nullptr) {} - Elf_auxv_t* auxv = reinterpret_cast(envp); - for (; auxv->a_type != AT_NULL; auxv++) { - if (auxv->a_type == AT_SECURE) { - node::per_process::linux_at_secure = auxv->a_un.a_val; - break; - } - } + node::per_process::linux_at_secure = getauxval(AT_SECURE); #endif // Disable stdio buffering, it interacts poorly with printf() // calls elsewhere in the program (e.g., any logging from V8.)