Skip site navigation (1)Skip section navigation (2)
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>