| /* SPDX-License-Identifier: GPL-2.0 */ |
| #ifdef CONFIG_CPU_HAS_NO_MULDIV64 |
| #include <asm-generic/div64.h> |
| /* n = n / base; return rem; */ |
| #define do_div(n, base) ({ \ |
| unsigned long long n64; \ |
| unsigned long __rem, __upper; \ |
| unsigned long __base = (base); \ |
| 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[1]), "=d" (__rem) \ |
| : "d" (__base), "1" (__upper), "0" (__n.n32[1])); \ |
| #endif /* CONFIG_CPU_HAS_NO_MULDIV64 */ |
| #endif /* _M68K_DIV64_H */ |