2012-09-17 11:09:12 +02:00
|
|
|
/* $NetBSD: fpsetmask.c,v 1.6 2012/03/17 21:35:06 martin Exp $ */
|
2011-02-14 20:36:03 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Written by J.T. Conklin, Apr 10, 1995
|
|
|
|
* Public domain.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
|
|
|
#if defined(LIBC_SCCS) && !defined(lint)
|
2012-09-17 11:09:12 +02:00
|
|
|
__RCSID("$NetBSD: fpsetmask.c,v 1.6 2012/03/17 21:35:06 martin Exp $");
|
2011-02-14 20:36:03 +01:00
|
|
|
#endif /* LIBC_SCCS and not lint */
|
|
|
|
|
|
|
|
#include "namespace.h"
|
|
|
|
|
2012-09-17 11:09:12 +02:00
|
|
|
#include <sys/types.h>
|
2011-02-14 20:36:03 +01:00
|
|
|
#include <ieeefp.h>
|
|
|
|
|
|
|
|
#ifdef __weak_alias
|
|
|
|
__weak_alias(fpsetmask,_fpsetmask)
|
|
|
|
#endif
|
|
|
|
|
2012-09-17 11:09:12 +02:00
|
|
|
#ifdef EXCEPTIONS_WITH_SOFTFLOAT
|
|
|
|
extern fp_except _softfloat_float_exception_mask;
|
|
|
|
#endif
|
|
|
|
|
2011-02-14 20:36:03 +01:00
|
|
|
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));
|
|
|
|
|
2012-09-17 11:09:12 +02:00
|
|
|
old = ((uint32_t)old >> 23) & 0x1f;
|
|
|
|
|
|
|
|
#ifdef EXCEPTIONS_WITH_SOFTFLOAT
|
|
|
|
/* update softfloat mask as well */
|
|
|
|
old |= _softfloat_float_exception_mask;
|
|
|
|
_softfloat_float_exception_mask = mask;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return old;
|
2011-02-14 20:36:03 +01:00
|
|
|
}
|