diff options
author | Rusty Russell <rusty@rustcorp.com.au> | 2008-12-29 16:32:35 -0500 |
---|---|---|
committer | Rusty Russell <rusty@rustcorp.com.au> | 2008-12-29 16:32:35 -0500 |
commit | 33edcf133ba93ecba2e4b6472e97b689895d805c (patch) | |
tree | 327d7a20acef64005e7c5ccbfa1265be28aeb6ac /arch/sh/kernel/sh_bios.c | |
parent | be4d638c1597580ed2294d899d9f1a2cd10e462c (diff) | |
parent | 3c92ec8ae91ecf59d88c798301833d7cf83f2179 (diff) |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
Diffstat (limited to 'arch/sh/kernel/sh_bios.c')
-rw-r--r-- | arch/sh/kernel/sh_bios.c | 65 |
1 files changed, 23 insertions, 42 deletions
diff --git a/arch/sh/kernel/sh_bios.c b/arch/sh/kernel/sh_bios.c index d1bcac4fa269..c852f7805728 100644 --- a/arch/sh/kernel/sh_bios.c +++ b/arch/sh/kernel/sh_bios.c | |||
@@ -8,69 +8,50 @@ | |||
8 | #include <linux/module.h> | 8 | #include <linux/module.h> |
9 | #include <asm/sh_bios.h> | 9 | #include <asm/sh_bios.h> |
10 | 10 | ||
11 | #define BIOS_CALL_CONSOLE_WRITE 0 | 11 | #define BIOS_CALL_CONSOLE_WRITE 0 |
12 | #define BIOS_CALL_READ_BLOCK 1 | ||
13 | #define BIOS_CALL_ETH_NODE_ADDR 10 | 12 | #define BIOS_CALL_ETH_NODE_ADDR 10 |
14 | #define BIOS_CALL_SHUTDOWN 11 | 13 | #define BIOS_CALL_SHUTDOWN 11 |
15 | #define BIOS_CALL_CHAR_OUT 0x1f /* TODO: hack */ | 14 | #define BIOS_CALL_CHAR_OUT 0x1f /* TODO: hack */ |
16 | #define BIOS_CALL_GDB_GET_MODE_PTR 0xfe | 15 | #define BIOS_CALL_GDB_DETACH 0xff |
17 | #define BIOS_CALL_GDB_DETACH 0xff | ||
18 | 16 | ||
19 | static __inline__ long sh_bios_call(long func, long arg0, long arg1, long arg2, long arg3) | 17 | static inline long sh_bios_call(long func, long arg0, long arg1, long arg2, |
18 | long arg3) | ||
20 | { | 19 | { |
21 | register long r0 __asm__("r0") = func; | 20 | register long r0 __asm__("r0") = func; |
22 | register long r4 __asm__("r4") = arg0; | 21 | register long r4 __asm__("r4") = arg0; |
23 | register long r5 __asm__("r5") = arg1; | 22 | register long r5 __asm__("r5") = arg1; |
24 | register long r6 __asm__("r6") = arg2; | 23 | register long r6 __asm__("r6") = arg2; |
25 | register long r7 __asm__("r7") = arg3; | 24 | register long r7 __asm__("r7") = arg3; |
26 | __asm__ __volatile__("trapa #0x3f" | 25 | |
27 | : "=z" (r0) | 26 | __asm__ __volatile__("trapa #0x3f":"=z"(r0) |
28 | : "0" (r0), "r" (r4), "r" (r5), "r" (r6), "r" (r7) | 27 | :"0"(r0), "r"(r4), "r"(r5), "r"(r6), "r"(r7) |
29 | : "memory"); | 28 | :"memory"); |
30 | return r0; | 29 | return r0; |
31 | } | 30 | } |
32 | 31 | ||
33 | |||
34 | void sh_bios_console_write(const char *buf, unsigned int len) | 32 | void sh_bios_console_write(const char *buf, unsigned int len) |
35 | { | 33 | { |
36 | sh_bios_call(BIOS_CALL_CONSOLE_WRITE, (long)buf, (long)len, 0, 0); | 34 | sh_bios_call(BIOS_CALL_CONSOLE_WRITE, (long)buf, (long)len, 0, 0); |
37 | } | 35 | } |
38 | 36 | ||
39 | |||
40 | void sh_bios_char_out(char ch) | 37 | void sh_bios_char_out(char ch) |
41 | { | 38 | { |
42 | sh_bios_call(BIOS_CALL_CHAR_OUT, ch, 0, 0, 0); | 39 | sh_bios_call(BIOS_CALL_CHAR_OUT, ch, 0, 0, 0); |
43 | } | ||
44 | |||
45 | |||
46 | int sh_bios_in_gdb_mode(void) | ||
47 | { | ||
48 | static char queried = 0; | ||
49 | static char *gdb_mode_p = 0; | ||
50 | |||
51 | if (!queried) | ||
52 | { | ||
53 | /* Query the gdb stub for address of its gdb mode variable */ | ||
54 | long r = sh_bios_call(BIOS_CALL_GDB_GET_MODE_PTR, 0, 0, 0, 0); | ||
55 | if (r != ~0) /* BIOS returns -1 for unknown function */ | ||
56 | gdb_mode_p = (char *)r; | ||
57 | queried = 1; | ||
58 | } | ||
59 | return (gdb_mode_p != 0 ? *gdb_mode_p : 0); | ||
60 | } | 40 | } |
61 | 41 | ||
62 | void sh_bios_gdb_detach(void) | 42 | void sh_bios_gdb_detach(void) |
63 | { | 43 | { |
64 | sh_bios_call(BIOS_CALL_GDB_DETACH, 0, 0, 0, 0); | 44 | sh_bios_call(BIOS_CALL_GDB_DETACH, 0, 0, 0, 0); |
65 | } | 45 | } |
66 | EXPORT_SYMBOL(sh_bios_gdb_detach); | 46 | EXPORT_SYMBOL_GPL(sh_bios_gdb_detach); |
67 | 47 | ||
68 | void sh_bios_get_node_addr (unsigned char *node_addr) | 48 | void sh_bios_get_node_addr(unsigned char *node_addr) |
69 | { | 49 | { |
70 | sh_bios_call(BIOS_CALL_ETH_NODE_ADDR, 0, (long)node_addr, 0, 0); | 50 | sh_bios_call(BIOS_CALL_ETH_NODE_ADDR, 0, (long)node_addr, 0, 0); |
71 | } | 51 | } |
52 | EXPORT_SYMBOL_GPL(sh_bios_get_node_addr); | ||
72 | 53 | ||
73 | void sh_bios_shutdown(unsigned int how) | 54 | void sh_bios_shutdown(unsigned int how) |
74 | { | 55 | { |
75 | sh_bios_call(BIOS_CALL_SHUTDOWN, how, 0, 0, 0); | 56 | sh_bios_call(BIOS_CALL_SHUTDOWN, how, 0, 0, 0); |
76 | } | 57 | } |