|
@@ -15,16 +15,17 @@
|
|
|
unsigned long long n64; \
|
|
|
} __n; \
|
|
|
unsigned long __rem, __upper; \
|
|
|
+ unsigned long __base = (base); \
|
|
|
\
|
|
|
__n.n64 = (n); \
|
|
|
if ((__upper = __n.n32[0])) { \
|
|
|
asm ("divul.l %2,%1:%0" \
|
|
|
- : "=d" (__n.n32[0]), "=d" (__upper) \
|
|
|
- : "d" (base), "0" (__n.n32[0])); \
|
|
|
+ : "=d" (__n.n32[0]), "=d" (__upper) \
|
|
|
+ : "d" (__base), "0" (__n.n32[0])); \
|
|
|
} \
|
|
|
asm ("divu.l %2,%1:%0" \
|
|
|
- : "=d" (__n.n32[1]), "=d" (__rem) \
|
|
|
- : "d" (base), "1" (__upper), "0" (__n.n32[1])); \
|
|
|
+ : "=d" (__n.n32[1]), "=d" (__rem) \
|
|
|
+ : "d" (__base), "1" (__upper), "0" (__n.n32[1])); \
|
|
|
(n) = __n.n64; \
|
|
|
__rem; \
|
|
|
})
|