Chameleon

Chameleon Svn Source Tree

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

Source at commit 1808 created 12 years 4 months ago.
By blackosx, Revise layout of package installer 'Welcome' file so it looks cleaner. Change the copyright notice to begin from 2009 as seen in the Chameleon 2.0 r431 installer. Should this date be set earlier?
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: 1808