diff options
author | Ulrich Drepper <drepper@gmail.com> | 2010-10-11 10:58:31 -0400 |
---|---|---|
committer | Ulrich Drepper <drepper@gmail.com> | 2010-10-11 10:58:31 -0400 |
commit | b76b818e6fe2061e778b3a9bbe63c554c3f9b3c1 (patch) | |
tree | 419c31b08cd21e8146b689035e766a22192a2fc2 /stdio-common | |
parent | 1751705d1c4e8b7aba391391d1d8d88fe8c9d8b8 (diff) | |
download | glibc-b76b818e6fe2061e778b3a9bbe63c554c3f9b3c1.zip glibc-b76b818e6fe2061e778b3a9bbe63c554c3f9b3c1.tar.gz glibc-b76b818e6fe2061e778b3a9bbe63c554c3f9b3c1.tar.bz2 |
psiginfo relied too much on sys_siglist.
Diffstat (limited to 'stdio-common')
-rw-r--r-- | stdio-common/psiginfo.c | 23 |
1 files changed, 21 insertions, 2 deletions
diff --git a/stdio-common/psiginfo.c b/stdio-common/psiginfo.c index 49b86ec..627c21c 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; |