mtfsf.c
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:1k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /*
  2.  * BK Id: SCCS/s.mtfsf.c 1.6 05/17/01 18:14:23 cort
  3.  */
  4. #include <linux/types.h>
  5. #include <linux/errno.h>
  6. #include <asm/uaccess.h>
  7. #include "soft-fp.h"
  8. int
  9. mtfsf(unsigned int FM, u32 *frB)
  10. {
  11. u32 mask;
  12. if (FM == 0)
  13. return 0;
  14. if (FM == 0xff)
  15. mask = 0x9fffffff;
  16. else {
  17. mask = 0;
  18. if (FM & (1 << 0))
  19. mask |= 0x90000000;
  20. if (FM & (1 << 1))
  21. mask |= 0x0f000000;
  22. if (FM & (1 << 2))
  23. mask |= 0x00f00000;
  24. if (FM & (1 << 3))
  25. mask |= 0x000f0000;
  26. if (FM & (1 << 4))
  27. mask |= 0x0000f000;
  28. if (FM & (1 << 5))
  29. mask |= 0x00000f00;
  30. if (FM & (1 << 6))
  31. mask |= 0x000000f0;
  32. if (FM & (1 << 7))
  33. mask |= 0x0000000f;
  34. }
  35. __FPU_FPSCR &= ~(mask);
  36. __FPU_FPSCR |= (frB[1] & mask);
  37. #ifdef DEBUG
  38. printk("%s: %02x %p: %08lxn", __FUNCTION__, FM, frB, __FPU_FPSCR);
  39. #endif
  40. return 0;
  41. }