about summary refs log tree commit diff
path: root/stdio-common/psiginfo.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@gmail.com>2010-10-11 10:58:31 -0400
committerUlrich Drepper <drepper@gmail.com>2010-10-11 10:58:31 -0400
commitb76b818e6fe2061e778b3a9bbe63c554c3f9b3c1 (patch)
tree419c31b08cd21e8146b689035e766a22192a2fc2 /stdio-common/psiginfo.c
parent1751705d1c4e8b7aba391391d1d8d88fe8c9d8b8 (diff)
downloadglibc-b76b818e6fe2061e778b3a9bbe63c554c3f9b3c1.tar.gz
glibc-b76b818e6fe2061e778b3a9bbe63c554c3f9b3c1.tar.xz
glibc-b76b818e6fe2061e778b3a9bbe63c554c3f9b3c1.zip
psiginfo relied too much on sys_siglist.
Diffstat (limited to 'stdio-common/psiginfo.c')
-rw-r--r--stdio-common/psiginfo.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/stdio-common/psiginfo.c b/stdio-common/psiginfo.c
index 49b86ec34a..627c21c640 100644
--- a/stdio-common/psiginfo.c
+++ b/stdio-common/psiginfo.c
@@ -85,9 +85,28 @@ psiginfo (const siginfo_t *pinfo, const char *s)
 
   const char *desc;
   if (pinfo->si_signo >= 0 && pinfo->si_signo < NSIG
-      && (desc = INTUSE(_sys_siglist)[pinfo->si_signo]) != NULL)
+      && ((desc = INTUSE(_sys_siglist)[pinfo->si_signo]) != NULL
+	  || (pinfo->si_signo >= SIGRTMIN && pinfo->si_signo < SIGRTMAX)))
     {
-      fprintf (fp, "%s (", _(desc));
+      if (desc == NULL)
+	{
+	  if (pinfo->si_signo - SIGRTMIN < SIGRTMAX - pinfo->si_signo)
+	    {
+	      if (pinfo->si_signo == SIGRTMIN)
+		fprintf (fp, "SIGRTMIN (");
+	      else
+		fprintf (fp, "SIGRTMIN+%d (", pinfo->si_signo - SIGRTMIN);
+	    }
+	  else
+	    {
+	      if (pinfo->si_signo == SIGRTMAX)
+		fprintf (fp, "SIGRTMAX (");
+	      else
+		fprintf (fp, "SIGRTMAX-%d (", SIGRTMAX - pinfo->si_signo);
+	    }
+	}
+      else
+	fprintf (fp, "%s (", _(desc));
 
       const char *base = NULL;
       const uint8_t *offarr = NULL;