/* FPU control word bits. x86 version. Copyright (C) 1993-2012 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 <http://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 */
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
GL | Folder | 0755 |
|
|
X11 | Folder | 0755 |
|
|
arpa | Folder | 0755 |
|
|
asm | Folder | 0755 |
|
|
asm-generic | Folder | 0755 |
|
|
bind9 | Folder | 0755 |
|
|
bits | Folder | 0755 |
|
|
blkid | Folder | 0755 |
|
|
c++ | Folder | 0755 |
|
|
db4.7.25 | Folder | 0755 |
|
|
drm | Folder | 0755 |
|
|
e2p | Folder | 0755 |
|
|
et | Folder | 0755 |
|
|
ext2fs | Folder | 0755 |
|
|
fontconfig | Folder | 0755 |
|
|
freetype2 | Folder | 0755 |
|
|
gdbm | Folder | 0755 |
|
|
gnu | Folder | 0755 |
|
|
gssapi | Folder | 0755 |
|
|
gssrpc | Folder | 0755 |
|
|
kadm5 | Folder | 0755 |
|
|
krb5 | Folder | 0755 |
|
|
libdb | Folder | 0755 |
|
|
libexslt | Folder | 0755 |
|
|
libltdl | Folder | 0755 |
|
|
libmount | Folder | 0755 |
|
|
libpng15 | Folder | 0755 |
|
|
libxml2 | Folder | 0755 |
|
|
libxslt | Folder | 0755 |
|
|
linux | Folder | 0755 |
|
|
lzma | Folder | 0755 |
|
|
misc | Folder | 0755 |
|
|
mtd | Folder | 0755 |
|
|
mysql | Folder | 0755 |
|
|
ncurses | Folder | 0755 |
|
|
ncursesw | Folder | 0755 |
|
|
net | Folder | 0755 |
|
|
netash | Folder | 0755 |
|
|
netatalk | Folder | 0755 |
|
|
netax25 | Folder | 0755 |
|
|
neteconet | Folder | 0755 |
|
|
netinet | Folder | 0755 |
|
|
netipx | Folder | 0755 |
|
|
netiucv | Folder | 0755 |
|
|
netpacket | Folder | 0755 |
|
|
netrom | Folder | 0755 |
|
|
netrose | Folder | 0755 |
|
|
nfs | Folder | 0755 |
|
|
openssl | Folder | 0755 |
|
|
protocols | Folder | 0755 |
|
|
python2.7 | Folder | 0755 |
|
|
quota | Folder | 0755 |
|
|
rdma | Folder | 0755 |
|
|
rpc | Folder | 0755 |
|
|
rpcsvc | Folder | 0755 |
|
|
scsi | Folder | 0755 |
|
|
security | Folder | 0755 |
|
|
selinux | Folder | 0755 |
|
|
sepol | Folder | 0755 |
|
|
sound | Folder | 0755 |
|
|
sys | Folder | 0755 |
|
|
uapi | Folder | 0755 |
|
|
uuid | Folder | 0755 |
|
|
video | Folder | 0755 |
|
|
xcb | Folder | 0755 |
|
|
xen | Folder | 0755 |
|
|
FlexLexer.h | File | 6.07 KB | 0644 |
|
_G_config.h | File | 1.26 KB | 0644 |
|
a.out.h | File | 4.25 KB | 0644 |
|
aio.h | File | 7.27 KB | 0644 |
|
aliases.h | File | 2 KB | 0644 |
|
alloca.h | File | 1.19 KB | 0644 |
|
ar.h | File | 1.68 KB | 0644 |
|
argp.h | File | 24.75 KB | 0644 |
|
argz.h | File | 6.96 KB | 0644 |
|
assert.h | File | 3.52 KB | 0644 |
|
autosprintf.h | File | 2.33 KB | 0644 |
|
byteswap.h | File | 1.41 KB | 0644 |
|
com_err.h | File | 2.07 KB | 0644 |
|
complex.h | File | 3.62 KB | 0644 |
|
cpio.h | File | 2.21 KB | 0644 |
|
cpufreq.h | File | 5.8 KB | 0644 |
|
crypt.h | File | 2.22 KB | 0644 |
|
ctype.h | File | 11.52 KB | 0644 |
|
curses.h | File | 93.19 KB | 0644 |
|
cursesapp.h | File | 6.62 KB | 0644 |
|
cursesf.h | File | 27.05 KB | 0644 |
|
cursesm.h | File | 19.09 KB | 0644 |
|
cursesp.h | File | 8.3 KB | 0644 |
|
cursesw.h | File | 48.24 KB | 0644 |
|
cursslk.h | File | 7.13 KB | 0644 |
|
db.h | File | 120.21 KB | 0444 |
|
db_185.h | File | 5.84 KB | 0444 |
|
dbm.h | File | 1.37 KB | 0644 |
|
dirent.h | File | 12.34 KB | 0644 |
|
dlfcn.h | File | 6.88 KB | 0644 |
|
elf.h | File | 141.01 KB | 0644 |
|
endian.h | File | 2.95 KB | 0644 |
|
entities.h | File | 4.56 KB | 0644 |
|
envz.h | File | 2.82 KB | 0644 |
|
err.h | File | 2.18 KB | 0644 |
|
errno.h | File | 2.33 KB | 0644 |
|
error.h | File | 2.01 KB | 0644 |
|
eti.h | File | 2.82 KB | 0644 |
|
etip.h | File | 9.04 KB | 0644 |
|
execinfo.h | File | 1.5 KB | 0644 |
|
expat.h | File | 40.92 KB | 0644 |
|
expat_external.h | File | 3.29 KB | 0644 |
|
fam.h | File | 6.71 KB | 0644 |
|
fcntl.h | File | 9.89 KB | 0644 |
|
features.h | File | 12.87 KB | 0644 |
|
fenv.h | File | 4.5 KB | 0644 |
|
fmtmsg.h | File | 3.18 KB | 0644 |
|
fnmatch.h | File | 2.27 KB | 0644 |
|
form.h | File | 17.56 KB | 0644 |
|
fpu_control.h | File | 3.5 KB | 0644 |
|
fstab.h | File | 3.04 KB | 0644 |
|
fts.h | File | 5.17 KB | 0644 |
|
ftw.h | File | 5.15 KB | 0644 |
|
gconv.h | File | 5.16 KB | 0644 |
|
gcrypt-module.h | File | 7.18 KB | 0644 |
|
gcrypt.h | File | 76.51 KB | 0644 |
|
gd.h | File | 32.02 KB | 0644 |
|
gd_io.h | File | 1.13 KB | 0644 |
|
gdbm.h | File | 5.75 KB | 0644 |
|
gdcache.h | File | 2.75 KB | 0644 |
|
gdfontg.h | File | 623 B | 0644 |
|
gdfontl.h | File | 621 B | 0644 |
|
gdfontmb.h | File | 590 B | 0644 |
|
gdfonts.h | File | 585 B | 0644 |
|
gdfontt.h | File | 617 B | 0644 |
|
gdfx.h | File | 2.34 KB | 0644 |
|
getopt.h | File | 6.53 KB | 0644 |
|
gettext-po.h | File | 15.17 KB | 0644 |
|
glob.h | File | 6.51 KB | 0644 |
|
gnu-versions.h | File | 2.29 KB | 0644 |
|
gpg-error.h | File | 23.66 KB | 0644 |
|
grp.h | File | 6.75 KB | 0644 |
|
gshadow.h | File | 4.43 KB | 0644 |
|
gssapi.h | File | 181 B | 0644 |
|
iconv.h | File | 1.83 KB | 0644 |
|
idn-free.h | File | 2.41 KB | 0644 |
|
idn-int.h | File | 20 B | 0644 |
|
idna.h | File | 3.48 KB | 0644 |
|
ieee754.h | File | 4.81 KB | 0644 |
|
ifaddrs.h | File | 2.77 KB | 0644 |
|
inttypes.h | File | 11.61 KB | 0644 |
|
jconfig.h | File | 1.7 KB | 0644 |
|
jerror.h | File | 14.4 KB | 0644 |
|
jmorecfg.h | File | 13.5 KB | 0644 |
|
jpeglib.h | File | 49.12 KB | 0644 |
|
kdb.h | File | 60.12 KB | 0644 |
|
keyutils.h | File | 7.08 KB | 0644 |
|
krad.h | File | 8.72 KB | 0644 |
|
krb5.h | File | 402 B | 0644 |
|
langinfo.h | File | 15.57 KB | 0644 |
|
lastlog.h | File | 126 B | 0644 |
|
libaio.h | File | 7.8 KB | 0644 |
|
libgen.h | File | 1.37 KB | 0644 |
|
libintl.h | File | 4.49 KB | 0644 |
|
libio.h | File | 16.87 KB | 0644 |
|
libssh2.h | File | 51.09 KB | 0644 |
|
libssh2_publickey.h | File | 4.8 KB | 0644 |
|
libssh2_sftp.h | File | 15.35 KB | 0644 |
|
limits.h | File | 4.42 KB | 0644 |
|
link.h | File | 6.99 KB | 0644 |
|
locale.h | File | 7.78 KB | 0644 |
|
ltdl.h | File | 5.58 KB | 0644 |
|
lzma.h | File | 9.51 KB | 0644 |
|
malloc.h | File | 6.44 KB | 0644 |
|
math.h | File | 15.7 KB | 0644 |
|
mcheck.h | File | 2.4 KB | 0644 |
|
memory.h | File | 962 B | 0644 |
|
menu.h | File | 11.67 KB | 0644 |
|
mntent.h | File | 3.3 KB | 0644 |
|
monetary.h | File | 1.73 KB | 0644 |
|
mqueue.h | File | 3.7 KB | 0644 |
|
nc_tparm.h | File | 4.05 KB | 0644 |
|
ncurses.h | File | 93.19 KB | 0644 |
|
ncurses_dll.h | File | 3.83 KB | 0644 |
|
ndbm.h | File | 2.39 KB | 0644 |
|
netdb.h | File | 27.46 KB | 0644 |
|
nl_types.h | File | 1.73 KB | 0644 |
|
nss.h | File | 1.85 KB | 0644 |
|
obstack.h | File | 18.84 KB | 0644 |
|
panel.h | File | 3.97 KB | 0644 |
|
paths.h | File | 2.91 KB | 0644 |
|
pcre.h | File | 29.73 KB | 0644 |
|
pcre_scanner.h | File | 6.45 KB | 0644 |
|
pcre_stringpiece.h | File | 6.11 KB | 0644 |
|
pcrecpp.h | File | 25.91 KB | 0644 |
|
pcrecpparg.h | File | 6.62 KB | 0644 |
|
pcreposix.h | File | 5.32 KB | 0644 |
|
png.h | File | 113.36 KB | 0644 |
|
pngconf.h | File | 20.94 KB | 0644 |
|
pnglibconf.h | File | 6.3 KB | 0644 |
|
poll.h | File | 22 B | 0644 |
|
pr29.h | File | 2.07 KB | 0644 |
|
printf.h | File | 6.56 KB | 0644 |
|
profile.h | File | 11.87 KB | 0644 |
|
pthread.h | File | 39.95 KB | 0644 |
|
pty.h | File | 1.51 KB | 0644 |
|
punycode.h | File | 9.36 KB | 0644 |
|
pwd.h | File | 5.87 KB | 0644 |
|
re_comp.h | File | 957 B | 0644 |
|
regex.h | File | 21.58 KB | 0644 |
|
regexp.h | File | 6.89 KB | 0644 |
|
resolv.h | File | 14.67 KB | 0644 |
|
sched.h | File | 4.55 KB | 0644 |
|
search.h | File | 5.11 KB | 0644 |
|
semaphore.h | File | 2.36 KB | 0644 |
|
setjmp.h | File | 3.97 KB | 0644 |
|
sgtty.h | File | 1.33 KB | 0644 |
|
shadow.h | File | 5.1 KB | 0644 |
|
signal.h | File | 13.3 KB | 0644 |
|
spawn.h | File | 6.53 KB | 0644 |
|
stab.h | File | 264 B | 0644 |
|
stdc-predef.h | File | 1.59 KB | 0644 |
|
stdint.h | File | 7.94 KB | 0644 |
|
stdio.h | File | 30.9 KB | 0644 |
|
stdio_ext.h | File | 2.74 KB | 0644 |
|
stdlib.h | File | 33.23 KB | 0644 |
|
string.h | File | 21.75 KB | 0644 |
|
stringprep.h | File | 8 KB | 0644 |
|
strings.h | File | 4.55 KB | 0644 |
|
syscall.h | File | 25 B | 0644 |
|
sysexits.h | File | 5.11 KB | 0644 |
|
syslog.h | File | 24 B | 0644 |
|
tar.h | File | 3.67 KB | 0644 |
|
tcpd.h | File | 11.48 KB | 0644 |
|
term.h | File | 38.63 KB | 0644 |
|
term_entry.h | File | 7.91 KB | 0644 |
|
termcap.h | File | 3.4 KB | 0644 |
|
termio.h | File | 214 B | 0644 |
|
termios.h | File | 3.52 KB | 0644 |
|
tgmath.h | File | 18.11 KB | 0644 |
|
thread_db.h | File | 15.65 KB | 0644 |
|
tic.h | File | 12.35 KB | 0644 |
|
tiff.h | File | 34.95 KB | 0644 |
|
tiffconf-64.h | File | 3.35 KB | 0644 |
|
tiffconf.h | File | 250 B | 0644 |
|
tiffio.h | File | 23.14 KB | 0644 |
|
tiffio.hxx | File | 1.66 KB | 0644 |
|
tiffvers.h | File | 410 B | 0644 |
|
time.h | File | 13.4 KB | 0644 |
|
tld.h | File | 4.54 KB | 0644 |
|
ttyent.h | File | 2.44 KB | 0644 |
|
uchar.h | File | 2.42 KB | 0644 |
|
ucontext.h | File | 1.92 KB | 0644 |
|
ulimit.h | File | 1.55 KB | 0644 |
|
unctrl.h | File | 3.03 KB | 0644 |
|
unistd.h | File | 41.78 KB | 0644 |
|
ustat.h | File | 23 B | 0644 |
|
utime.h | File | 1.5 KB | 0644 |
|
utmp.h | File | 3.16 KB | 0644 |
|
utmpx.h | File | 4.02 KB | 0644 |
|
values.h | File | 1.92 KB | 0644 |
|
verto-module.h | File | 6.48 KB | 0644 |
|
verto.h | File | 18.57 KB | 0644 |
|
wait.h | File | 22 B | 0644 |
|
wchar.h | File | 31.37 KB | 0644 |
|
wctype.h | File | 10.89 KB | 0644 |
|
wordexp.h | File | 2.47 KB | 0644 |
|
xlocale.h | File | 1.66 KB | 0644 |
|
yaml.h | File | 52.95 KB | 0644 |
|
zconf.h | File | 14.92 KB | 0644 |
|
zlib.h | File | 84.68 KB | 0644 |
|