summaryrefslogtreecommitdiff
path: root/libsanitizer
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2021-08-11 10:23:34 +0200
committerJakub Jelinek <jakub@redhat.com>2021-08-11 10:23:34 +0200
commit0e6017f5b4f13906dd2c09b25403ffa94a80181f (patch)
treea07b36bfa3f2b5f40efa235ed6f6de93ee507578 /libsanitizer
parenta45918f8a7444a40eb397a037683ba5900a2db74 (diff)
sanitizer: Cherry-pick realpath fix
tsan in some cases starts ignoring interceptors and only calls the intercepted functions. But for realpath the behavior for NULL second argument was only handled in the interceptor and intercepted function was the one found by dlsym which is often one that doesn't handle NULL as second argument. Fixed by using dlvsym with "GLIBC_2.3" if possible for intercepted function and don't emulate behavior in the wrapper. 2021-08-11 Jakub Jelinek <jakub@redhat.com> * sanitizer_common/sanitizer_common_interceptors.inc: Cherry-pick llvm-project revision faef0d042f523357fe5590e7cb6a8391cf0351a8.
Diffstat (limited to 'libsanitizer')
-rw-r--r--libsanitizer/sanitizer_common/sanitizer_common_interceptors.inc12
1 files changed, 1 insertions, 11 deletions
diff --git a/libsanitizer/sanitizer_common/sanitizer_common_interceptors.inc b/libsanitizer/sanitizer_common/sanitizer_common_interceptors.inc
index 6205d853a4c..5ac6cf45fd2 100644
--- a/libsanitizer/sanitizer_common/sanitizer_common_interceptors.inc
+++ b/libsanitizer/sanitizer_common/sanitizer_common_interceptors.inc
@@ -3664,21 +3664,11 @@ INTERCEPTOR(char *, realpath, const char *path, char *resolved_path) {
void *ctx;
COMMON_INTERCEPTOR_ENTER(ctx, realpath, path, resolved_path);
if (path) COMMON_INTERCEPTOR_READ_RANGE(ctx, path, REAL(strlen)(path) + 1);
-
- // Workaround a bug in glibc where dlsym(RTLD_NEXT, ...) returns the oldest
- // version of a versioned symbol. For realpath(), this gives us something
- // (called __old_realpath) that does not handle NULL in the second argument.
- // Handle it as part of the interceptor.
- char *allocated_path = nullptr;
- if (!resolved_path)
- allocated_path = resolved_path = (char *)WRAP(malloc)(path_max + 1);
-
char *res = REAL(realpath)(path, resolved_path);
- if (allocated_path && !res) WRAP(free)(allocated_path);
if (res) COMMON_INTERCEPTOR_WRITE_RANGE(ctx, res, REAL(strlen)(res) + 1);
return res;
}
-#define INIT_REALPATH COMMON_INTERCEPT_FUNCTION(realpath);
+#define INIT_REALPATH COMMON_INTERCEPT_FUNCTION_GLIBC_VER_MIN(realpath, "GLIBC_2.3");
#else
#define INIT_REALPATH
#endif