blob: 365f39f5e256f08bf12b887bd8a935cb4cbf0eb8 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Greg Ungererd20f5aa2009-02-06 14:50:08 +10002#ifndef _M68K_DIV64_H
3#define _M68K_DIV64_H
4
Greg Ungerer84f3fb72011-11-11 15:13:08 +10005#ifdef CONFIG_CPU_HAS_NO_MULDIV64
6#include <asm-generic/div64.h>
7#else
Greg Ungererd20f5aa2009-02-06 14:50:08 +10008
9#include <linux/types.h>
10
11/* n = n / base; return rem; */
12
13#define do_div(n, base) ({ \
14 union { \
15 unsigned long n32[2]; \
16 unsigned long long n64; \
17 } __n; \
18 unsigned long __rem, __upper; \
Andreas Schwabea077b12013-08-09 15:14:08 +020019 unsigned long __base = (base); \
Greg Ungererd20f5aa2009-02-06 14:50:08 +100020 \
21 __n.n64 = (n); \
22 if ((__upper = __n.n32[0])) { \
23 asm ("divul.l %2,%1:%0" \
Andreas Schwabea077b12013-08-09 15:14:08 +020024 : "=d" (__n.n32[0]), "=d" (__upper) \
25 : "d" (__base), "0" (__n.n32[0])); \
Greg Ungererd20f5aa2009-02-06 14:50:08 +100026 } \
27 asm ("divu.l %2,%1:%0" \
Andreas Schwabea077b12013-08-09 15:14:08 +020028 : "=d" (__n.n32[1]), "=d" (__rem) \
29 : "d" (__base), "1" (__upper), "0" (__n.n32[1])); \
Greg Ungererd20f5aa2009-02-06 14:50:08 +100030 (n) = __n.n64; \
31 __rem; \
32})
33
Greg Ungerer84f3fb72011-11-11 15:13:08 +100034#endif /* CONFIG_CPU_HAS_NO_MULDIV64 */
Greg Ungererd20f5aa2009-02-06 14:50:08 +100035
36#endif /* _M68K_DIV64_H */