sp_2008class.c 974 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * IEEE754 floating point arithmetic
  4. * single precision: CLASS.f
  5. * FPR[fd] = class(FPR[fs])
  6. *
  7. * MIPS floating point support
  8. * Copyright (C) 2015 Imagination Technologies, Ltd.
  9. * Author: Markos Chandras <[email protected]>
  10. */
  11. #include "ieee754sp.h"
  12. int ieee754sp_2008class(union ieee754sp x)
  13. {
  14. COMPXSP;
  15. EXPLODEXSP;
  16. /*
  17. * 10 bit mask as follows:
  18. *
  19. * bit0 = SNAN
  20. * bit1 = QNAN
  21. * bit2 = -INF
  22. * bit3 = -NORM
  23. * bit4 = -DNORM
  24. * bit5 = -ZERO
  25. * bit6 = INF
  26. * bit7 = NORM
  27. * bit8 = DNORM
  28. * bit9 = ZERO
  29. */
  30. switch(xc) {
  31. case IEEE754_CLASS_SNAN:
  32. return 0x01;
  33. case IEEE754_CLASS_QNAN:
  34. return 0x02;
  35. case IEEE754_CLASS_INF:
  36. return 0x04 << (xs ? 0 : 4);
  37. case IEEE754_CLASS_NORM:
  38. return 0x08 << (xs ? 0 : 4);
  39. case IEEE754_CLASS_DNORM:
  40. return 0x10 << (xs ? 0 : 4);
  41. case IEEE754_CLASS_ZERO:
  42. return 0x20 << (xs ? 0 : 4);
  43. default:
  44. pr_err("Unknown class: %d\n", xc);
  45. return 0;
  46. }
  47. }