| |
| |
| #include <linux/uaccess.h> |
| |
| #include <asm/sfp-machine.h> |
| #include <math-emu/soft-fp.h> |
| #include <math-emu/double.h> |
| |
| void fd2ui(void *ft, void *fa) |
| { |
| <------>unsigned int r; |
| |
| <------>FP_DECL_D(A); |
| <------>FP_DECL_EX; |
| |
| <------>FP_UNPACK_DP(A, fa); |
| |
| <------>if (A_c == FP_CLS_INF) { |
| <------><------>*(unsigned int *)ft = (A_s == 0) ? 0xffffffff : 0x00000000; |
| <------><------>__FPU_FPCSR |= FP_EX_INVALID; |
| <------>} else if (A_c == FP_CLS_NAN) { |
| <------><------>*(unsigned int *)ft = 0xffffffff; |
| <------><------>__FPU_FPCSR |= FP_EX_INVALID; |
| <------>} else { |
| <------><------>FP_TO_INT_ROUND_D(r, A, 32, 0); |
| <------><------>__FPU_FPCSR |= FP_CUR_EXCEPTIONS; |
| <------><------>*(unsigned int *)ft = r; |
| <------>} |
| |
| } |
| |