aboutsummaryrefslogtreecommitdiff
path: root/softint/udivrem.c
diff options
context:
space:
mode:
Diffstat (limited to 'softint/udivrem.c')
-rwxr-xr-xsoftint/udivrem.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/softint/udivrem.c b/softint/udivrem.c
new file mode 100755
index 0000000..906c665
--- /dev/null
+++ b/softint/udivrem.c
@@ -0,0 +1,29 @@
+
+#include <stdint.h>
+
+
+unsigned long
+softint_udivrem(unsigned long num, unsigned long den, int modwanted)
+{
+ unsigned long bit = 1;
+ unsigned long res = 0;
+
+ while (den < num && bit && ((signed long) den >= 0))
+ {
+ den <<=1;
+ bit <<=1;
+ }
+ while (bit)
+ {
+ if (num >= den)
+ {
+ num -= den;
+ res |= bit;
+ }
+ bit >>=1;
+ den >>=1;
+ }
+ if (modwanted) return num;
+ return res;
+}
+