Blame sysdeps/powerpc/fpu/fraiseexcpt.c

Packit 6c4009
/* Raise given exceptions.
Packit 6c4009
   Copyright (C) 1997-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#include <fenv_libc.h>
Packit 6c4009
Packit 6c4009
#undef feraiseexcept
Packit 6c4009
int
Packit 6c4009
__feraiseexcept (int excepts)
Packit 6c4009
{
Packit 6c4009
  fenv_union_t u;
Packit 6c4009
Packit 6c4009
  /* Raise exceptions represented by EXCEPTS.  It is the responsibility of
Packit 6c4009
     the OS to ensure that if multiple exceptions occur they are fed back
Packit 6c4009
     to this process in the proper way; this can happen in hardware,
Packit 6c4009
     anyway (in particular, inexact with overflow or underflow). */
Packit 6c4009
Packit 6c4009
  /* Get the current state.  */
Packit 6c4009
  u.fenv = fegetenv_register ();
Packit 6c4009
Packit 6c4009
  /* Add the exceptions */
Packit 6c4009
  u.l = (u.l
Packit 6c4009
	 | (excepts & FPSCR_STICKY_BITS)
Packit 6c4009
	 /* Turn FE_INVALID into FE_INVALID_SOFTWARE.  */
Packit 6c4009
	 | (excepts >> ((31 - FPSCR_VX) - (31 - FPSCR_VXSOFT))
Packit 6c4009
	    & FE_INVALID_SOFTWARE));
Packit 6c4009
Packit 6c4009
  /* Store the new status word (along with the rest of the environment),
Packit 6c4009
     triggering any appropriate exceptions.  */
Packit 6c4009
  fesetenv_register (u.fenv);
Packit 6c4009
Packit 6c4009
  if ((excepts & FE_INVALID))
Packit 6c4009
    {
Packit 6c4009
      /* For some reason, some PowerPC chips (the 601, in particular)
Packit 6c4009
	 don't have FE_INVALID_SOFTWARE implemented.  Detect this
Packit 6c4009
	 case and raise FE_INVALID_SNAN instead.  */
Packit 6c4009
      u.fenv = fegetenv_register ();
Packit 6c4009
      if ((u.l & FE_INVALID) == 0)
Packit 6c4009
	set_fpscr_bit (FPSCR_VXSNAN);
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  /* Success.  */
Packit 6c4009
  return 0;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
#include <shlib-compat.h>
Packit 6c4009
#if SHLIB_COMPAT (libm, GLIBC_2_1, GLIBC_2_2)
Packit 6c4009
strong_alias (__feraiseexcept, __old_feraiseexcept)
Packit 6c4009
compat_symbol (libm, __old_feraiseexcept, feraiseexcept, GLIBC_2_1);
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
libm_hidden_def (__feraiseexcept)
Packit 6c4009
libm_hidden_ver (__feraiseexcept, feraiseexcept)
Packit 6c4009
versioned_symbol (libm, __feraiseexcept, feraiseexcept, GLIBC_2_2);