From 84d199451cf33734003c00c043a1480920f5563b Mon Sep 17 00:00:00 2001 From: Pasha Date: Thu, 29 Feb 2024 19:30:30 +0000 Subject: initial commit --- patches/glibc/unsubmitted-prof-eintr.diff | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 patches/glibc/unsubmitted-prof-eintr.diff (limited to 'patches/glibc/unsubmitted-prof-eintr.diff') diff --git a/patches/glibc/unsubmitted-prof-eintr.diff b/patches/glibc/unsubmitted-prof-eintr.diff new file mode 100644 index 0000000..1b0808c --- /dev/null +++ b/patches/glibc/unsubmitted-prof-eintr.diff @@ -0,0 +1,21 @@ +When profiling ext2fs, the shutdown stops all RPC, which thus interrupts this +open, and we have to retry here. + +TODO: is open really supposed to expose such EINTR? Should the generic gmon +loop around EINTR (since there might be signals happening indeed) + +diff --git a/gmon/gmon.c b/gmon/gmon.c +index 6439ed1caa..507ad0c9fc 100644 +--- a/gmon/gmon.c ++++ b/gmon/gmon.c +@@ -390,8 +390,10 @@ write_gmon (void) + + if (fd == -1) + { ++ do + fd = __open_nocancel ("gmon.out", O_CREAT | O_TRUNC | O_WRONLY + | O_NOFOLLOW | O_CLOEXEC, 0666); ++ while (fd < 0 && errno == EINTR); + if (fd < 0) + { + char buf[300]; -- cgit v1.2.1