fctiwz.c 573 B

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