Blame sysdeps/x86_64/fpu/feenablxcpt.c

Packit Service 82fcde
/* Enable floating-point exceptions.
Packit Service 82fcde
   Copyright (C) 2001-2018 Free Software Foundation, Inc.
Packit Service 82fcde
   This file is part of the GNU C Library.
Packit Service 82fcde
   Contributed by Andreas Jaeger <aj@suse.de>, 2001.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is free software; you can redistribute it and/or
Packit Service 82fcde
   modify it under the terms of the GNU Lesser General Public
Packit Service 82fcde
   License as published by the Free Software Foundation; either
Packit Service 82fcde
   version 2.1 of the License, or (at your option) any later version.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is distributed in the hope that it will be useful,
Packit Service 82fcde
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 82fcde
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 82fcde
   Lesser General Public License for more details.
Packit Service 82fcde
Packit Service 82fcde
   You should have received a copy of the GNU Lesser General Public
Packit Service 82fcde
   License along with the GNU C Library; if not, see
Packit Service 82fcde
   <http://www.gnu.org/licenses/>.  */
Packit Service 82fcde
Packit Service 82fcde
#include <fenv.h>
Packit Service 82fcde
Packit Service 82fcde
int
Packit Service 82fcde
feenableexcept (int excepts)
Packit Service 82fcde
{
Packit Service 82fcde
  unsigned short int new_exc, old_exc;
Packit Service 82fcde
  unsigned int new;
Packit Service 82fcde
Packit Service 82fcde
  excepts &= FE_ALL_EXCEPT;
Packit Service 82fcde
Packit Service 82fcde
  /* Get the current control word of the x87 FPU.  */
Packit Service 82fcde
  __asm__ ("fstcw %0" : "=m" (*&new_exc));
Packit Service 82fcde
Packit Service 82fcde
  old_exc = (~new_exc) & FE_ALL_EXCEPT;
Packit Service 82fcde
Packit Service 82fcde
  new_exc &= ~excepts;
Packit Service 82fcde
  __asm__ ("fldcw %0" : : "m" (*&new_exc));
Packit Service 82fcde
Packit Service 82fcde
  /* And now the same for the SSE MXCSR register.  */
Packit Service 82fcde
  __asm__ ("stmxcsr %0" : "=m" (*&new));
Packit Service 82fcde
Packit Service 82fcde
  /* The SSE exception masks are shifted by 7 bits.  */
Packit Service 82fcde
  new &= ~(excepts << 7);
Packit Service 82fcde
  __asm__ ("ldmxcsr %0" : : "m" (*&new));
Packit Service 82fcde
Packit Service 82fcde
  return old_exc;
Packit Service 82fcde
}