38 lines
668 B
C
38 lines
668 B
C
|
/* $NetBSD: fpsetmask.c,v 1.5 2005/12/24 23:10:08 perry Exp $ */
|
||
|
|
||
|
/*
|
||
|
* Written by J.T. Conklin, Apr 10, 1995
|
||
|
* Public domain.
|
||
|
*/
|
||
|
|
||
|
#include <sys/cdefs.h>
|
||
|
#if defined(LIBC_SCCS) && !defined(lint)
|
||
|
__RCSID("$NetBSD: fpsetmask.c,v 1.5 2005/12/24 23:10:08 perry Exp $");
|
||
|
#endif /* LIBC_SCCS and not lint */
|
||
|
|
||
|
#include "namespace.h"
|
||
|
|
||
|
#include <ieeefp.h>
|
||
|
|
||
|
#ifdef __weak_alias
|
||
|
__weak_alias(fpsetmask,_fpsetmask)
|
||
|
#endif
|
||
|
|
||
|
fp_except
|
||
|
fpsetmask(mask)
|
||
|
fp_except mask;
|
||
|
{
|
||
|
fp_except old;
|
||
|
fp_except new;
|
||
|
|
||
|
__asm("st %%fsr,%0" : "=m" (*&old));
|
||
|
|
||
|
new = old;
|
||
|
new &= ~(0x1f << 23);
|
||
|
new |= ((mask & 0x1f) << 23);
|
||
|
|
||
|
__asm("ld %0,%%fsr" : : "m" (*&new));
|
||
|
|
||
|
return (old >> 23) & 0x1f;
|
||
|
}
|