[compiler-rt] cfdd7d7 - [compiler-rt][rtsan] sched cpu affinity for linux interception. (#124194)
via llvm-commits
llvm-commits at lists.llvm.org
Mon Jan 27 04:50:13 PST 2025
Author: David CARLIER
Date: 2025-01-27T12:50:10Z
New Revision: cfdd7d736a94aa65a23eb41258d9d6712cdb2b0d
URL: https://github.com/llvm/llvm-project/commit/cfdd7d736a94aa65a23eb41258d9d6712cdb2b0d
DIFF: https://github.com/llvm/llvm-project/commit/cfdd7d736a94aa65a23eb41258d9d6712cdb2b0d.diff
LOG: [compiler-rt][rtsan] sched cpu affinity for linux interception. (#124194)
Added:
Modified:
compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp
compiler-rt/lib/rtsan/tests/rtsan_test_interceptors_posix.cpp
Removed:
################################################################################
diff --git a/compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp b/compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp
index 1b499f2194f212..7d8b1c84f7d1c3 100644
--- a/compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp
+++ b/compiler-rt/lib/rtsan/rtsan_interceptors_posix.cpp
@@ -740,6 +740,26 @@ INTERCEPTOR(int, sched_yield, void) {
return REAL(sched_yield)();
}
+#if SANITIZER_LINUX
+INTERCEPTOR(int, sched_getaffinity, pid_t pid, size_t len, cpu_set_t *set) {
+ __rtsan_notify_intercepted_call("sched_getaffinity");
+ return REAL(sched_getaffinity)(pid, len, set);
+}
+
+INTERCEPTOR(int, sched_setaffinity, pid_t pid, size_t len,
+ const cpu_set_t *set) {
+ __rtsan_notify_intercepted_call("sched_setaffinity");
+ return REAL(sched_setaffinity)(pid, len, set);
+}
+#define RTSAN_MAYBE_INTERCEPT_SCHED_GETAFFINITY \
+ INTERCEPT_FUNCTION(sched_getaffinity)
+#define RTSAN_MAYBE_INTERCEPT_SCHED_SETAFFINITY \
+ INTERCEPT_FUNCTION(sched_setaffinity)
+#else
+#define RTSAN_MAYBE_INTERCEPT_SCHED_GETAFFINITY
+#define RTSAN_MAYBE_INTERCEPT_SCHED_SETAFFINITY
+#endif
+
// Memory
INTERCEPTOR(void *, calloc, SIZE_T num, SIZE_T size) {
@@ -1415,6 +1435,8 @@ void __rtsan::InitializeInterceptors() {
INTERCEPT_FUNCTION(usleep);
INTERCEPT_FUNCTION(nanosleep);
INTERCEPT_FUNCTION(sched_yield);
+ RTSAN_MAYBE_INTERCEPT_SCHED_GETAFFINITY;
+ RTSAN_MAYBE_INTERCEPT_SCHED_SETAFFINITY;
INTERCEPT_FUNCTION(accept);
INTERCEPT_FUNCTION(bind);
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 a4f2b92b7c4945..ef9ec626610d5e 100644
--- a/compiler-rt/lib/rtsan/tests/rtsan_test_interceptors_posix.cpp
+++ b/compiler-rt/lib/rtsan/tests/rtsan_test_interceptors_posix.cpp
@@ -323,6 +323,22 @@ TEST(TestRtsanInterceptors, SchedYieldDiesWhenRealtime) {
ExpectNonRealtimeSurvival(Func);
}
+#if SANITIZER_LINUX
+TEST(TestRtsanInterceptors, SchedGetaffinityDiesWhenRealtime) {
+ cpu_set_t set{};
+ auto Func = [&set]() { sched_getaffinity(0, sizeof(set), &set); };
+ ExpectRealtimeDeath(Func, "sched_getaffinity");
+ ExpectNonRealtimeSurvival(Func);
+}
+
+TEST(TestRtsanInterceptors, SchedSetaffinityDiesWhenRealtime) {
+ cpu_set_t set{};
+ auto Func = [&set]() { sched_setaffinity(0, sizeof(set), &set); };
+ ExpectRealtimeDeath(Func, "sched_setaffinity");
+ ExpectNonRealtimeSurvival(Func);
+}
+#endif
+
/*
Filesystem
*/
More information about the llvm-commits
mailing list