Chameleon

Chameleon Svn Source Tree

Root/tags/2.0/i386/modules/klibc/__udivmodsi4.c

Source at commit 1834 created 12 years 4 months ago.
By blackosx, Fix (patch) building process. Resources now download and build successfully so package can be made. Checks are now needed to see if this works on different localizations and different systems. I have a feeling more work weill be needed to handle the unicodes etc.
1#include "libsaio.h"
2extern void __divide_error();
3uint32_t __udivmodsi4(uint32_t num, uint32_t den, uint32_t * rem_p)
4{
5uint32_t quot = 0, qbit = 1;
6
7if (den == 0) {
8__divide_error();
9return 0;/* If trap returns... */
10}
11
12/* Left-justify denominator and count shift */
13while ((int32_t) den >= 0) {
14den <<= 1;
15qbit <<= 1;
16}
17
18while (qbit) {
19if (den <= num) {
20num -= den;
21quot += qbit;
22}
23den >>= 1;
24qbit >>= 1;
25}
26
27if (rem_p)
28*rem_p = num;
29
30return quot;
31}
32

Archive Download this file

Revision: 1834