blob: ef881cfbbca90987bf0e93c9271537317c15886c [file] [log] [blame]
Greg Ungererd20f5aa2009-02-06 14:50:08 +10001#ifndef _M68K_DIV64_H
2#define _M68K_DIV64_H
3
Greg Ungerer84f3fb72011-11-11 15:13:08 +10004#ifdef CONFIG_CPU_HAS_NO_MULDIV64
5#include <asm-generic/div64.h>
6#else
Greg Ungererd20f5aa2009-02-06 14:50:08 +10007
8#include <linux/types.h>
9
10/* n = n / base; return rem; */
11
12#define do_div(n, base) ({ \
13 union { \
14 unsigned long n32[2]; \
15 unsigned long long n64; \
16 } __n; \
17 unsigned long __rem, __upper; \
Andreas Schwabea077b12013-08-09 15:14:08 +020018 unsigned long __base = (base); \
Greg Ungererd20f5aa2009-02-06 14:50:08 +100019 \
20 __n.n64 = (n); \
21 if ((__upper = __n.n32[0])) { \
22 asm ("divul.l %2,%1:%0" \
Andreas Schwabea077b12013-08-09 15:14:08 +020023 : "=d" (__n.n32[0]), "=d" (__upper) \
24 : "d" (__base), "0" (__n.n32[0])); \
Greg Ungererd20f5aa2009-02-06 14:50:08 +100025 } \
26 asm ("divu.l %2,%1:%0" \
Andreas Schwabea077b12013-08-09 15:14:08 +020027 : "=d" (__n.n32[1]), "=d" (__rem) \
28 : "d" (__base), "1" (__upper), "0" (__n.n32[1])); \
Greg Ungererd20f5aa2009-02-06 14:50:08 +100029 (n) = __n.n64; \
30 __rem; \
31})
32
Greg Ungerer84f3fb72011-11-11 15:13:08 +100033#endif /* CONFIG_CPU_HAS_NO_MULDIV64 */
Greg Ungererd20f5aa2009-02-06 14:50:08 +100034
35#endif /* _M68K_DIV64_H */