control_w.h 1.8 KB

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