diff options
Diffstat (limited to 'arch/xtensa/platforms/iss')
-rw-r--r-- | arch/xtensa/platforms/iss/Makefile | 4 | ||||
-rw-r--r-- | arch/xtensa/platforms/iss/console.c | 15 | ||||
-rw-r--r-- | arch/xtensa/platforms/iss/include/platform/serial.h | 0 | ||||
-rw-r--r-- | arch/xtensa/platforms/iss/include/platform/simcall.h | 53 | ||||
-rw-r--r-- | arch/xtensa/platforms/iss/io.c | 32 | ||||
-rw-r--r-- | arch/xtensa/platforms/iss/network.c | 49 | ||||
-rw-r--r-- | arch/xtensa/platforms/iss/setup.c | 14 |
7 files changed, 66 insertions, 101 deletions
diff --git a/arch/xtensa/platforms/iss/Makefile b/arch/xtensa/platforms/iss/Makefile index af96e314d71..b7d1a5c0ff7 100644 --- a/arch/xtensa/platforms/iss/Makefile +++ b/arch/xtensa/platforms/iss/Makefile | |||
@@ -4,5 +4,5 @@ | |||
4 | # "prom monitor" library routines under Linux. | 4 | # "prom monitor" library routines under Linux. |
5 | # | 5 | # |
6 | 6 | ||
7 | obj-y = io.o console.o setup.o network.o | 7 | obj-y = console.o setup.o |
8 | 8 | obj-$(CONFIG_NET) += network.o | |
diff --git a/arch/xtensa/platforms/iss/console.c b/arch/xtensa/platforms/iss/console.c index 2cd3d3a3400..8ab47edd7c8 100644 --- a/arch/xtensa/platforms/iss/console.c +++ b/arch/xtensa/platforms/iss/console.c | |||
@@ -33,7 +33,7 @@ | |||
33 | #endif | 33 | #endif |
34 | 34 | ||
35 | #define SERIAL_MAX_NUM_LINES 1 | 35 | #define SERIAL_MAX_NUM_LINES 1 |
36 | #define SERIAL_TIMER_VALUE (20 * HZ) | 36 | #define SERIAL_TIMER_VALUE (HZ / 10) |
37 | 37 | ||
38 | static struct tty_driver *serial_driver; | 38 | static struct tty_driver *serial_driver; |
39 | static struct tty_port serial_port; | 39 | static struct tty_port serial_port; |
@@ -41,19 +41,6 @@ static struct timer_list serial_timer; | |||
41 | 41 | ||
42 | static DEFINE_SPINLOCK(timer_lock); | 42 | static DEFINE_SPINLOCK(timer_lock); |
43 | 43 | ||
44 | int errno; | ||
45 | |||
46 | static int __simc (int a, int b, int c, int d, int e, int f) __attribute__((__noinline__)); | ||
47 | static int __simc (int a, int b, int c, int d, int e, int f) | ||
48 | { | ||
49 | int ret; | ||
50 | __asm__ __volatile__ ("simcall\n" | ||
51 | "mov %0, a2\n" | ||
52 | "mov %1, a3\n" : "=a" (ret), "=a" (errno) | ||
53 | : : "a2", "a3"); | ||
54 | return ret; | ||
55 | } | ||
56 | |||
57 | static char *serial_version = "0.1"; | 44 | static char *serial_version = "0.1"; |
58 | static char *serial_name = "ISS serial driver"; | 45 | static char *serial_name = "ISS serial driver"; |
59 | 46 | ||
diff --git a/arch/xtensa/platforms/iss/include/platform/serial.h b/arch/xtensa/platforms/iss/include/platform/serial.h new file mode 100644 index 00000000000..e69de29bb2d --- /dev/null +++ b/arch/xtensa/platforms/iss/include/platform/serial.h | |||
diff --git a/arch/xtensa/platforms/iss/include/platform/simcall.h b/arch/xtensa/platforms/iss/include/platform/simcall.h index b7952c06a2b..8c43bfea05e 100644 --- a/arch/xtensa/platforms/iss/include/platform/simcall.h +++ b/arch/xtensa/platforms/iss/include/platform/simcall.h | |||
@@ -57,6 +57,59 @@ | |||
57 | #define XTISS_SELECT_ONE_WRITE 2 | 57 | #define XTISS_SELECT_ONE_WRITE 2 |
58 | #define XTISS_SELECT_ONE_EXCEPT 3 | 58 | #define XTISS_SELECT_ONE_EXCEPT 3 |
59 | 59 | ||
60 | static int errno; | ||
61 | |||
62 | static inline int __simc(int a, int b, int c, int d, int e, int f) | ||
63 | { | ||
64 | int ret; | ||
65 | register int a1 asm("a2") = a; | ||
66 | register int b1 asm("a3") = b; | ||
67 | register int c1 asm("a4") = c; | ||
68 | register int d1 asm("a5") = d; | ||
69 | register int e1 asm("a6") = e; | ||
70 | register int f1 asm("a7") = f; | ||
71 | __asm__ __volatile__ ( | ||
72 | "simcall\n" | ||
73 | "mov %0, a2\n" | ||
74 | "mov %1, a3\n" | ||
75 | : "=a" (ret), "=a" (errno), "+r"(a1), "+r"(b1) | ||
76 | : "r"(c1), "r"(d1), "r"(e1), "r"(f1) | ||
77 | : ); | ||
78 | return ret; | ||
79 | } | ||
80 | |||
81 | static inline int simc_open(char *file, int flags, int mode) | ||
82 | { | ||
83 | return __simc(SYS_open, (int) file, flags, mode, 0, 0); | ||
84 | } | ||
85 | |||
86 | static inline int simc_close(int fd) | ||
87 | { | ||
88 | return __simc(SYS_close, fd, 0, 0, 0, 0); | ||
89 | } | ||
90 | |||
91 | static inline int simc_ioctl(int fd, int request, void *arg) | ||
92 | { | ||
93 | return __simc(SYS_ioctl, fd, request, (int) arg, 0, 0); | ||
94 | } | ||
95 | |||
96 | static inline int simc_read(int fd, void *buf, size_t count) | ||
97 | { | ||
98 | return __simc(SYS_read, fd, (int) buf, count, 0, 0); | ||
99 | } | ||
100 | |||
101 | static inline int simc_write(int fd, void *buf, size_t count) | ||
102 | { | ||
103 | return __simc(SYS_write, fd, (int) buf, count, 0, 0); | ||
104 | } | ||
105 | |||
106 | static inline int simc_poll(int fd) | ||
107 | { | ||
108 | struct timeval tv = { .tv_sec = 0, .tv_usec = 0 }; | ||
109 | |||
110 | return __simc(SYS_select_one, fd, XTISS_SELECT_ONE_READ, (int)&tv, | ||
111 | 0, 0); | ||
112 | } | ||
60 | 113 | ||
61 | #endif /* _XTENSA_PLATFORM_ISS_SIMCALL_H */ | 114 | #endif /* _XTENSA_PLATFORM_ISS_SIMCALL_H */ |
62 | 115 | ||
diff --git a/arch/xtensa/platforms/iss/io.c b/arch/xtensa/platforms/iss/io.c deleted file mode 100644 index 571d0b24f89..00000000000 --- a/arch/xtensa/platforms/iss/io.c +++ /dev/null | |||
@@ -1,32 +0,0 @@ | |||
1 | /* This file isn't really needed right now. */ | ||
2 | |||
3 | #if 0 | ||
4 | |||
5 | #include <asm/io.h> | ||
6 | #include <platform/platform-iss/simcall.h> | ||
7 | |||
8 | extern int __simc (); | ||
9 | |||
10 | |||
11 | char iss_serial_getc() | ||
12 | { | ||
13 | char c; | ||
14 | __simc( SYS_read, 0, &c, 1 ); | ||
15 | return c; | ||
16 | } | ||
17 | |||
18 | void iss_serial_putc( char c ) | ||
19 | { | ||
20 | __simc( SYS_write, 1, &c, 1 ); | ||
21 | } | ||
22 | |||
23 | void iss_serial_puts( char *s ) | ||
24 | { | ||
25 | if( s != 0 && *s != 0 ) | ||
26 | __simc( SYS_write, 1, s, strlen(s) ); | ||
27 | } | ||
28 | |||
29 | /*#error Need I/O ports to specific hardware!*/ | ||
30 | |||
31 | #endif | ||
32 | |||
diff --git a/arch/xtensa/platforms/iss/network.c b/arch/xtensa/platforms/iss/network.c index 7dde2445642..7d0fea6d7f2 100644 --- a/arch/xtensa/platforms/iss/network.c +++ b/arch/xtensa/platforms/iss/network.c | |||
@@ -101,55 +101,6 @@ struct iss_net_private { | |||
101 | 101 | ||
102 | }; | 102 | }; |
103 | 103 | ||
104 | /* ======================= ISS SIMCALL INTERFACE =========================== */ | ||
105 | |||
106 | /* Note: __simc must _not_ be declared inline! */ | ||
107 | |||
108 | static int errno; | ||
109 | |||
110 | static int __simc (int a, int b, int c, int d, int e, int f) __attribute__((__noinline__)); | ||
111 | static int __simc (int a, int b, int c, int d, int e, int f) | ||
112 | { | ||
113 | int ret; | ||
114 | __asm__ __volatile__ ("simcall\n" | ||
115 | "mov %0, a2\n" | ||
116 | "mov %1, a3\n" : "=a" (ret), "=a" (errno) | ||
117 | : : "a2", "a3"); | ||
118 | return ret; | ||
119 | } | ||
120 | |||
121 | static int inline simc_open(char *file, int flags, int mode) | ||
122 | { | ||
123 | return __simc(SYS_open, (int) file, flags, mode, 0, 0); | ||
124 | } | ||
125 | |||
126 | static int inline simc_close(int fd) | ||
127 | { | ||
128 | return __simc(SYS_close, fd, 0, 0, 0, 0); | ||
129 | } | ||
130 | |||
131 | static int inline simc_ioctl(int fd, int request, void *arg) | ||
132 | { | ||
133 | return __simc(SYS_ioctl, fd, request, (int) arg, 0, 0); | ||
134 | } | ||
135 | |||
136 | static int inline simc_read(int fd, void *buf, size_t count) | ||
137 | { | ||
138 | return __simc(SYS_read, fd, (int) buf, count, 0, 0); | ||
139 | } | ||
140 | |||
141 | static int inline simc_write(int fd, void *buf, size_t count) | ||
142 | { | ||
143 | return __simc(SYS_write, fd, (int) buf, count, 0, 0); | ||
144 | } | ||
145 | |||
146 | static int inline simc_poll(int fd) | ||
147 | { | ||
148 | struct timeval tv = { .tv_sec = 0, .tv_usec = 0 }; | ||
149 | |||
150 | return __simc(SYS_select_one, fd, XTISS_SELECT_ONE_READ, (int)&tv,0,0); | ||
151 | } | ||
152 | |||
153 | /* ================================ HELPERS ================================ */ | 104 | /* ================================ HELPERS ================================ */ |
154 | 105 | ||
155 | 106 | ||
diff --git a/arch/xtensa/platforms/iss/setup.c b/arch/xtensa/platforms/iss/setup.c index f60c8cf6dfb..927acf378ea 100644 --- a/arch/xtensa/platforms/iss/setup.c +++ b/arch/xtensa/platforms/iss/setup.c | |||
@@ -38,16 +38,22 @@ void __init platform_init(bp_tag_t* bootparam) | |||
38 | 38 | ||
39 | } | 39 | } |
40 | 40 | ||
41 | #ifdef CONFIG_PCI | ||
42 | void platform_pcibios_init(void) | ||
43 | { | ||
44 | } | ||
45 | #endif | ||
46 | |||
41 | void platform_halt(void) | 47 | void platform_halt(void) |
42 | { | 48 | { |
43 | printk (" ** Called platform_halt(), looping forever! **\n"); | 49 | pr_info(" ** Called platform_halt() **\n"); |
44 | while (1); | 50 | __asm__ __volatile__("movi a2, 1\nsimcall\n"); |
45 | } | 51 | } |
46 | 52 | ||
47 | void platform_power_off(void) | 53 | void platform_power_off(void) |
48 | { | 54 | { |
49 | printk (" ** Called platform_power_off(), looping forever! **\n"); | 55 | pr_info(" ** Called platform_power_off() **\n"); |
50 | while (1); | 56 | __asm__ __volatile__("movi a2, 1\nsimcall\n"); |
51 | } | 57 | } |
52 | void platform_restart(void) | 58 | void platform_restart(void) |
53 | { | 59 | { |