sdivsi3.S 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /* $NetBSD: sdivsi3.S,v 1.8 2006/05/22 20:56:44 uwe Exp $ */
  2. /*-
  3. * Copyright (c) 1990 The Regents of the University of California.
  4. * All rights reserved.
  5. *
  6. * This code is derived from software contributed to Berkeley by
  7. * William Jolitz.
  8. *
  9. * Redistribution and use in source and binary forms, with or without
  10. * modification, are permitted provided that the following conditions
  11. * are met:
  12. * 1. Redistributions of source code must retain the above copyright
  13. * notice, this list of conditions and the following disclaimer.
  14. * 2. Redistributions in binary form must reproduce the above copyright
  15. * notice, this list of conditions and the following disclaimer in the
  16. * documentation and/or other materials provided with the distribution.
  17. * 3. Neither the name of the University nor the names of its contributors
  18. * may be used to endorse or promote products derived from this software
  19. * without specific prior written permission.
  20. *
  21. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31. * SUCH DAMAGE.
  32. *
  33. * from: @(#)udivsi3.s 5.1 (Berkeley) 5/15/90
  34. */
  35. #include <machine/asm.h>
  36. /* r0 <= r4 / r5 */
  37. NENTRY(__sdivsi3)
  38. mov r4, r0
  39. mov r5, r1
  40. tst r1, r1
  41. bt div_by_zero
  42. mov #0, r2
  43. div0s r2, r0
  44. subc r3, r3
  45. subc r2, r0
  46. div0s r1, r3
  47. #define DIVSTEP rotcl r0; div1 r1, r3
  48. /* repeat 32 times */
  49. DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP;
  50. DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP;
  51. DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP;
  52. DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP; DIVSTEP;
  53. #undef DIVSTEP
  54. rotcl r0
  55. rts
  56. addc r2, r0
  57. div_by_zero:
  58. #ifdef _KERNEL
  59. rts
  60. mov #0, r0
  61. #else
  62. mov.l r14, @-r15
  63. sts.l pr, @-r15
  64. mov r15, r14
  65. mov.l L_raise, r1
  66. #ifdef PIC
  67. 1: bsrf r1
  68. #else
  69. jsr @r1
  70. #endif
  71. mov #8, r4 /* delay slot. 8 <- SIGFPE. */
  72. mov #0, r0
  73. lds.l @r15+, pr
  74. rts
  75. mov.l @r15+, r14
  76. .align 2
  77. L_raise:
  78. #ifdef PIC
  79. .long _C_LABEL(raise)-(1b+4)
  80. #else
  81. .long _C_LABEL(raise)
  82. #endif
  83. #endif