OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [newlib-1.18.0/] [newlib-1.18.0-or32-1.0rc2/] [newlib/] [libc/] [sys/] [linux/] [sigset.c] - Diff between revs 207 and 520

Only display areas with differences | Details | Blame | View Log

Rev 207 Rev 520
/* sigset.c - signal set manipulation functions */
/* sigset.c - signal set manipulation functions */
 
 
/* Copyright 2002, Red Hat Inc. */
/* Copyright 2002, Red Hat Inc. */
 
 
/* Note: these are currently grouped together in one file so that
/* Note: these are currently grouped together in one file so that
         it will override the default version in the libc/unix
         it will override the default version in the libc/unix
         directory which has grouped all functions in one file. */
         directory which has grouped all functions in one file. */
 
 
/* sigaddset function */
/* sigaddset function */
 
 
#include <signal.h>
#include <signal.h>
#include <bits/sigset.h>
#include <bits/sigset.h>
#include <errno.h>
#include <errno.h>
#include <string.h>
#include <string.h>
#include <machine/weakalias.h>
#include <machine/weakalias.h>
 
 
int
int
sigaddset (sigset_t *set, const int signo)
sigaddset (sigset_t *set, const int signo)
{
{
  int index, mask;
  int index, mask;
  __sigset_t *st = (__sigset_t *)set;
  __sigset_t *st = (__sigset_t *)set;
 
 
  if (signo > NSIG)
  if (signo > NSIG)
    {
    {
      errno = EINVAL;
      errno = EINVAL;
      return -1;
      return -1;
    }
    }
 
 
  index = (signo - 1) / (8 * sizeof(long));
  index = (signo - 1) / (8 * sizeof(long));
  mask = 1 << ((signo - 1) % (8 * sizeof(long)));
  mask = 1 << ((signo - 1) % (8 * sizeof(long)));
 
 
  st->__val[index] |= mask;
  st->__val[index] |= mask;
  return 0;
  return 0;
}
}
 
 
/* sigdelset function */
/* sigdelset function */
 
 
int
int
sigdelset (sigset_t *set, const int signo)
sigdelset (sigset_t *set, const int signo)
{
{
  int index, mask;
  int index, mask;
  __sigset_t *st = (__sigset_t *)set;
  __sigset_t *st = (__sigset_t *)set;
 
 
  if (signo > NSIG)
  if (signo > NSIG)
    {
    {
      errno = EINVAL;
      errno = EINVAL;
      return -1;
      return -1;
    }
    }
 
 
  index = (signo - 1) / (8 * sizeof(long));
  index = (signo - 1) / (8 * sizeof(long));
  mask = 1 << ((signo - 1) % (8 * sizeof(long)));
  mask = 1 << ((signo - 1) % (8 * sizeof(long)));
 
 
  st->__val[index] &= ~mask;
  st->__val[index] &= ~mask;
  return 0;
  return 0;
}
}
 
 
/* sigemptyset function */
/* sigemptyset function */
 
 
int
int
sigemptyset (sigset_t *set)
sigemptyset (sigset_t *set)
{
{
  int size = NSIG / 8;
  int size = NSIG / 8;
  __sigset_t *st = (__sigset_t *)set;
  __sigset_t *st = (__sigset_t *)set;
  memset (st->__val, 0, size);
  memset (st->__val, 0, size);
  return 0;
  return 0;
}
}
 
 
/* sigfillset function */
/* sigfillset function */
 
 
int
int
sigfillset (sigset_t *set)
sigfillset (sigset_t *set)
{
{
  int size = NSIG / 8;
  int size = NSIG / 8;
  __sigset_t *st = (__sigset_t *)set;
  __sigset_t *st = (__sigset_t *)set;
  memset (st->__val, 0xff, size);
  memset (st->__val, 0xff, size);
  return 0;
  return 0;
}
}
 
 
/* sigismember function */
/* sigismember function */
 
 
int
int
sigismember (const sigset_t *set, int signo)
sigismember (const sigset_t *set, int signo)
{
{
  int index, mask;
  int index, mask;
  __sigset_t *st = (__sigset_t *)set;
  __sigset_t *st = (__sigset_t *)set;
 
 
  if (signo > NSIG)
  if (signo > NSIG)
    {
    {
      errno = EINVAL;
      errno = EINVAL;
      return -1;
      return -1;
    }
    }
 
 
  index = (signo - 1) / (8 * sizeof(long));
  index = (signo - 1) / (8 * sizeof(long));
  mask = 1 << ((signo - 1) % (8 * sizeof(long)));
  mask = 1 << ((signo - 1) % (8 * sizeof(long)));
 
 
  return (st->__val[index] & mask) != 0;
  return (st->__val[index] & mask) != 0;
}
}
 
 
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.