[compiler-rt] [libfuzzer] use timer_create() instead of setitimer() for linux (PR #110274)
via llvm-commits
llvm-commits at lists.llvm.org
Fri Nov 8 19:43:42 PST 2024
https://github.com/MinxuanZ updated https://github.com/llvm/llvm-project/pull/110274
>From c2293659408f6147ecf6d25a700baeb771d2bcfa Mon Sep 17 00:00:00 2001
From: magus <manypotatoes1 at gmail.com>
Date: Fri, 27 Sep 2024 17:29:39 +0800
Subject: [PATCH 1/2] [libfuzzer] use timer_create() instead of setitimer() for
linux
---
compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp | 11 ++++++++---
1 file changed, 8 insertions(+), 3 deletions(-)
diff --git a/compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp b/compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp
index 392c1e5be4eea3..469e4ed0661908 100644
--- a/compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp
+++ b/compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp
@@ -104,11 +104,16 @@ bool ExecuteCommand(const Command &Cmd, std::string *CmdOutput) {
}
void SetTimer(int Seconds) {
- struct itimerval T {
+ timer_t timerid;
+ struct itimerspec T {
{Seconds, 0}, { Seconds, 0 }
};
- if (setitimer(ITIMER_REAL, &T, nullptr)) {
- Printf("libFuzzer: setitimer failed with %d\n", errno);
+ if (timer_create(CLOCK_REALTIME, NULL, &timerid) == -1) {
+ Printf("libFuzzer: timer_create failed with %d\n", errno);
+ exit(1);
+ }
+ if (timer_settime(timerid, 0, &T, NULL) == -1) {
+ Printf("libFuzzer: timer_settime failed with %d\n", errno);
exit(1);
}
SetSigaction(SIGALRM, AlarmHandler);
>From 001d59b1ddf3dc3a4624d40c272fc5d87b3de9e6 Mon Sep 17 00:00:00 2001
From: Min <45393763+MinxuanZ at users.noreply.github.com>
Date: Sat, 9 Nov 2024 11:43:33 +0800
Subject: [PATCH 2/2] move SetSigaction above timer_settime
---
compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp b/compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp
index 469e4ed0661908..6e6413ff5dd567 100644
--- a/compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp
+++ b/compiler-rt/lib/fuzzer/FuzzerUtilPosix.cpp
@@ -108,6 +108,7 @@ void SetTimer(int Seconds) {
struct itimerspec T {
{Seconds, 0}, { Seconds, 0 }
};
+ SetSigaction(SIGALRM, AlarmHandler);
if (timer_create(CLOCK_REALTIME, NULL, &timerid) == -1) {
Printf("libFuzzer: timer_create failed with %d\n", errno);
exit(1);
@@ -115,8 +116,7 @@ void SetTimer(int Seconds) {
if (timer_settime(timerid, 0, &T, NULL) == -1) {
Printf("libFuzzer: timer_settime failed with %d\n", errno);
exit(1);
- }
- SetSigaction(SIGALRM, AlarmHandler);
+ }
}
void SetSignalHandler(const FuzzingOptions& Options) {
More information about the llvm-commits
mailing list