diff options
author | Kaz Kojima <kkojima@rr.iij4u.or.jp> | 2012-04-05 11:43:30 +0900 |
---|---|---|
committer | Kaz Kojima <kkojima@rr.iij4u.or.jp> | 2012-04-05 11:43:30 +0900 |
commit | 15a946b57a1e7f4ba95b63572062860ca1a5e58f (patch) | |
tree | 0965e410cebc68a678ef9a0704bad00eaad765e3 /sysdeps/sh/sh4/fpu/fegetexcept.c | |
parent | d653abb723919fb11f8573cdedf65505c0eca55f (diff) | |
download | glibc-15a946b57a1e7f4ba95b63572062860ca1a5e58f.tar.gz glibc-15a946b57a1e7f4ba95b63572062860ca1a5e58f.tar.xz glibc-15a946b57a1e7f4ba95b63572062860ca1a5e58f.zip |
Add support fedisableexcept, feenableexcept, fegetexcept and feupdateenv
for SH.
Diffstat (limited to 'sysdeps/sh/sh4/fpu/fegetexcept.c')
-rw-r--r-- | sysdeps/sh/sh4/fpu/fegetexcept.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/sysdeps/sh/sh4/fpu/fegetexcept.c b/sysdeps/sh/sh4/fpu/fegetexcept.c new file mode 100644 index 0000000000..a849a17756 --- /dev/null +++ b/sysdeps/sh/sh4/fpu/fegetexcept.c @@ -0,0 +1,35 @@ +/* Get enabled floating-point exceptions. + Copyright (C) 2012 Free Software Foundation, Inc. + This file is part of the GNU C Library. + Contributed by Nobuhiro Iwamatsu <iwamatsu@nigauri.org>, 2012. + + The GNU C Library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library; if not, see + <http://www.gnu.org/licenses/>. */ + +#include <fenv.h> +#include <fpu_control.h> + +int +fegetexcept (void) +{ + unsigned int temp; + + /* Get current exceptions. */ + _FPU_GETCW (temp); + /* When read fpscr, this was initialized. + We need to rewrite value of temp. */ + _FPU_SETCW (temp); + + return (temp >> 5) & FE_ALL_EXCEPT; +} |