aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPrzemek Kryger <pkryger@bloomberg.net>2020-03-24 10:08:42 +0000
committerPrzemek Kryger <pkryger@bloomberg.net>2020-03-24 10:08:42 +0000
commit08347d7a16044ea636465a2bbe13a5d15522e238 (patch)
tree87c661fb1cdcbe57297238fa215a467777162064
parent749148f1accc346d94825358a9a745b852961a11 (diff)
downloadgoogletest-08347d7a16044ea636465a2bbe13a5d15522e238.tar.gz
googletest-08347d7a16044ea636465a2bbe13a5d15522e238.tar.bz2
googletest-08347d7a16044ea636465a2bbe13a5d15522e238.zip
Swap settimer and sigaction calls to avoid SIGPROF
Fixes #2760.
-rw-r--r--googletest/test/googletest-death-test-test.cc12
1 files changed, 7 insertions, 5 deletions
diff --git a/googletest/test/googletest-death-test-test.cc b/googletest/test/googletest-death-test-test.cc
index cba906cc..b0dda27f 100644
--- a/googletest/test/googletest-death-test-test.cc
+++ b/googletest/test/googletest-death-test-test.cc
@@ -391,17 +391,19 @@ void SigprofAction(int, siginfo_t*, void*) { /* no op */ }
// Sets SIGPROF action and ITIMER_PROF timer (interval: 1ms).
void SetSigprofActionAndTimer() {
- struct itimerval timer;
- timer.it_interval.tv_sec = 0;
- timer.it_interval.tv_usec = 1;
- timer.it_value = timer.it_interval;
- ASSERT_EQ(0, setitimer(ITIMER_PROF, &timer, nullptr));
struct sigaction signal_action;
memset(&signal_action, 0, sizeof(signal_action));
sigemptyset(&signal_action.sa_mask);
signal_action.sa_sigaction = SigprofAction;
signal_action.sa_flags = SA_RESTART | SA_SIGINFO;
ASSERT_EQ(0, sigaction(SIGPROF, &signal_action, nullptr));
+ // timer comes second, to avoid SIGPROF premature delivery, as suggested at
+ // https://www.gnu.org/software/libc/manual/html_node/Setting-an-Alarm.html
+ struct itimerval timer;
+ timer.it_interval.tv_sec = 0;
+ timer.it_interval.tv_usec = 1;
+ timer.it_value = timer.it_interval;
+ ASSERT_EQ(0, setitimer(ITIMER_PROF, &timer, nullptr));
}
// Disables ITIMER_PROF timer and ignores SIGPROF signal.