[compiler-rt] Revert "[compiler-rt][rtsan] stat api interception." (PR #128465)
Chris Apple via llvm-commits
llvm-commits at lists.llvm.org
Sun Feb 23 21:21:30 PST 2025
https://github.com/cjappl created https://github.com/llvm/llvm-project/pull/128465
Reverts llvm/llvm-project#128430
Reverting this as I could repro the failure here:
> Hi @devnexen I believe this change is causing failures on a bot. Any idea what might be causing the problems?
> https://lab.llvm.org/staging/#/builders/202/builds/1324
https://github.com/llvm/llvm-project/pull/128430#issuecomment-2677298624
>From cbe1fac154be42b8b4cad2f25df0642726098bdf Mon Sep 17 00:00:00 2001
From: Chris Apple <cja-private at pm.me>
Date: Mon, 24 Feb 2025 14:20:18 +0900
Subject: [PATCH] Revert "[compiler-rt][rtsan] stat api interception.
(#128430)"
This reverts commit 4d928d5b5858de18f47f68c0d309dafd24cea875.
---
.../lib/rtsan/rtsan_interceptors_posix.cpp | 45 -------------------
.../tests/rtsan_test_interceptors_posix.cpp | 31 +------------
2 files changed, 2 insertions(+), 74 deletions(-)
diff --git a/compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp b/compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp
index 57a01396b8123..5b9e992639f55 100644
--- a/compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp
+++ b/compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp
@@ -285,45 +285,6 @@ INTERCEPTOR(int, unlinkat, int fd, const char *pathname, int flag) {
return REAL(unlinkat)(fd, pathname, flag);
}
-INTERCEPTOR(int, stat, const char *pathname, struct stat *s) {
- __rtsan_notify_intercepted_call("stat");
- return REAL(stat)(pathname, s);
-}
-
-INTERCEPTOR(int, lstat, const char *pathname, struct stat *s) {
- __rtsan_notify_intercepted_call("lstat");
- return REAL(lstat)(pathname, s);
-}
-
-INTERCEPTOR(int, fstat, int fd, struct stat *s) {
- __rtsan_notify_intercepted_call("fstat");
- return REAL(fstat)(fd, s);
-}
-
-#if !SANITIZER_APPLE // deprecated for darwin
-INTERCEPTOR(int, stat64, const char *pathname, struct stat64 *s) {
- __rtsan_notify_intercepted_call("stat64");
- return REAL(stat64)(pathname, s);
-}
-
-INTERCEPTOR(int, lstat64, const char *pathname, struct stat64 *s) {
- __rtsan_notify_intercepted_call("lstat64");
- return REAL(lstat64)(pathname, s);
-}
-
-INTERCEPTOR(int, fstat64, int fd, struct stat64 *s) {
- __rtsan_notify_intercepted_call("fstat64");
- return REAL(fstat64)(fd, s);
-}
-#define RTSAN_MAYBE_INTERCEPT_STAT64 INTERCEPT_FUNCTION(stat64)
-#define RTSAN_MAYBE_INTERCEPT_LSTAT64 INTERCEPT_FUNCTION(lstat64)
-#define RTSAN_MAYBE_INTERCEPT_FSTAT64 INTERCEPT_FUNCTION(fstat64)
-#else
-#define RTSAN_MAYBE_INTERCEPT_STAT64
-#define RTSAN_MAYBE_INTERCEPT_LSTAT64
-#define RTSAN_MAYBE_INTERCEPT_FSTAT64
-#endif
-
// Streams
INTERCEPTOR(FILE *, fopen, const char *path, const char *mode) {
@@ -1476,12 +1437,6 @@ void __rtsan::InitializeInterceptors() {
RTSAN_MAYBE_INTERCEPT_READLINKAT;
INTERCEPT_FUNCTION(unlink);
INTERCEPT_FUNCTION(unlinkat);
- INTERCEPT_FUNCTION(stat);
- INTERCEPT_FUNCTION(lstat);
- INTERCEPT_FUNCTION(fstat);
- RTSAN_MAYBE_INTERCEPT_STAT64;
- RTSAN_MAYBE_INTERCEPT_LSTAT64;
- RTSAN_MAYBE_INTERCEPT_FSTAT64;
INTERCEPT_FUNCTION(fopen);
RTSAN_MAYBE_INTERCEPT_FOPEN64;
RTSAN_MAYBE_INTERCEPT_FREOPEN64;
diff --git a/compiler-rt/lib/rtsan/tests/rtsan_test_interceptors_posix.cpp b/compiler-rt/lib/rtsan/tests/rtsan_test_interceptors_posix.cpp
index fc5a2f771ddb7..d1c5a94c12213 100644
--- a/compiler-rt/lib/rtsan/tests/rtsan_test_interceptors_posix.cpp
+++ b/compiler-rt/lib/rtsan/tests/rtsan_test_interceptors_posix.cpp
@@ -401,7 +401,7 @@ TEST_F(RtsanFileTest, FcntlFlockDiesWhenRealtime) {
ASSERT_THAT(fd, Ne(-1));
auto Func = [fd]() {
- struct flock lock{};
+ struct flock lock {};
lock.l_type = F_RDLCK;
lock.l_whence = SEEK_SET;
lock.l_start = 0;
@@ -735,7 +735,7 @@ TEST(TestRtsanInterceptors, IoctlBehavesWithOutputPointer) {
GTEST_SKIP();
}
- struct ifreq ifr{};
+ struct ifreq ifr {};
strncpy(ifr.ifr_name, ifaddr->ifa_name, IFNAMSIZ - 1);
int retval = ioctl(sock, SIOCGIFADDR, &ifr);
@@ -875,33 +875,6 @@ TEST_F(RtsanOpenedFileTest, UnlinkatDiesWhenRealtime) {
ExpectNonRealtimeSurvival(Func);
}
-TEST_F(RtsanOpenedFileTest, StatDiesWhenRealtime) {
- auto Func = [&]() {
- struct stat s{};
- stat(GetTemporaryFilePath(), &s);
- };
- ExpectRealtimeDeath(Func, MAYBE_APPEND_64("stat"));
- ExpectNonRealtimeSurvival(Func);
-}
-
-TEST_F(RtsanOpenedFileTest, LstatDiesWhenRealtime) {
- auto Func = [&]() {
- struct stat s{};
- lstat(GetTemporaryFilePath(), &s);
- };
- ExpectRealtimeDeath(Func, MAYBE_APPEND_64("lstat"));
- ExpectNonRealtimeSurvival(Func);
-}
-
-TEST_F(RtsanOpenedFileTest, FstatDiesWhenRealtime) {
- auto Func = [&]() {
- struct stat s{};
- fstat(GetOpenFd(), &s);
- };
- ExpectRealtimeDeath(Func, MAYBE_APPEND_64("fstat"));
- ExpectNonRealtimeSurvival(Func);
-}
-
TEST_F(RtsanFileTest, FcloseDiesWhenRealtime) {
FILE *f = fopen(GetTemporaryFilePath(), "w");
EXPECT_THAT(f, Ne(nullptr));
More information about the llvm-commits
mailing list