control_w.h 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /*---------------------------------------------------------------------------+
  2. | control_w.h |
  3. | |
  4. | Copyright (C) 1992,1993 |
  5. | W. Metzenthen, 22 Parker St, Ormond, Vic 3163, |
  6. | Australia. E-mail billm@vaxc.cc.monash.edu.au |
  7. | |
  8. +---------------------------------------------------------------------------*/
  9. #ifndef _CONTROLW_H_
  10. #define _CONTROLW_H_
  11. #ifdef __ASSEMBLY__
  12. #define _Const_(x) $##x
  13. #else
  14. #define _Const_(x) x
  15. #endif
  16. #define CW_RC _Const_(0x0C00) /* rounding control */
  17. #define CW_PC _Const_(0x0300) /* precision control */
  18. #define CW_Precision Const_(0x0020) /* loss of precision mask */
  19. #define CW_Underflow Const_(0x0010) /* underflow mask */
  20. #define CW_Overflow Const_(0x0008) /* overflow mask */
  21. #define CW_ZeroDiv Const_(0x0004) /* divide by zero mask */
  22. #define CW_Denormal Const_(0x0002) /* denormalized operand mask */
  23. #define CW_Invalid Const_(0x0001) /* invalid operation mask */
  24. #define CW_Exceptions _Const_(0x003f) /* all masks */
  25. #define RC_RND _Const_(0x0000)
  26. #define RC_DOWN _Const_(0x0400)
  27. #define RC_UP _Const_(0x0800)
  28. #define RC_CHOP _Const_(0x0C00)
  29. /* p 15-5: Precision control bits affect only the following:
  30. ADD, SUB(R), MUL, DIV(R), and SQRT */
  31. #define PR_24_BITS _Const_(0x000)
  32. #define PR_53_BITS _Const_(0x200)
  33. #define PR_64_BITS _Const_(0x300)
  34. #define PR_RESERVED_BITS _Const_(0x100)
  35. /* FULL_PRECISION simulates all exceptions masked */
  36. #define FULL_PRECISION (PR_64_BITS | RC_RND | 0x3f)
  37. #endif /* _CONTROLW_H_ */