1
2
3
4
5
6
7
8 !! libgcc routines for the Renesas / SuperH SH CPUs.
9 !! Contributed by Steve Chamberlain.
10 !! sac@cygnus.com
11
12 !! ashiftrt_r4_x, ___ashrsi3, ___ashlsi3, ___lshrsi3 routines
13 !! recoded in assembly by Toshiyasu Morita
14 !! tm@netcom.com
15
16
17
18
19
20
21
22 .global __udiv_qrnnd_16
23 .balign 8
24 __udiv_qrnnd_16:
25 div0u
26 cmp/hi r6,r0
27 bt .Lots
28 .rept 16
29 div1 r6,r0
30 .endr
31 extu.w r0,r1
32 bt 0f
33 add r6,r0
34 0: rotcl r1
35 mulu.w r1,r5
36 xtrct r4,r0
37 swap.w r0,r0
38 sts macl,r2
39 cmp/hs r2,r0
40 sub r2,r0
41 bt 0f
42 addc r5,r0
43 add #-1,r1
44 bt 0f
45 1: add #-1,r1
46 rts
47 add r5,r0
48 .balign 8
49 .Lots:
50 sub r5,r0
51 swap.w r4,r1
52 xtrct r0,r1
53 clrt
54 mov r1,r0
55 addc r5,r0
56 mov #-1,r1
57 bf/s 1b
58 shlr16 r1
59 0: rts
60 nop