Index: lib/sanitizer_common/sanitizer_linux.cc =================================================================== --- lib/sanitizer_common/sanitizer_linux.cc +++ lib/sanitizer_common/sanitizer_linux.cc @@ -60,7 +60,10 @@ #include #if SANITIZER_FREEBSD +#include #include +#include +#include #include extern "C" { // must be included after and on @@ -395,11 +398,13 @@ #endif } +#if !SANITIZER_FREEBSD extern "C" { SANITIZER_WEAK_ATTRIBUTE extern void *__libc_stack_end; } +#endif -#if !SANITIZER_GO +#if !SANITIZER_GO && !SANITIZER_FREEBSD static void ReadNullSepFileToArray(const char *path, char ***arr, int arr_size) { char *buff; @@ -425,6 +430,7 @@ #endif static void GetArgsAndEnv(char ***argv, char ***envp) { +#if !SANITIZER_FREEBSD #if !SANITIZER_GO if (&__libc_stack_end) { #endif @@ -439,6 +445,14 @@ ReadNullSepFileToArray("/proc/self/environ", envp, kMaxEnvp); } #endif +#else // FreeBSD + ps_strings *pss; + size_t sz = sizeof(pss); + if (sysctlbyname("kern.ps_strings", &pss, &sz, NULL, 0) == -1) + pss = (ps_strings*)PS_STRINGS; + *argv = pss->ps_argvstr; + *envp = pss->ps_envstr; +#endif } char **GetArgv() {