Skip to content

Commit

Permalink
m68k: merge the mmu and non-mmu versions of div64.h
Browse files Browse the repository at this point in the history
Trivial merge of the mmu and non-mmu versions of div64.h

Signed-off-by: Greg Ungerer <gerg@uclinux.org>
Acked-by: Geert Uytterhoeven <geert@linux-m68k.org>
  • Loading branch information
Greg Ungerer committed Mar 24, 2009
1 parent 76adcb2 commit d20f5aa
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 33 deletions.
37 changes: 33 additions & 4 deletions arch/m68k/include/asm/div64.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,34 @@
#ifdef __uClinux__
#include "div64_no.h"
#ifndef _M68K_DIV64_H
#define _M68K_DIV64_H

#ifdef CONFIG_MMU

#include <linux/types.h>

/* n = n / base; return rem; */

#define do_div(n, base) ({ \
union { \
unsigned long n32[2]; \
unsigned long long n64; \
} __n; \
unsigned long __rem, __upper; \
\
__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])); \
} \
asm ("divu.l %2,%1:%0" \
: "=d" (__n.n32[1]), "=d" (__rem) \
: "d" (base), "1" (__upper), "0" (__n.n32[1])); \
(n) = __n.n64; \
__rem; \
})

#else
#include "div64_mm.h"
#endif
#include <asm-generic/div64.h>
#endif /* CONFIG_MMU */

#endif /* _M68K_DIV64_H */
28 changes: 0 additions & 28 deletions arch/m68k/include/asm/div64_mm.h

This file was deleted.

1 change: 0 additions & 1 deletion arch/m68k/include/asm/div64_no.h

This file was deleted.

0 comments on commit d20f5aa

Please sign in to comment.