PATH:
usr
/
include
/* FPU control word bits. x86 version. Copyright (C) 1993-2021 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Olaf Flebbe. 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 <https://www.gnu.org/licenses/>. */ #ifndef _FPU_CONTROL_H #define _FPU_CONTROL_H 1 /* Note that this file sets on x86-64 only the x87 FPU, it does not touch the SSE unit. */ /* Here is the dirty part. Set up your 387 through the control word * (cw) register. * * 15-13 12 11-10 9-8 7-6 5 4 3 2 1 0 * | reserved | IC | RC | PC | reserved | PM | UM | OM | ZM | DM | IM * * IM: Invalid operation mask * DM: Denormalized operand mask * ZM: Zero-divide mask * OM: Overflow mask * UM: Underflow mask * PM: Precision (inexact result) mask * * Mask bit is 1 means no interrupt. * * PC: Precision control * 11 - round to extended precision * 10 - round to double precision * 00 - round to single precision * * RC: Rounding control * 00 - rounding to nearest * 01 - rounding down (toward - infinity) * 10 - rounding up (toward + infinity) * 11 - rounding toward zero * * IC: Infinity control * That is for 8087 and 80287 only. * * The hardware default is 0x037f which we use. */ #include <features.h> /* masking of interrupts */ #define _FPU_MASK_IM 0x01 #define _FPU_MASK_DM 0x02 #define _FPU_MASK_ZM 0x04 #define _FPU_MASK_OM 0x08 #define _FPU_MASK_UM 0x10 #define _FPU_MASK_PM 0x20 /* precision control */ #define _FPU_EXTENDED 0x300 /* libm requires double extended precision. */ #define _FPU_DOUBLE 0x200 #define _FPU_SINGLE 0x0 /* rounding control */ #define _FPU_RC_NEAREST 0x0 /* RECOMMENDED */ #define _FPU_RC_DOWN 0x400 #define _FPU_RC_UP 0x800 #define _FPU_RC_ZERO 0xC00 #define _FPU_RESERVED 0xF0C0 /* Reserved bits in cw */ /* The fdlibm code requires strict IEEE double precision arithmetic, and no interrupts for exceptions, rounding to nearest. */ #define _FPU_DEFAULT 0x037f /* IEEE: same as above. */ #define _FPU_IEEE 0x037f /* Type of the control word. */ typedef unsigned int fpu_control_t __attribute__ ((__mode__ (__HI__))); /* Macros for accessing the hardware control word. "*&" is used to work around a bug in older versions of GCC. __volatile__ is used to support combination of writing the control register and reading it back. Without __volatile__, the old value may be used for reading back under compiler optimization. Note that the use of these macros is not sufficient anymore with recent hardware nor on x86-64. Some floating point operations are executed in the SSE/SSE2 engines which have their own control and status register. */ #define _FPU_GETCW(cw) __asm__ __volatile__ ("fnstcw %0" : "=m" (*&cw)) #define _FPU_SETCW(cw) __asm__ __volatile__ ("fldcw %0" : : "m" (*&cw)) /* Default control word set at startup. */ extern fpu_control_t __fpu_control; #endif /* fpu_control.h */
[+]
..
[-] iconv.h
[edit]
[-] evrpc.h
[edit]
[+]
gnu
[-] expat_config.h
[edit]
[-] ctype.h
[edit]
[-] limits.h
[edit]
[-] tar.h
[edit]
[-] evdns.h
[edit]
[-] mcheck.h
[edit]
[+]
libxslt
[-] utmp.h
[edit]
[-] printf.h
[edit]
[-] term.h
[edit]
[+]
gssrpc
[-] time.h
[edit]
[-] nl_types.h
[edit]
[-] gdfontl.h
[edit]
[+]
netipx
[+]
asm-generic
[-] termios.h
[edit]
[-] gd.h
[edit]
[-] pcre2.h
[edit]
[+]
fontconfig
[-] gpg-error.h
[edit]
[-] ftw.h
[edit]
[+]
c++
[-] maxminddb_config-64.h
[edit]
[-] features-time64.h
[edit]
[-] cpuidle.h
[edit]
[-] event.h
[edit]
[-] gnu-versions.h
[edit]
[+]
asm
[-] png.h
[edit]
[-] krb5.h
[edit]
[-] pcre_scanner.h
[edit]
[-] fts.h
[edit]
[-] threads.h
[edit]
[+]
gssapi
[-] jpeglib.h
[edit]
[-] utmpx.h
[edit]
[+]
sound
[-] complex.h
[edit]
[-] err.h
[edit]
[-] strings.h
[edit]
[-] pcrecpparg.h
[edit]
[-] spawn.h
[edit]
[+]
finclude
[-] panel.h
[edit]
[-] fmtmsg.h
[edit]
[+]
xcb
[+]
brotli
[-] tiffio.hxx
[edit]
[-] verto-module.h
[edit]
[-] idna.h
[edit]
[-] jconfig.h
[edit]
[-] tld.h
[edit]
[+]
rpc
[+]
netinet
[-] maxminddb.h
[edit]
[+]
drm
[-] thread_db.h
[edit]
[+]
neteconet
[-] autosprintf.h
[edit]
[+]
google
[-] dlfcn.h
[edit]
[-] ncurses_dll.h
[edit]
[-] tiff.h
[edit]
[+]
ext2fs
[-] monetary.h
[edit]
[-] gdfontt.h
[edit]
[-] wait.h
[edit]
[-] keyutils.h
[edit]
[+]
sepol
[-] sgtty.h
[edit]
[-] jerror.h
[edit]
[-] form.h
[edit]
[-] assert.h
[edit]
[-] tic.h
[edit]
[-] mntent.h
[edit]
[-] cursesm.h
[edit]
[-] stdio.h
[edit]
[-] error.h
[edit]
[-] execinfo.h
[edit]
[-] ieee754.h
[edit]
[-] menu.h
[edit]
[-] cursesp.h
[edit]
[+]
libmount
[-] ltdl.h
[edit]
[-] cursesw.h
[edit]
[-] jpegint.h
[edit]
[-] entities.h
[edit]
[+]
rdma
[-] lzma.h
[edit]
[-] zlib.h
[edit]
[-] pwd.h
[edit]
[+]
nfs
[+]
python3.9
[-] nc_tparm.h
[edit]
[-] gdfontg.h
[edit]
[-] gconv.h
[edit]
[-] termcap.h
[edit]
[-] etip.h
[edit]
[+]
libltdl
[+]
et
[+]
protobuf-c
[+]
bits
[+]
net
[-] ttyent.h
[edit]
[-] inttypes.h
[edit]
[-] nss.h
[edit]
[-] semaphore.h
[edit]
[-] kdb.h
[edit]
[+]
arpa
[-] alloca.h
[edit]
[-] ucontext.h
[edit]
[-] tgmath.h
[edit]
[-] tiffvers.h
[edit]
[-] fenv.h
[edit]
[-] gdfonts.h
[edit]
[-] string.h
[edit]
[-] ffitarget.h
[edit]
[-] lmdb.h
[edit]
[-] fpu_control.h
[edit]
[+]
unicode
[-] byteswap.h
[edit]
[-] setjmp.h
[edit]
[+]
sys
[-] pr29.h
[edit]
[-] zconf.h
[edit]
[-] stdint.h
[edit]
[-] errno.h
[edit]
[-] mqueue.h
[edit]
[-] evutil.h
[edit]
[+]
harfbuzz
[-] ffi-x86_64.h
[edit]
[-] grp.h
[edit]
[-] gdfontmb.h
[edit]
[-] stdc-predef.h
[edit]
[-] malloc.h
[edit]
[-] tiffconf.h
[edit]
[-] pnglibconf.h
[edit]
[-] tiffconf-64.h
[edit]
[-] resolv.h
[edit]
[-] FlexLexer.h
[edit]
[-] punycode.h
[edit]
[+]
blkid
[-] glob.h
[edit]
[-] unctrl.h
[edit]
[-] regex.h
[edit]
[+]
xen
[-] signal.h
[edit]
[+]
netrose
[+]
openssl
[-] ifaddrs.h
[edit]
[-] unistd.h
[edit]
[-] gssapi.h
[edit]
[+]
misc
[-] ffi.h
[edit]
[+]
kadm5
[+]
freetype2
[+]
video
[-] tiffio.h
[edit]
[-] wchar.h
[edit]
[-] elf.h
[edit]
[-] ncurses.h
[edit]
[-] proc_service.h
[edit]
[-] uchar.h
[edit]
[-] gdbm.h
[edit]
[-] langinfo.h
[edit]
[-] pcre.h
[edit]
[+]
webp
[-] values.h
[edit]
[+]
libexslt
[-] jconfig-64.h
[edit]
[-] netdb.h
[edit]
[-] cpio.h
[edit]
[-] libaio.h
[edit]
[-] powercap.h
[edit]
[-] dbm.h
[edit]
[-] pngconf.h
[edit]
[+]
netpacket
[-] cursslk.h
[edit]
[-] link.h
[edit]
[+]
security
[-] lastlog.h
[edit]
[-] wordexp.h
[edit]
[-] gd_io.h
[edit]
[+]
X11
[-] verto.h
[edit]
[-] curses.h
[edit]
[-] wctype.h
[edit]
[+]
netax25
[-] libintl.h
[edit]
[-] gettext-po.h
[edit]
[+]
netrom
[-] stringprep.h
[edit]
[-] argp.h
[edit]
[+]
lzma
[-] ulimit.h
[edit]
[+]
fwctl
[-] gnumake.h
[edit]
[-] krad.h
[edit]
[-] pcre_stringpiece.h
[edit]
[-] expat_external.h
[edit]
[-] shadow.h
[edit]
[-] expat.h
[edit]
[+]
pcp
[-] ar.h
[edit]
[-] endian.h
[edit]
[+]
gdbm
[-] fstab.h
[edit]
[-] envz.h
[edit]
[-] pty.h
[edit]
[-] eti.h
[edit]
[-] paths.h
[edit]
[-] argz.h
[edit]
[-] math.h
[edit]
[-] getopt.h
[edit]
[-] gpgrt.h
[edit]
[+]
ncurses
[-] gdcache.h
[edit]
[-] fstrm.h
[edit]
[-] obstack.h
[edit]
[-] maxminddb_config.h
[edit]
[+]
fstrm
[-] term_entry.h
[edit]
[-] sched.h
[edit]
[-] memory.h
[edit]
[-] gd_color_map.h
[edit]
[-] gdfx.h
[edit]
[+]
mysql
[+]
json-c
[+]
graphite2
[-] locale.h
[edit]
[+]
libxml2
[+]
e2p
[-] com_err.h
[edit]
[-] pcre2posix.h
[edit]
[+]
scsi
[+]
ncursesw
[+]
krb5
[-] gd_errors.h
[edit]
[+]
event2
[-] search.h
[edit]
[-] re_comp.h
[edit]
[-] fnmatch.h
[edit]
[+]
libpng16
[-] ndbm.h
[edit]
[-] syslog.h
[edit]
[-] sysexits.h
[edit]
[+]
netash
[-] cursesf.h
[edit]
[-] pthread.h
[edit]
[+]
linux
[-] pcrecpp.h
[edit]
[-] fcntl.h
[edit]
[-] syscall.h
[edit]
[-] libgen.h
[edit]
[-] ffitarget-x86_64.h
[edit]
[-] features.h
[edit]
[-] a.out.h
[edit]
[+]
glib-2.0
[-] evhttp.h
[edit]
[+]
gio-unix-2.0
[-] idn-free.h
[edit]
[-] gshadow.h
[edit]
[-] stdlib.h
[edit]
[-] dirent.h
[edit]
[-] pcreposix.h
[edit]
[-] crypt.h
[edit]
[+]
selinux
[-] regexp.h
[edit]
[-] aliases.h
[edit]
[-] stdio_ext.h
[edit]
[+]
netatalk
[-] utime.h
[edit]
[-] termio.h
[edit]
[-] poll.h
[edit]
[+]
GL
[+]
sysprof-4
[-] aio.h
[edit]
[-] gdpp.h
[edit]
[+]
mtd
[-] stab.h
[edit]
[-] idn-int.h
[edit]
[-] cursesapp.h
[edit]
[-] profile.h
[edit]
[-] jmorecfg.h
[edit]
[+]
bind9
[+]
protocols
[+]
netiucv
[-] bzlib.h
[edit]