sfp-util_32.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. #include <linux/kernel.h>
  2. #include <linux/sched.h>
  3. #include <linux/types.h>
  4. #include <asm/byteorder.h>
  5. #define add_ssaaaa(sh, sl, ah, al, bh, bl) \
  6. __asm__ ("addcc %r4,%5,%1\n\t" \
  7. "addx %r2,%3,%0\n" \
  8. : "=r" (sh), \
  9. "=&r" (sl) \
  10. : "%rJ" ((USItype)(ah)), \
  11. "rI" ((USItype)(bh)), \
  12. "%rJ" ((USItype)(al)), \
  13. "rI" ((USItype)(bl)) \
  14. : "cc")
  15. #define sub_ddmmss(sh, sl, ah, al, bh, bl) \
  16. __asm__ ("subcc %r4,%5,%1\n\t" \
  17. "subx %r2,%3,%0\n" \
  18. : "=r" (sh), \
  19. "=&r" (sl) \
  20. : "rJ" ((USItype)(ah)), \
  21. "rI" ((USItype)(bh)), \
  22. "rJ" ((USItype)(al)), \
  23. "rI" ((USItype)(bl)) \
  24. : "cc")
  25. #define umul_ppmm(w1, w0, u, v) \
  26. __asm__ ("! Inlined umul_ppmm\n\t" \
  27. "wr %%g0,%2,%%y ! SPARC has 0-3 delay insn after a wr\n\t" \
  28. "sra %3,31,%%g2 ! Don't move this insn\n\t" \
  29. "and %2,%%g2,%%g2 ! Don't move this insn\n\t" \
  30. "andcc %%g0,0,%%g1 ! Don't move this insn\n\t" \
  31. "mulscc %%g1,%3,%%g1\n\t" \
  32. "mulscc %%g1,%3,%%g1\n\t" \
  33. "mulscc %%g1,%3,%%g1\n\t" \
  34. "mulscc %%g1,%3,%%g1\n\t" \
  35. "mulscc %%g1,%3,%%g1\n\t" \
  36. "mulscc %%g1,%3,%%g1\n\t" \
  37. "mulscc %%g1,%3,%%g1\n\t" \
  38. "mulscc %%g1,%3,%%g1\n\t" \
  39. "mulscc %%g1,%3,%%g1\n\t" \
  40. "mulscc %%g1,%3,%%g1\n\t" \
  41. "mulscc %%g1,%3,%%g1\n\t" \
  42. "mulscc %%g1,%3,%%g1\n\t" \
  43. "mulscc %%g1,%3,%%g1\n\t" \
  44. "mulscc %%g1,%3,%%g1\n\t" \
  45. "mulscc %%g1,%3,%%g1\n\t" \
  46. "mulscc %%g1,%3,%%g1\n\t" \
  47. "mulscc %%g1,%3,%%g1\n\t" \
  48. "mulscc %%g1,%3,%%g1\n\t" \
  49. "mulscc %%g1,%3,%%g1\n\t" \
  50. "mulscc %%g1,%3,%%g1\n\t" \
  51. "mulscc %%g1,%3,%%g1\n\t" \
  52. "mulscc %%g1,%3,%%g1\n\t" \
  53. "mulscc %%g1,%3,%%g1\n\t" \
  54. "mulscc %%g1,%3,%%g1\n\t" \
  55. "mulscc %%g1,%3,%%g1\n\t" \
  56. "mulscc %%g1,%3,%%g1\n\t" \
  57. "mulscc %%g1,%3,%%g1\n\t" \
  58. "mulscc %%g1,%3,%%g1\n\t" \
  59. "mulscc %%g1,%3,%%g1\n\t" \
  60. "mulscc %%g1,%3,%%g1\n\t" \
  61. "mulscc %%g1,%3,%%g1\n\t" \
  62. "mulscc %%g1,%3,%%g1\n\t" \
  63. "mulscc %%g1,0,%%g1\n\t" \
  64. "add %%g1,%%g2,%0\n\t" \
  65. "rd %%y,%1\n" \
  66. : "=r" (w1), \
  67. "=r" (w0) \
  68. : "%rI" ((USItype)(u)), \
  69. "r" ((USItype)(v)) \
  70. : "%g1", "%g2", "cc")
  71. /* It's quite necessary to add this much assembler for the sparc.
  72. The default udiv_qrnnd (in C) is more than 10 times slower! */
  73. #define udiv_qrnnd(q, r, n1, n0, d) \
  74. __asm__ ("! Inlined udiv_qrnnd\n\t" \
  75. "mov 32,%%g1\n\t" \
  76. "subcc %1,%2,%%g0\n\t" \
  77. "1: bcs 5f\n\t" \
  78. "addxcc %0,%0,%0 ! shift n1n0 and a q-bit in lsb\n\t" \
  79. "sub %1,%2,%1 ! this kills msb of n\n\t" \
  80. "addx %1,%1,%1 ! so this can't give carry\n\t" \
  81. "subcc %%g1,1,%%g1\n\t" \
  82. "2: bne 1b\n\t" \
  83. "subcc %1,%2,%%g0\n\t" \
  84. "bcs 3f\n\t" \
  85. "addxcc %0,%0,%0 ! shift n1n0 and a q-bit in lsb\n\t" \
  86. "b 3f\n\t" \
  87. "sub %1,%2,%1 ! this kills msb of n\n\t" \
  88. "4: sub %1,%2,%1\n\t" \
  89. "5: addxcc %1,%1,%1\n\t" \
  90. "bcc 2b\n\t" \
  91. "subcc %%g1,1,%%g1\n\t" \
  92. "! Got carry from n. Subtract next step to cancel this carry.\n\t" \
  93. "bne 4b\n\t" \
  94. "addcc %0,%0,%0 ! shift n1n0 and a 0-bit in lsb\n\t" \
  95. "sub %1,%2,%1\n\t" \
  96. "3: xnor %0,0,%0\n\t" \
  97. "! End of inline udiv_qrnnd\n" \
  98. : "=&r" (q), \
  99. "=&r" (r) \
  100. : "r" ((USItype)(d)), \
  101. "1" ((USItype)(n1)), \
  102. "0" ((USItype)(n0)) : "%g1", "cc")
  103. #define UDIV_NEEDS_NORMALIZATION 0
  104. #define abort() \
  105. return 0
  106. #ifdef __BIG_ENDIAN
  107. #define __BYTE_ORDER __BIG_ENDIAN
  108. #else
  109. #define __BYTE_ORDER __LITTLE_ENDIAN
  110. #endif