32 lines
490 B
C
32 lines
490 B
C
#include <stdint.h>
|
|
|
|
uint64_t __udivmoddi4(uint64_t num, uint64_t den, uint64_t * rem_p)
|
|
{
|
|
uint64_t quot = 0, qbit = 1;
|
|
|
|
if (den == 0) {
|
|
asm volatile ("int $0");
|
|
return 0; /* If trap returns... */
|
|
}
|
|
|
|
/* Left-justify denominator and count shift */
|
|
while ((int64_t) den >= 0) {
|
|
den <<= 1;
|
|
qbit <<= 1;
|
|
}
|
|
|
|
while (qbit) {
|
|
if (den <= num) {
|
|
num -= den;
|
|
quot += qbit;
|
|
}
|
|
den >>= 1;
|
|
qbit >>= 1;
|
|
}
|
|
|
|
if (rem_p)
|
|
*rem_p = num;
|
|
|
|
return quot;
|
|
}
|