/* $OpenBSD: flt_rounds.c,v 1.1 2001/08/29 01:45:24 art Exp $ */ /* $NetBSD: flt_rounds.c,v 1.1 1998/09/11 04:56:23 eeh Exp $ */ /* * Written by J.T. Conklin, Apr 10, 1995 * Public domain. */ #include #include static const int map[] = { 1, /* round to nearest */ 0, /* round to zero */ 3, /* round to negative infinity */ 2 /* round to positive infinity */ }; int __flt_rounds() { int x; __asm__("st %%fsr,%0" : "=m" (*&x)); return map[(x >> 30) & 0x03]; }