diff options
| -rw-r--r-- | arch/m68k/emu/natfeat.c | 23 | ||||
| -rw-r--r-- | arch/m68k/include/asm/div64.h | 9 |
2 files changed, 24 insertions, 8 deletions
diff --git a/arch/m68k/emu/natfeat.c b/arch/m68k/emu/natfeat.c index 2291a7d69d49..fa277aecfb78 100644 --- a/arch/m68k/emu/natfeat.c +++ b/arch/m68k/emu/natfeat.c | |||
| @@ -18,9 +18,11 @@ | |||
| 18 | #include <asm/machdep.h> | 18 | #include <asm/machdep.h> |
| 19 | #include <asm/natfeat.h> | 19 | #include <asm/natfeat.h> |
| 20 | 20 | ||
| 21 | extern long nf_get_id2(const char *feature_name); | ||
| 22 | |||
| 21 | asm("\n" | 23 | asm("\n" |
| 22 | " .global nf_get_id,nf_call\n" | 24 | " .global nf_get_id2,nf_call\n" |
| 23 | "nf_get_id:\n" | 25 | "nf_get_id2:\n" |
| 24 | " .short 0x7300\n" | 26 | " .short 0x7300\n" |
| 25 | " rts\n" | 27 | " rts\n" |
| 26 | "nf_call:\n" | 28 | "nf_call:\n" |
| @@ -29,12 +31,25 @@ asm("\n" | |||
| 29 | "1: moveq.l #0,%d0\n" | 31 | "1: moveq.l #0,%d0\n" |
| 30 | " rts\n" | 32 | " rts\n" |
| 31 | " .section __ex_table,\"a\"\n" | 33 | " .section __ex_table,\"a\"\n" |
| 32 | " .long nf_get_id,1b\n" | 34 | " .long nf_get_id2,1b\n" |
| 33 | " .long nf_call,1b\n" | 35 | " .long nf_call,1b\n" |
| 34 | " .previous"); | 36 | " .previous"); |
| 35 | EXPORT_SYMBOL_GPL(nf_get_id); | ||
| 36 | EXPORT_SYMBOL_GPL(nf_call); | 37 | EXPORT_SYMBOL_GPL(nf_call); |
| 37 | 38 | ||
| 39 | long nf_get_id(const char *feature_name) | ||
| 40 | { | ||
| 41 | /* feature_name may be in vmalloc()ed memory, so make a copy */ | ||
| 42 | char name_copy[32]; | ||
| 43 | size_t n; | ||
| 44 | |||
| 45 | n = strlcpy(name_copy, feature_name, sizeof(name_copy)); | ||
| 46 | if (n >= sizeof(name_copy)) | ||
| 47 | return 0; | ||
| 48 | |||
| 49 | return nf_get_id2(name_copy); | ||
| 50 | } | ||
| 51 | EXPORT_SYMBOL_GPL(nf_get_id); | ||
| 52 | |||
| 38 | void nfprint(const char *fmt, ...) | 53 | void nfprint(const char *fmt, ...) |
| 39 | { | 54 | { |
| 40 | static char buf[256]; | 55 | static char buf[256]; |
diff --git a/arch/m68k/include/asm/div64.h b/arch/m68k/include/asm/div64.h index 444ea8a09e9f..ef881cfbbca9 100644 --- a/arch/m68k/include/asm/div64.h +++ b/arch/m68k/include/asm/div64.h | |||
| @@ -15,16 +15,17 @@ | |||
| 15 | unsigned long long n64; \ | 15 | unsigned long long n64; \ |
| 16 | } __n; \ | 16 | } __n; \ |
| 17 | unsigned long __rem, __upper; \ | 17 | unsigned long __rem, __upper; \ |
| 18 | unsigned long __base = (base); \ | ||
| 18 | \ | 19 | \ |
| 19 | __n.n64 = (n); \ | 20 | __n.n64 = (n); \ |
| 20 | if ((__upper = __n.n32[0])) { \ | 21 | if ((__upper = __n.n32[0])) { \ |
| 21 | asm ("divul.l %2,%1:%0" \ | 22 | asm ("divul.l %2,%1:%0" \ |
| 22 | : "=d" (__n.n32[0]), "=d" (__upper) \ | 23 | : "=d" (__n.n32[0]), "=d" (__upper) \ |
| 23 | : "d" (base), "0" (__n.n32[0])); \ | 24 | : "d" (__base), "0" (__n.n32[0])); \ |
| 24 | } \ | 25 | } \ |
| 25 | asm ("divu.l %2,%1:%0" \ | 26 | asm ("divu.l %2,%1:%0" \ |
| 26 | : "=d" (__n.n32[1]), "=d" (__rem) \ | 27 | : "=d" (__n.n32[1]), "=d" (__rem) \ |
| 27 | : "d" (base), "1" (__upper), "0" (__n.n32[1])); \ | 28 | : "d" (__base), "1" (__upper), "0" (__n.n32[1])); \ |
| 28 | (n) = __n.n64; \ | 29 | (n) = __n.n64; \ |
| 29 | __rem; \ | 30 | __rem; \ |
| 30 | }) | 31 | }) |
