Date: Sat, 17 May 1997 23:34:19 -0700 (PDT) From: nw1@cs.wustl.edu To: freebsd-gnats-submit@FreeBSD.ORG Subject: misc/3615: Error in /usr/src/lib/libc/gen/sigsetops.c Message-ID: <199705180634.XAA13495@hub.freebsd.org> Resent-Message-ID: <199705180640.XAA13698@hub.freebsd.org>
next in thread | raw e-mail | index | archive | help
>Number: 3615
>Category: misc
>Synopsis: Error in /usr/src/lib/libc/gen/sigsetops.c
>Confidential: no
>Severity: critical
>Priority: high
>Responsible: freebsd-bugs
>State: open
>Class: sw-bug
>Submitter-Id: current-users
>Arrival-Date: Sat May 17 23:40:01 PDT 1997
>Last-Modified:
>Originator: Nanbor Wang
>Organization:
Washington University
>Release: 3.0-current
>Environment:
FreeBSD number.wustl.edu 3.0-CURRENT FreeBSD 3.0-CURRENT #0: Wed Feb 26 00:22:44 CST 1997 root@number.wustl.edu:/usr/src/sys/compile/EXTRA_SLOW_PENTIUM i386
>Description:
In file /usr/src/lib/libc/gen/sigsetops.c, the sigismember() is implemented as:
int
sigismember(set, signo)
const sigset_t *set;
int signo;
{
return ((*set & ~sigmask(signo)) != 0);
}
Which is not correct. (In /usr/include/signal.h, if _ANSI_SOURCE is defined,
it is defined as:
#define sigismember(set, signo) ((*(set) & (1 << ((signo) - 1))) != 0)
This is correct.)
>How-To-Repeat:
Try play with it and you know. I have compared it with Solaris's behaviors
and am absolutely sure this is a bug.
>Fix:
int
sigismember(set, signo)
const sigset_t *set;
int signo;
{
return ((*set & sigmask(signo)) != 0);
}
>Audit-Trail:
>Unformatted:
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?199705180634.XAA13495>
