1 #include <linux/types.h>
2 #include <linux/errno.h>
3 #include <asm/uaccess.h>
4
5 #include <asm/sfp-machine.h>
6 #include <math-emu/soft-fp.h>
7 #include <math-emu/double.h>
8
9 int
fctiwz(u32 * frD,void * frB)10 fctiwz(u32 *frD, void *frB)
11 {
12 FP_DECL_D(B);
13 FP_DECL_EX;
14 u32 fpscr;
15 unsigned int r;
16
17 fpscr = __FPU_FPSCR;
18 __FPU_FPSCR &= ~(3);
19 __FPU_FPSCR |= FP_RND_ZERO;
20
21 FP_UNPACK_DP(B, frB);
22 FP_TO_INT_D(r, B, 32, 1);
23 frD[1] = r;
24
25 __FPU_FPSCR = fpscr;
26
27 #ifdef DEBUG
28 printk("%s: D %p, B %p: ", __func__, frD, frB);
29 dump_double(frD);
30 printk("\n");
31 #endif
32
33 return 0;
34 }
35