123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- #include "int_lib.h"
- ARM_EABI_FNALIAS(uidiv, udivsi3)
- COMPILER_RT_ABI su_int
- __udivsi3(su_int n, su_int d)
- {
- const unsigned n_uword_bits = sizeof(su_int) * CHAR_BIT;
- su_int q;
- su_int r;
- unsigned sr;
-
- if (d == 0)
- return 0;
- if (n == 0)
- return 0;
- sr = __builtin_clz(d) - __builtin_clz(n);
-
- if (sr > n_uword_bits - 1)
- return 0;
- if (sr == n_uword_bits - 1)
- return n;
- ++sr;
-
-
- q = n << (n_uword_bits - sr);
- r = n >> sr;
- su_int carry = 0;
- for (; sr > 0; --sr)
- {
-
- r = (r << 1) | (q >> (n_uword_bits - 1));
- q = (q << 1) | carry;
-
- const si_int s = (si_int)(d - r - 1) >> (n_uword_bits - 1);
- carry = s & 1;
- r -= d & s;
- }
- q = (q << 1) | carry;
- return q;
- }
|