]> git.ipfire.org Git - thirdparty/glibc.git/blame - sysdeps/sparc/fpu/fesetmode.c
Prefer https to http for gnu.org and fsf.org URLs
[thirdparty/glibc.git] / sysdeps / sparc / fpu / fesetmode.c
CommitLineData
ed29339b 1/* Install given floating-point control modes. SPARC version.
04277e02 2 Copyright (C) 2016-2019 Free Software Foundation, Inc.
ed29339b
JM
3 This file is part of the GNU C Library.
4
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
9
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
14
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
5a82c748 17 <https://www.gnu.org/licenses/>. */
ed29339b
JM
18
19#include <fenv.h>
20#include <fpu_control.h>
21
22#define FPU_CONTROL_BITS 0xcfc00000UL
23
24int
25fesetmode (const femode_t *modep)
26{
27 femode_t fsr;
28
29 __fenv_stfsr (fsr);
30 fsr &= ~FPU_CONTROL_BITS;
31 if (modep == FE_DFL_MODE)
32 fsr |= _FPU_DEFAULT;
33 else
34 fsr |= *modep & FPU_CONTROL_BITS;
35 __fenv_ldfsr (fsr);
36
37 return 0;
38}