diff options
Diffstat (limited to 'arch/mips')
-rw-r--r-- | arch/mips/pci/fixup-rbtx4927.c | 1 | ||||
-rw-r--r-- | arch/mips/pci/ops-tx4927.c | 5 | ||||
-rw-r--r-- | arch/mips/tx4927/common/tx4927_dbgio.c | 5 | ||||
-rw-r--r-- | arch/mips/tx4927/common/tx4927_prom.c | 8 | ||||
-rw-r--r-- | arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_irq.c | 234 | ||||
-rw-r--r-- | arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_prom.c | 7 | ||||
-rw-r--r-- | arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c | 322 |
7 files changed, 29 insertions, 553 deletions
diff --git a/arch/mips/pci/fixup-rbtx4927.c b/arch/mips/pci/fixup-rbtx4927.c index 7450c335b38..2d234ca017d 100644 --- a/arch/mips/pci/fixup-rbtx4927.c +++ b/arch/mips/pci/fixup-rbtx4927.c | |||
@@ -38,7 +38,6 @@ | |||
38 | #include <linux/init.h> | 38 | #include <linux/init.h> |
39 | 39 | ||
40 | #include <asm/tx4927/tx4927.h> | 40 | #include <asm/tx4927/tx4927.h> |
41 | #include <asm/tx4927/tx4927_pci.h> | ||
42 | 41 | ||
43 | #undef DEBUG | 42 | #undef DEBUG |
44 | #ifdef DEBUG | 43 | #ifdef DEBUG |
diff --git a/arch/mips/pci/ops-tx4927.c b/arch/mips/pci/ops-tx4927.c index 150419c8b41..1bbafeb4a77 100644 --- a/arch/mips/pci/ops-tx4927.c +++ b/arch/mips/pci/ops-tx4927.c | |||
@@ -40,10 +40,7 @@ | |||
40 | #include <linux/pci.h> | 40 | #include <linux/pci.h> |
41 | #include <linux/kernel.h> | 41 | #include <linux/kernel.h> |
42 | #include <linux/init.h> | 42 | #include <linux/init.h> |
43 | 43 | #include <asm/tx4927/tx4927.h> | |
44 | #include <asm/addrspace.h> | ||
45 | #include <asm/byteorder.h> | ||
46 | #include <asm/tx4927/tx4927_pci.h> | ||
47 | 44 | ||
48 | /* initialize in setup */ | 45 | /* initialize in setup */ |
49 | struct resource pci_io_resource = { | 46 | struct resource pci_io_resource = { |
diff --git a/arch/mips/tx4927/common/tx4927_dbgio.c b/arch/mips/tx4927/common/tx4927_dbgio.c index d8423e001b2..ea1ff23f4b7 100644 --- a/arch/mips/tx4927/common/tx4927_dbgio.c +++ b/arch/mips/tx4927/common/tx4927_dbgio.c | |||
@@ -28,9 +28,7 @@ | |||
28 | * with this program; if not, write to the Free Software Foundation, Inc., | 28 | * with this program; if not, write to the Free Software Foundation, Inc., |
29 | * 675 Mass Ave, Cambridge, MA 02139, USA. | 29 | * 675 Mass Ave, Cambridge, MA 02139, USA. |
30 | */ | 30 | */ |
31 | 31 | #include <linux/types.h> | |
32 | #include <asm/mipsregs.h> | ||
33 | #include <asm/system.h> | ||
34 | 32 | ||
35 | u8 getDebugChar(void) | 33 | u8 getDebugChar(void) |
36 | { | 34 | { |
@@ -38,7 +36,6 @@ u8 getDebugChar(void) | |||
38 | return (txx9_sio_kdbg_rd()); | 36 | return (txx9_sio_kdbg_rd()); |
39 | } | 37 | } |
40 | 38 | ||
41 | |||
42 | int putDebugChar(u8 byte) | 39 | int putDebugChar(u8 byte) |
43 | { | 40 | { |
44 | extern int txx9_sio_kdbg_wr( u8 ch ); | 41 | extern int txx9_sio_kdbg_wr( u8 ch ); |
diff --git a/arch/mips/tx4927/common/tx4927_prom.c b/arch/mips/tx4927/common/tx4927_prom.c index 6eed53d8f38..cc2aa9d63e8 100644 --- a/arch/mips/tx4927/common/tx4927_prom.c +++ b/arch/mips/tx4927/common/tx4927_prom.c | |||
@@ -30,12 +30,8 @@ | |||
30 | */ | 30 | */ |
31 | 31 | ||
32 | #include <linux/init.h> | 32 | #include <linux/init.h> |
33 | #include <linux/mm.h> | 33 | #include <linux/types.h> |
34 | #include <linux/sched.h> | 34 | #include <linux/io.h> |
35 | #include <linux/bootmem.h> | ||
36 | |||
37 | #include <asm/addrspace.h> | ||
38 | #include <asm/bootinfo.h> | ||
39 | #include <asm/tx4927/tx4927.h> | 35 | #include <asm/tx4927/tx4927.h> |
40 | 36 | ||
41 | static unsigned int __init tx4927_process_sdccr(unsigned long addr) | 37 | static unsigned int __init tx4927_process_sdccr(unsigned long addr) |
diff --git a/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_irq.c b/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_irq.c index 6d31f2a98ab..c18901a75cc 100644 --- a/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_irq.c +++ b/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_irq.c | |||
@@ -28,8 +28,6 @@ | |||
28 | * with this program; if not, write to the Free Software Foundation, Inc., | 28 | * with this program; if not, write to the Free Software Foundation, Inc., |
29 | * 675 Mass Ave, Cambridge, MA 02139, USA. | 29 | * 675 Mass Ave, Cambridge, MA 02139, USA. |
30 | */ | 30 | */ |
31 | |||
32 | |||
33 | /* | 31 | /* |
34 | IRQ Device | 32 | IRQ Device |
35 | 00 RBTX4927-ISA/00 | 33 | 00 RBTX4927-ISA/00 |
@@ -112,76 +110,14 @@ JP7 is not bus master -- do NOT use -- only 4 pci bus master's allowed -- SouthB | |||
112 | */ | 110 | */ |
113 | 111 | ||
114 | #include <linux/init.h> | 112 | #include <linux/init.h> |
115 | #include <linux/kernel.h> | ||
116 | #include <linux/types.h> | 113 | #include <linux/types.h> |
117 | #include <linux/mm.h> | ||
118 | #include <linux/swap.h> | ||
119 | #include <linux/ioport.h> | ||
120 | #include <linux/sched.h> | ||
121 | #include <linux/interrupt.h> | 114 | #include <linux/interrupt.h> |
122 | #include <linux/pci.h> | ||
123 | #include <linux/timex.h> | ||
124 | #include <asm/bootinfo.h> | ||
125 | #include <asm/page.h> | ||
126 | #include <asm/io.h> | 115 | #include <asm/io.h> |
127 | #include <asm/irq.h> | ||
128 | #include <asm/pci.h> | ||
129 | #include <asm/processor.h> | ||
130 | #include <asm/reboot.h> | ||
131 | #include <asm/time.h> | ||
132 | #include <asm/wbflush.h> | ||
133 | #include <linux/bootmem.h> | ||
134 | #include <linux/blkdev.h> | ||
135 | #ifdef CONFIG_TOSHIBA_FPCIB0 | 116 | #ifdef CONFIG_TOSHIBA_FPCIB0 |
136 | #include <asm/i8259.h> | 117 | #include <asm/i8259.h> |
137 | #include <asm/tx4927/smsc_fdc37m81x.h> | ||
138 | #endif | 118 | #endif |
139 | #include <asm/tx4927/toshiba_rbtx4927.h> | 119 | #include <asm/tx4927/toshiba_rbtx4927.h> |
140 | 120 | ||
141 | |||
142 | #undef TOSHIBA_RBTX4927_IRQ_DEBUG | ||
143 | |||
144 | #ifdef TOSHIBA_RBTX4927_IRQ_DEBUG | ||
145 | #define TOSHIBA_RBTX4927_IRQ_NONE 0x00000000 | ||
146 | |||
147 | #define TOSHIBA_RBTX4927_IRQ_INFO ( 1 << 0 ) | ||
148 | #define TOSHIBA_RBTX4927_IRQ_WARN ( 1 << 1 ) | ||
149 | #define TOSHIBA_RBTX4927_IRQ_EROR ( 1 << 2 ) | ||
150 | |||
151 | #define TOSHIBA_RBTX4927_IRQ_IOC_INIT ( 1 << 10 ) | ||
152 | #define TOSHIBA_RBTX4927_IRQ_IOC_ENABLE ( 1 << 13 ) | ||
153 | #define TOSHIBA_RBTX4927_IRQ_IOC_DISABLE ( 1 << 14 ) | ||
154 | |||
155 | #define TOSHIBA_RBTX4927_SETUP_ALL 0xffffffff | ||
156 | #endif | ||
157 | |||
158 | |||
159 | #ifdef TOSHIBA_RBTX4927_IRQ_DEBUG | ||
160 | static const u32 toshiba_rbtx4927_irq_debug_flag = | ||
161 | (TOSHIBA_RBTX4927_IRQ_NONE | TOSHIBA_RBTX4927_IRQ_INFO | | ||
162 | TOSHIBA_RBTX4927_IRQ_WARN | TOSHIBA_RBTX4927_IRQ_EROR | ||
163 | // | TOSHIBA_RBTX4927_IRQ_IOC_INIT | ||
164 | // | TOSHIBA_RBTX4927_IRQ_IOC_ENABLE | ||
165 | // | TOSHIBA_RBTX4927_IRQ_IOC_DISABLE | ||
166 | ); | ||
167 | #endif | ||
168 | |||
169 | |||
170 | #ifdef TOSHIBA_RBTX4927_IRQ_DEBUG | ||
171 | #define TOSHIBA_RBTX4927_IRQ_DPRINTK(flag,str...) \ | ||
172 | if ( (toshiba_rbtx4927_irq_debug_flag) & (flag) ) \ | ||
173 | { \ | ||
174 | char tmp[100]; \ | ||
175 | sprintf( tmp, str ); \ | ||
176 | printk( "%s(%s:%u)::%s", __func__, __FILE__, __LINE__, tmp ); \ | ||
177 | } | ||
178 | #else | ||
179 | #define TOSHIBA_RBTX4927_IRQ_DPRINTK(flag, str...) | ||
180 | #endif | ||
181 | |||
182 | |||
183 | |||
184 | |||
185 | #define TOSHIBA_RBTX4927_IRQ_IOC_RAW_BEG 0 | 121 | #define TOSHIBA_RBTX4927_IRQ_IOC_RAW_BEG 0 |
186 | #define TOSHIBA_RBTX4927_IRQ_IOC_RAW_END 7 | 122 | #define TOSHIBA_RBTX4927_IRQ_IOC_RAW_END 7 |
187 | 123 | ||
@@ -207,39 +143,22 @@ static struct irq_chip toshiba_rbtx4927_irq_ioc_type = { | |||
207 | #define TOSHIBA_RBTX4927_IOC_INTR_ENAB (void __iomem *)0xbc002000UL | 143 | #define TOSHIBA_RBTX4927_IOC_INTR_ENAB (void __iomem *)0xbc002000UL |
208 | #define TOSHIBA_RBTX4927_IOC_INTR_STAT (void __iomem *)0xbc002006UL | 144 | #define TOSHIBA_RBTX4927_IOC_INTR_STAT (void __iomem *)0xbc002006UL |
209 | 145 | ||
210 | |||
211 | u32 bit2num(u32 num) | ||
212 | { | ||
213 | u32 i; | ||
214 | |||
215 | for (i = 0; i < (sizeof(num) * 8); i++) { | ||
216 | if (num & (1 << i)) { | ||
217 | return (i); | ||
218 | } | ||
219 | } | ||
220 | return (0); | ||
221 | } | ||
222 | |||
223 | int toshiba_rbtx4927_irq_nested(int sw_irq) | 146 | int toshiba_rbtx4927_irq_nested(int sw_irq) |
224 | { | 147 | { |
225 | u32 level3; | 148 | u8 level3; |
226 | 149 | ||
227 | level3 = readb(TOSHIBA_RBTX4927_IOC_INTR_STAT) & 0x1f; | 150 | level3 = readb(TOSHIBA_RBTX4927_IOC_INTR_STAT) & 0x1f; |
228 | if (level3) { | 151 | if (level3) { |
229 | sw_irq = TOSHIBA_RBTX4927_IRQ_IOC_BEG + bit2num(level3); | 152 | sw_irq = TOSHIBA_RBTX4927_IRQ_IOC_BEG + fls(level3) - 1; |
230 | if (sw_irq != TOSHIBA_RBTX4927_IRQ_NEST_ISA_ON_IOC) { | ||
231 | goto RETURN; | ||
232 | } | ||
233 | } | ||
234 | #ifdef CONFIG_TOSHIBA_FPCIB0 | 153 | #ifdef CONFIG_TOSHIBA_FPCIB0 |
235 | if (tx4927_using_backplane) { | 154 | if (sw_irq == TOSHIBA_RBTX4927_IRQ_NEST_ISA_ON_IOC && |
236 | int irq = i8259_irq(); | 155 | tx4927_using_backplane) { |
237 | if (irq >= 0) | 156 | int irq = i8259_irq(); |
238 | sw_irq = irq; | 157 | if (irq >= 0) |
239 | } | 158 | sw_irq = irq; |
159 | } | ||
240 | #endif | 160 | #endif |
241 | 161 | } | |
242 | RETURN: | ||
243 | return (sw_irq); | 162 | return (sw_irq); |
244 | } | 163 | } |
245 | 164 | ||
@@ -250,21 +169,10 @@ static struct irqaction toshiba_rbtx4927_irq_ioc_action = { | |||
250 | .name = TOSHIBA_RBTX4927_IOC_NAME | 169 | .name = TOSHIBA_RBTX4927_IOC_NAME |
251 | }; | 170 | }; |
252 | 171 | ||
253 | |||
254 | /**********************************************************************************/ | ||
255 | /* Functions for ioc */ | ||
256 | /**********************************************************************************/ | ||
257 | |||
258 | |||
259 | static void __init toshiba_rbtx4927_irq_ioc_init(void) | 172 | static void __init toshiba_rbtx4927_irq_ioc_init(void) |
260 | { | 173 | { |
261 | int i; | 174 | int i; |
262 | 175 | ||
263 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_IOC_INIT, | ||
264 | "beg=%d end=%d\n", | ||
265 | TOSHIBA_RBTX4927_IRQ_IOC_BEG, | ||
266 | TOSHIBA_RBTX4927_IRQ_IOC_END); | ||
267 | |||
268 | for (i = TOSHIBA_RBTX4927_IRQ_IOC_BEG; | 176 | for (i = TOSHIBA_RBTX4927_IRQ_IOC_BEG; |
269 | i <= TOSHIBA_RBTX4927_IRQ_IOC_END; i++) | 177 | i <= TOSHIBA_RBTX4927_IRQ_IOC_END; i++) |
270 | set_irq_chip_and_handler(i, &toshiba_rbtx4927_irq_ioc_type, | 178 | set_irq_chip_and_handler(i, &toshiba_rbtx4927_irq_ioc_type, |
@@ -276,37 +184,16 @@ static void __init toshiba_rbtx4927_irq_ioc_init(void) | |||
276 | 184 | ||
277 | static void toshiba_rbtx4927_irq_ioc_enable(unsigned int irq) | 185 | static void toshiba_rbtx4927_irq_ioc_enable(unsigned int irq) |
278 | { | 186 | { |
279 | volatile unsigned char v; | 187 | unsigned char v; |
280 | |||
281 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_IOC_ENABLE, | ||
282 | "irq=%d\n", irq); | ||
283 | |||
284 | if (irq < TOSHIBA_RBTX4927_IRQ_IOC_BEG | ||
285 | || irq > TOSHIBA_RBTX4927_IRQ_IOC_END) { | ||
286 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_EROR, | ||
287 | "bad irq=%d\n", irq); | ||
288 | panic("\n"); | ||
289 | } | ||
290 | 188 | ||
291 | v = readb(TOSHIBA_RBTX4927_IOC_INTR_ENAB); | 189 | v = readb(TOSHIBA_RBTX4927_IOC_INTR_ENAB); |
292 | v |= (1 << (irq - TOSHIBA_RBTX4927_IRQ_IOC_BEG)); | 190 | v |= (1 << (irq - TOSHIBA_RBTX4927_IRQ_IOC_BEG)); |
293 | writeb(v, TOSHIBA_RBTX4927_IOC_INTR_ENAB); | 191 | writeb(v, TOSHIBA_RBTX4927_IOC_INTR_ENAB); |
294 | } | 192 | } |
295 | 193 | ||
296 | |||
297 | static void toshiba_rbtx4927_irq_ioc_disable(unsigned int irq) | 194 | static void toshiba_rbtx4927_irq_ioc_disable(unsigned int irq) |
298 | { | 195 | { |
299 | volatile unsigned char v; | 196 | unsigned char v; |
300 | |||
301 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_IOC_DISABLE, | ||
302 | "irq=%d\n", irq); | ||
303 | |||
304 | if (irq < TOSHIBA_RBTX4927_IRQ_IOC_BEG | ||
305 | || irq > TOSHIBA_RBTX4927_IRQ_IOC_END) { | ||
306 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_EROR, | ||
307 | "bad irq=%d\n", irq); | ||
308 | panic("\n"); | ||
309 | } | ||
310 | 197 | ||
311 | v = readb(TOSHIBA_RBTX4927_IOC_INTR_ENAB); | 198 | v = readb(TOSHIBA_RBTX4927_IOC_INTR_ENAB); |
312 | v &= ~(1 << (irq - TOSHIBA_RBTX4927_IRQ_IOC_BEG)); | 199 | v &= ~(1 << (irq - TOSHIBA_RBTX4927_IRQ_IOC_BEG)); |
@@ -314,7 +201,6 @@ static void toshiba_rbtx4927_irq_ioc_disable(unsigned int irq) | |||
314 | mmiowb(); | 201 | mmiowb(); |
315 | } | 202 | } |
316 | 203 | ||
317 | |||
318 | void __init arch_init_irq(void) | 204 | void __init arch_init_irq(void) |
319 | { | 205 | { |
320 | extern void tx4927_irq_init(void); | 206 | extern void tx4927_irq_init(void); |
@@ -327,102 +213,4 @@ void __init arch_init_irq(void) | |||
327 | #endif | 213 | #endif |
328 | /* Onboard 10M Ether: High Active */ | 214 | /* Onboard 10M Ether: High Active */ |
329 | set_irq_type(RBTX4927_RTL_8019_IRQ, IRQF_TRIGGER_HIGH); | 215 | set_irq_type(RBTX4927_RTL_8019_IRQ, IRQF_TRIGGER_HIGH); |
330 | |||
331 | wbflush(); | ||
332 | } | ||
333 | |||
334 | void toshiba_rbtx4927_irq_dump(char *key) | ||
335 | { | ||
336 | #ifdef TOSHIBA_RBTX4927_IRQ_DEBUG | ||
337 | { | ||
338 | u32 i, j = 0; | ||
339 | for (i = 0; i < NR_IRQS; i++) { | ||
340 | if (strcmp(irq_desc[i].chip->name, "none") | ||
341 | == 0) | ||
342 | continue; | ||
343 | |||
344 | if ((i >= 1) | ||
345 | && (irq_desc[i - 1].chip->name == | ||
346 | irq_desc[i].chip->name)) { | ||
347 | j++; | ||
348 | } else { | ||
349 | j = 0; | ||
350 | } | ||
351 | TOSHIBA_RBTX4927_IRQ_DPRINTK | ||
352 | (TOSHIBA_RBTX4927_IRQ_INFO, | ||
353 | "%s irq=0x%02x/%3d s=0x%08x h=0x%08x a=0x%08x ah=0x%08x d=%1d n=%s/%02d\n", | ||
354 | key, i, i, irq_desc[i].status, | ||
355 | (u32) irq_desc[i].chip, | ||
356 | (u32) irq_desc[i].action, | ||
357 | (u32) (irq_desc[i].action ? irq_desc[i]. | ||
358 | action->handler : 0), | ||
359 | irq_desc[i].depth, | ||
360 | irq_desc[i].chip->name, j); | ||
361 | } | ||
362 | } | ||
363 | #endif | ||
364 | } | ||
365 | |||
366 | void toshiba_rbtx4927_irq_dump_pics(char *s) | ||
367 | { | ||
368 | u32 level0_m; | ||
369 | u32 level0_s; | ||
370 | u32 level1_m; | ||
371 | u32 level1_s; | ||
372 | u32 level2; | ||
373 | u32 level2_p; | ||
374 | u32 level2_s; | ||
375 | u32 level3_m; | ||
376 | u32 level3_s; | ||
377 | u32 level4_m; | ||
378 | u32 level4_s; | ||
379 | u32 level5_m; | ||
380 | u32 level5_s; | ||
381 | |||
382 | if (s == NULL) | ||
383 | s = "null"; | ||
384 | |||
385 | level0_m = (read_c0_status() & 0x0000ff00) >> 8; | ||
386 | level0_s = (read_c0_cause() & 0x0000ff00) >> 8; | ||
387 | |||
388 | level1_m = level0_m; | ||
389 | level1_s = level0_s & 0x87; | ||
390 | |||
391 | level2 = __raw_readl((void __iomem *)0xff1ff6a0UL); | ||
392 | level2_p = (((level2 & 0x10000)) ? 0 : 1); | ||
393 | level2_s = (((level2 & 0x1f) == 0x1f) ? 0 : (level2 & 0x1f)); | ||
394 | |||
395 | level3_m = readb(TOSHIBA_RBTX4927_IOC_INTR_ENAB) & 0x1f; | ||
396 | level3_s = readb(TOSHIBA_RBTX4927_IOC_INTR_STAT) & 0x1f; | ||
397 | |||
398 | level4_m = inb(0x21); | ||
399 | outb(0x0A, 0x20); | ||
400 | level4_s = inb(0x20); | ||
401 | |||
402 | level5_m = inb(0xa1); | ||
403 | outb(0x0A, 0xa0); | ||
404 | level5_s = inb(0xa0); | ||
405 | |||
406 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_INFO, | ||
407 | "dump_raw_pic() "); | ||
408 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_INFO, | ||
409 | "cp0:m=0x%02x/s=0x%02x ", level0_m, | ||
410 | level0_s); | ||
411 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_INFO, | ||
412 | "cp0:m=0x%02x/s=0x%02x ", level1_m, | ||
413 | level1_s); | ||
414 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_INFO, | ||
415 | "pic:e=0x%02x/s=0x%02x ", level2_p, | ||
416 | level2_s); | ||
417 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_INFO, | ||
418 | "ioc:m=0x%02x/s=0x%02x ", level3_m, | ||
419 | level3_s); | ||
420 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_INFO, | ||
421 | "sbm:m=0x%02x/s=0x%02x ", level4_m, | ||
422 | level4_s); | ||
423 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_INFO, | ||
424 | "sbs:m=0x%02x/s=0x%02x ", level5_m, | ||
425 | level5_s); | ||
426 | TOSHIBA_RBTX4927_IRQ_DPRINTK(TOSHIBA_RBTX4927_IRQ_INFO, "[%s]\n", | ||
427 | s); | ||
428 | } | 216 | } |
diff --git a/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_prom.c b/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_prom.c index f3f86857bea..fdbad4bc602 100644 --- a/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_prom.c +++ b/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_prom.c | |||
@@ -30,13 +30,10 @@ | |||
30 | * 675 Mass Ave, Cambridge, MA 02139, USA. | 30 | * 675 Mass Ave, Cambridge, MA 02139, USA. |
31 | */ | 31 | */ |
32 | #include <linux/init.h> | 32 | #include <linux/init.h> |
33 | #include <linux/mm.h> | 33 | #include <linux/string.h> |
34 | #include <linux/sched.h> | ||
35 | #include <linux/bootmem.h> | ||
36 | |||
37 | #include <asm/addrspace.h> | ||
38 | #include <asm/bootinfo.h> | 34 | #include <asm/bootinfo.h> |
39 | #include <asm/cpu.h> | 35 | #include <asm/cpu.h> |
36 | #include <asm/mipsregs.h> | ||
40 | #include <asm/tx4927/tx4927.h> | 37 | #include <asm/tx4927/tx4927.h> |
41 | 38 | ||
42 | void __init prom_init_cmdline(void) | 39 | void __init prom_init_cmdline(void) |
diff --git a/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c b/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c index 2203c77b2ce..185f303c0e2 100644 --- a/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c +++ b/arch/mips/tx4927/toshiba_rbtx4927/toshiba_rbtx4927_setup.c | |||
@@ -62,43 +62,10 @@ | |||
62 | #include <asm/tx4927/smsc_fdc37m81x.h> | 62 | #include <asm/tx4927/smsc_fdc37m81x.h> |
63 | #endif | 63 | #endif |
64 | #include <asm/tx4927/toshiba_rbtx4927.h> | 64 | #include <asm/tx4927/toshiba_rbtx4927.h> |
65 | #ifdef CONFIG_PCI | ||
66 | #include <asm/tx4927/tx4927_pci.h> | ||
67 | #endif | ||
68 | #ifdef CONFIG_SERIAL_TXX9 | 65 | #ifdef CONFIG_SERIAL_TXX9 |
69 | #include <linux/serial_core.h> | 66 | #include <linux/serial_core.h> |
70 | #endif | 67 | #endif |
71 | 68 | ||
72 | #undef TOSHIBA_RBTX4927_SETUP_DEBUG | ||
73 | |||
74 | #ifdef TOSHIBA_RBTX4927_SETUP_DEBUG | ||
75 | #define TOSHIBA_RBTX4927_SETUP_SETUP ( 1 << 4 ) | ||
76 | #define TOSHIBA_RBTX4927_SETUP_PCIBIOS ( 1 << 7 ) | ||
77 | #define TOSHIBA_RBTX4927_SETUP_PCI1 ( 1 << 8 ) | ||
78 | #define TOSHIBA_RBTX4927_SETUP_PCI2 ( 1 << 9 ) | ||
79 | |||
80 | #define TOSHIBA_RBTX4927_SETUP_ALL 0xffffffff | ||
81 | #endif | ||
82 | |||
83 | #ifdef TOSHIBA_RBTX4927_SETUP_DEBUG | ||
84 | static const u32 toshiba_rbtx4927_setup_debug_flag = | ||
85 | (TOSHIBA_RBTX4927_SETUP_SETUP | | ||
86 | | TOSHIBA_RBTX4927_SETUP_PCIBIOS | TOSHIBA_RBTX4927_SETUP_PCI1 | | ||
87 | TOSHIBA_RBTX4927_SETUP_PCI2); | ||
88 | #endif | ||
89 | |||
90 | #ifdef TOSHIBA_RBTX4927_SETUP_DEBUG | ||
91 | #define TOSHIBA_RBTX4927_SETUP_DPRINTK(flag,str...) \ | ||
92 | if ( (toshiba_rbtx4927_setup_debug_flag) & (flag) ) \ | ||
93 | { \ | ||
94 | char tmp[100]; \ | ||
95 | sprintf( tmp, str ); \ | ||
96 | printk( "%s(%s:%u)::%s", __func__, __FILE__, __LINE__, tmp ); \ | ||
97 | } | ||
98 | #else | ||
99 | #define TOSHIBA_RBTX4927_SETUP_DPRINTK(flag, str...) | ||
100 | #endif | ||
101 | |||
102 | /* These functions are used for rebooting or halting the machine*/ | 69 | /* These functions are used for rebooting or halting the machine*/ |
103 | extern void toshiba_rbtx4927_restart(char *command); | 70 | extern void toshiba_rbtx4927_restart(char *command); |
104 | extern void toshiba_rbtx4927_halt(void); | 71 | extern void toshiba_rbtx4927_halt(void); |
@@ -124,7 +91,6 @@ unsigned long mips_memory_upper; | |||
124 | static int tx4927_ccfg_toeon = 1; | 91 | static int tx4927_ccfg_toeon = 1; |
125 | static int tx4927_pcic_trdyto = 0; /* default: disabled */ | 92 | static int tx4927_pcic_trdyto = 0; /* default: disabled */ |
126 | unsigned long tx4927_ce_base[8]; | 93 | unsigned long tx4927_ce_base[8]; |
127 | void tx4927_reset_pci_pcic(void); | ||
128 | int tx4927_pci66 = 0; /* 0:auto */ | 94 | int tx4927_pci66 = 0; /* 0:auto */ |
129 | #endif | 95 | #endif |
130 | 96 | ||
@@ -172,9 +138,6 @@ static int __init tx4927_pcibios_init(void) | |||
172 | int busno = 0; /* One bus on the Toshiba */ | 138 | int busno = 0; /* One bus on the Toshiba */ |
173 | struct pci_controller *hose = &tx4927_controller; | 139 | struct pci_controller *hose = &tx4927_controller; |
174 | 140 | ||
175 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
176 | "-\n"); | ||
177 | |||
178 | for (pci_devfn = devfn_start; pci_devfn < devfn_stop; pci_devfn++) { | 141 | for (pci_devfn = devfn_start; pci_devfn < devfn_stop; pci_devfn++) { |
179 | early_read_config_dword(hose, busno, busno, pci_devfn, | 142 | early_read_config_dword(hose, busno, busno, pci_devfn, |
180 | PCI_VENDOR_ID, &id); | 143 | PCI_VENDOR_ID, &id); |
@@ -187,13 +150,6 @@ static int __init tx4927_pcibios_init(void) | |||
187 | u8 v08_64; | 150 | u8 v08_64; |
188 | u32 v32_b0; | 151 | u32 v32_b0; |
189 | u8 v08_e1; | 152 | u8 v08_e1; |
190 | #ifdef TOSHIBA_RBTX4927_SETUP_DEBUG | ||
191 | char *s = " sb/isa --"; | ||
192 | #endif | ||
193 | |||
194 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
195 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, ":%s beg\n", | ||
196 | s); | ||
197 | 153 | ||
198 | early_read_config_byte(hose, busno, busno, | 154 | early_read_config_byte(hose, busno, busno, |
199 | pci_devfn, 0x64, &v08_64); | 155 | pci_devfn, 0x64, &v08_64); |
@@ -202,16 +158,6 @@ static int __init tx4927_pcibios_init(void) | |||
202 | early_read_config_byte(hose, busno, busno, | 158 | early_read_config_byte(hose, busno, busno, |
203 | pci_devfn, 0xe1, &v08_e1); | 159 | pci_devfn, 0xe1, &v08_e1); |
204 | 160 | ||
205 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
206 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
207 | ":%s beg 0x64 = 0x%02x\n", s, v08_64); | ||
208 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
209 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
210 | ":%s beg 0xb0 = 0x%02x\n", s, v32_b0); | ||
211 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
212 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
213 | ":%s beg 0xe1 = 0x%02x\n", s, v08_e1); | ||
214 | |||
215 | /* serial irq control */ | 161 | /* serial irq control */ |
216 | v08_64 = 0xd0; | 162 | v08_64 = 0xd0; |
217 | 163 | ||
@@ -222,50 +168,12 @@ static int __init tx4927_pcibios_init(void) | |||
222 | v08_e1 &= 0xf0; | 168 | v08_e1 &= 0xf0; |
223 | v08_e1 |= 0x0d; | 169 | v08_e1 |= 0x0d; |
224 | 170 | ||
225 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
226 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
227 | ":%s mid 0x64 = 0x%02x\n", s, v08_64); | ||
228 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
229 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
230 | ":%s mid 0xb0 = 0x%02x\n", s, v32_b0); | ||
231 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
232 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
233 | ":%s mid 0xe1 = 0x%02x\n", s, v08_e1); | ||
234 | |||
235 | early_write_config_byte(hose, busno, busno, | 171 | early_write_config_byte(hose, busno, busno, |
236 | pci_devfn, 0x64, v08_64); | 172 | pci_devfn, 0x64, v08_64); |
237 | early_write_config_dword(hose, busno, busno, | 173 | early_write_config_dword(hose, busno, busno, |
238 | pci_devfn, 0xb0, v32_b0); | 174 | pci_devfn, 0xb0, v32_b0); |
239 | early_write_config_byte(hose, busno, busno, | 175 | early_write_config_byte(hose, busno, busno, |
240 | pci_devfn, 0xe1, v08_e1); | 176 | pci_devfn, 0xe1, v08_e1); |
241 | |||
242 | #ifdef TOSHIBA_RBTX4927_SETUP_DEBUG | ||
243 | { | ||
244 | early_read_config_byte(hose, busno, busno, | ||
245 | pci_devfn, 0x64, | ||
246 | &v08_64); | ||
247 | early_read_config_dword(hose, busno, busno, | ||
248 | pci_devfn, 0xb0, | ||
249 | &v32_b0); | ||
250 | early_read_config_byte(hose, busno, busno, | ||
251 | pci_devfn, 0xe1, | ||
252 | &v08_e1); | ||
253 | |||
254 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
255 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
256 | ":%s end 0x64 = 0x%02x\n", s, v08_64); | ||
257 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
258 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
259 | ":%s end 0xb0 = 0x%02x\n", s, v32_b0); | ||
260 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
261 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
262 | ":%s end 0xe1 = 0x%02x\n", s, v08_e1); | ||
263 | } | ||
264 | #endif | ||
265 | |||
266 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
267 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, ":%s end\n", | ||
268 | s); | ||
269 | } | 177 | } |
270 | 178 | ||
271 | if (id == 0x91301055) { | 179 | if (id == 0x91301055) { |
@@ -274,13 +182,6 @@ static int __init tx4927_pcibios_init(void) | |||
274 | u8 v08_41; | 182 | u8 v08_41; |
275 | u8 v08_43; | 183 | u8 v08_43; |
276 | u8 v08_5c; | 184 | u8 v08_5c; |
277 | #ifdef TOSHIBA_RBTX4927_SETUP_DEBUG | ||
278 | char *s = " sb/ide --"; | ||
279 | #endif | ||
280 | |||
281 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
282 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, ":%s beg\n", | ||
283 | s); | ||
284 | 185 | ||
285 | early_read_config_byte(hose, busno, busno, | 186 | early_read_config_byte(hose, busno, busno, |
286 | pci_devfn, 0x04, &v08_04); | 187 | pci_devfn, 0x04, &v08_04); |
@@ -293,22 +194,6 @@ static int __init tx4927_pcibios_init(void) | |||
293 | early_read_config_byte(hose, busno, busno, | 194 | early_read_config_byte(hose, busno, busno, |
294 | pci_devfn, 0x5c, &v08_5c); | 195 | pci_devfn, 0x5c, &v08_5c); |
295 | 196 | ||
296 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
297 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
298 | ":%s beg 0x04 = 0x%02x\n", s, v08_04); | ||
299 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
300 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
301 | ":%s beg 0x09 = 0x%02x\n", s, v08_09); | ||
302 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
303 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
304 | ":%s beg 0x41 = 0x%02x\n", s, v08_41); | ||
305 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
306 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
307 | ":%s beg 0x43 = 0x%02x\n", s, v08_43); | ||
308 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
309 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
310 | ":%s beg 0x5c = 0x%02x\n", s, v08_5c); | ||
311 | |||
312 | /* enable ide master/io */ | 197 | /* enable ide master/io */ |
313 | v08_04 |= (PCI_COMMAND_MASTER | PCI_COMMAND_IO); | 198 | v08_04 |= (PCI_COMMAND_MASTER | PCI_COMMAND_IO); |
314 | 199 | ||
@@ -332,22 +217,6 @@ static int __init tx4927_pcibios_init(void) | |||
332 | */ | 217 | */ |
333 | v08_5c |= 0x01; | 218 | v08_5c |= 0x01; |
334 | 219 | ||
335 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
336 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
337 | ":%s mid 0x04 = 0x%02x\n", s, v08_04); | ||
338 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
339 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
340 | ":%s mid 0x09 = 0x%02x\n", s, v08_09); | ||
341 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
342 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
343 | ":%s mid 0x41 = 0x%02x\n", s, v08_41); | ||
344 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
345 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
346 | ":%s mid 0x43 = 0x%02x\n", s, v08_43); | ||
347 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
348 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
349 | ":%s mid 0x5c = 0x%02x\n", s, v08_5c); | ||
350 | |||
351 | early_write_config_byte(hose, busno, busno, | 220 | early_write_config_byte(hose, busno, busno, |
352 | pci_devfn, 0x5c, v08_5c); | 221 | pci_devfn, 0x5c, v08_5c); |
353 | early_write_config_byte(hose, busno, busno, | 222 | early_write_config_byte(hose, busno, busno, |
@@ -358,54 +227,11 @@ static int __init tx4927_pcibios_init(void) | |||
358 | pci_devfn, 0x41, v08_41); | 227 | pci_devfn, 0x41, v08_41); |
359 | early_write_config_byte(hose, busno, busno, | 228 | early_write_config_byte(hose, busno, busno, |
360 | pci_devfn, 0x43, v08_43); | 229 | pci_devfn, 0x43, v08_43); |
361 | |||
362 | #ifdef TOSHIBA_RBTX4927_SETUP_DEBUG | ||
363 | { | ||
364 | early_read_config_byte(hose, busno, busno, | ||
365 | pci_devfn, 0x04, | ||
366 | &v08_04); | ||
367 | early_read_config_byte(hose, busno, busno, | ||
368 | pci_devfn, 0x09, | ||
369 | &v08_09); | ||
370 | early_read_config_byte(hose, busno, busno, | ||
371 | pci_devfn, 0x41, | ||
372 | &v08_41); | ||
373 | early_read_config_byte(hose, busno, busno, | ||
374 | pci_devfn, 0x43, | ||
375 | &v08_43); | ||
376 | early_read_config_byte(hose, busno, busno, | ||
377 | pci_devfn, 0x5c, | ||
378 | &v08_5c); | ||
379 | |||
380 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
381 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
382 | ":%s end 0x04 = 0x%02x\n", s, v08_04); | ||
383 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
384 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
385 | ":%s end 0x09 = 0x%02x\n", s, v08_09); | ||
386 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
387 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
388 | ":%s end 0x41 = 0x%02x\n", s, v08_41); | ||
389 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
390 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
391 | ":%s end 0x43 = 0x%02x\n", s, v08_43); | ||
392 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
393 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
394 | ":%s end 0x5c = 0x%02x\n", s, v08_5c); | ||
395 | } | ||
396 | #endif | ||
397 | |||
398 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
399 | (TOSHIBA_RBTX4927_SETUP_PCIBIOS, ":%s end\n", | ||
400 | s); | ||
401 | } | 230 | } |
402 | 231 | ||
403 | } | 232 | } |
404 | 233 | ||
405 | register_pci_controller(&tx4927_controller); | 234 | register_pci_controller(&tx4927_controller); |
406 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCIBIOS, | ||
407 | "+\n"); | ||
408 | |||
409 | return 0; | 235 | return 0; |
410 | } | 236 | } |
411 | 237 | ||
@@ -419,45 +245,13 @@ void __init tx4927_pci_setup(void) | |||
419 | static int called = 0; | 245 | static int called = 0; |
420 | extern unsigned int tx4927_get_mem_size(void); | 246 | extern unsigned int tx4927_get_mem_size(void); |
421 | 247 | ||
422 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, "-\n"); | ||
423 | |||
424 | mips_memory_upper = tx4927_get_mem_size() << 20; | 248 | mips_memory_upper = tx4927_get_mem_size() << 20; |
425 | mips_memory_upper += KSEG0; | 249 | mips_memory_upper += KSEG0; |
426 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
427 | "0x%08lx=mips_memory_upper\n", | ||
428 | mips_memory_upper); | ||
429 | mips_pci_io_base = TX4927_PCIIO; | 250 | mips_pci_io_base = TX4927_PCIIO; |
430 | mips_pci_io_size = TX4927_PCIIO_SIZE; | 251 | mips_pci_io_size = TX4927_PCIIO_SIZE; |
431 | mips_pci_mem_base = TX4927_PCIMEM; | 252 | mips_pci_mem_base = TX4927_PCIMEM; |
432 | mips_pci_mem_size = TX4927_PCIMEM_SIZE; | 253 | mips_pci_mem_size = TX4927_PCIMEM_SIZE; |
433 | 254 | ||
434 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
435 | "0x%08lx=mips_pci_io_base\n", | ||
436 | mips_pci_io_base); | ||
437 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
438 | "0x%08lx=mips_pci_io_size\n", | ||
439 | mips_pci_io_size); | ||
440 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
441 | "0x%08lx=mips_pci_mem_base\n", | ||
442 | mips_pci_mem_base); | ||
443 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
444 | "0x%08lx=mips_pci_mem_size\n", | ||
445 | mips_pci_mem_size); | ||
446 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
447 | "0x%08lx=pci_io_resource.start\n", | ||
448 | pci_io_resource.start); | ||
449 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
450 | "0x%08lx=pci_io_resource.end\n", | ||
451 | pci_io_resource.end); | ||
452 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
453 | "0x%08lx=pci_mem_resource.start\n", | ||
454 | pci_mem_resource.start); | ||
455 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
456 | "0x%08lx=pci_mem_resource.end\n", | ||
457 | pci_mem_resource.end); | ||
458 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
459 | "0x%08lx=mips_io_port_base", | ||
460 | mips_io_port_base); | ||
461 | if (!called) { | 255 | if (!called) { |
462 | printk | 256 | printk |
463 | ("%s PCIC -- DID:%04x VID:%04x RID:%02x Arbiter:%s\n", | 257 | ("%s PCIC -- DID:%04x VID:%04x RID:%02x Arbiter:%s\n", |
@@ -521,29 +315,10 @@ void __init tx4927_pci_setup(void) | |||
521 | } | 315 | } |
522 | 316 | ||
523 | printk("Internal(%dMHz)", pciclk / 1000000); | 317 | printk("Internal(%dMHz)", pciclk / 1000000); |
524 | } else { | 318 | } else |
525 | int pciclk = 0; | 319 | printk("External"); |
526 | int pciclk_setting = *tx4927_pci_clk_ptr; | ||
527 | switch (pciclk_setting & TX4927_PCI_CLK_MASK) { | ||
528 | case TX4927_PCI_CLK_33: | ||
529 | pciclk = 33333333; | ||
530 | break; | ||
531 | case TX4927_PCI_CLK_25: | ||
532 | pciclk = 25000000; | ||
533 | break; | ||
534 | case TX4927_PCI_CLK_66: | ||
535 | pciclk = 66666666; | ||
536 | break; | ||
537 | case TX4927_PCI_CLK_50: | ||
538 | pciclk = 50000000; | ||
539 | break; | ||
540 | } | ||
541 | printk("External(%dMHz)", pciclk / 1000000); | ||
542 | } | ||
543 | printk("\n"); | 320 | printk("\n"); |
544 | 321 | ||
545 | |||
546 | |||
547 | /* GB->PCI mappings */ | 322 | /* GB->PCI mappings */ |
548 | tx4927_pcicptr->g2piomask = (mips_pci_io_size - 1) >> 4; | 323 | tx4927_pcicptr->g2piomask = (mips_pci_io_size - 1) >> 4; |
549 | tx4927_pcicptr->g2piogbase = mips_pci_io_base | | 324 | tx4927_pcicptr->g2piogbase = mips_pci_io_base | |
@@ -644,12 +419,7 @@ void __init tx4927_pci_setup(void) | |||
644 | tx4927_pcicptr->pcistatus = PCI_COMMAND_MASTER | | 419 | tx4927_pcicptr->pcistatus = PCI_COMMAND_MASTER | |
645 | PCI_COMMAND_MEMORY | | 420 | PCI_COMMAND_MEMORY | |
646 | PCI_COMMAND_PARITY | PCI_COMMAND_SERR; | 421 | PCI_COMMAND_PARITY | PCI_COMMAND_SERR; |
647 | |||
648 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, | ||
649 | ":pci setup complete:\n"); | ||
650 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI2, "+\n"); | ||
651 | } | 422 | } |
652 | |||
653 | #endif /* CONFIG_PCI */ | 423 | #endif /* CONFIG_PCI */ |
654 | 424 | ||
655 | static void __noreturn wait_forever(void) | 425 | static void __noreturn wait_forever(void) |
@@ -679,7 +449,6 @@ void toshiba_rbtx4927_restart(char *command) | |||
679 | /* no return */ | 449 | /* no return */ |
680 | } | 450 | } |
681 | 451 | ||
682 | |||
683 | void toshiba_rbtx4927_halt(void) | 452 | void toshiba_rbtx4927_halt(void) |
684 | { | 453 | { |
685 | printk(KERN_NOTICE "System Halted\n"); | 454 | printk(KERN_NOTICE "System Halted\n"); |
@@ -702,33 +471,19 @@ void __init plat_mem_setup(void) | |||
702 | 471 | ||
703 | printk("CPU is %s\n", toshiba_name); | 472 | printk("CPU is %s\n", toshiba_name); |
704 | 473 | ||
705 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_SETUP, | ||
706 | "-\n"); | ||
707 | |||
708 | /* f/w leaves this on at startup */ | 474 | /* f/w leaves this on at startup */ |
709 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_SETUP, | ||
710 | ":Clearing STO_ERL.\n"); | ||
711 | clear_c0_status(ST0_ERL); | 475 | clear_c0_status(ST0_ERL); |
712 | 476 | ||
713 | /* enable caches -- HCP5 does this, pmon does not */ | 477 | /* enable caches -- HCP5 does this, pmon does not */ |
714 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_SETUP, | ||
715 | ":Enabling TX49_CONF_IC,TX49_CONF_DC.\n"); | ||
716 | cp0_config = read_c0_config(); | 478 | cp0_config = read_c0_config(); |
717 | cp0_config = cp0_config & ~(TX49_CONF_IC | TX49_CONF_DC); | 479 | cp0_config = cp0_config & ~(TX49_CONF_IC | TX49_CONF_DC); |
718 | write_c0_config(cp0_config); | 480 | write_c0_config(cp0_config); |
719 | 481 | ||
720 | set_io_port_base(KSEG1 + TBTX4927_ISA_IO_OFFSET); | 482 | set_io_port_base(KSEG1 + TBTX4927_ISA_IO_OFFSET); |
721 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_SETUP, | ||
722 | ":mips_io_port_base=0x%08lx\n", | ||
723 | mips_io_port_base); | ||
724 | 483 | ||
725 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_SETUP, | ||
726 | ":Resource\n"); | ||
727 | ioport_resource.end = 0xffffffff; | 484 | ioport_resource.end = 0xffffffff; |
728 | iomem_resource.end = 0xffffffff; | 485 | iomem_resource.end = 0xffffffff; |
729 | 486 | ||
730 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_SETUP, | ||
731 | ":ResetRoutines\n"); | ||
732 | _machine_restart = toshiba_rbtx4927_restart; | 487 | _machine_restart = toshiba_rbtx4927_restart; |
733 | _machine_halt = toshiba_rbtx4927_halt; | 488 | _machine_halt = toshiba_rbtx4927_halt; |
734 | pm_power_off = toshiba_rbtx4927_power_off; | 489 | pm_power_off = toshiba_rbtx4927_power_off; |
@@ -761,23 +516,6 @@ void __init plat_mem_setup(void) | |||
761 | * CPU 333MHz: PCI 66MHz : PCIDIVMODE: 101 (1/5) | 516 | * CPU 333MHz: PCI 66MHz : PCIDIVMODE: 101 (1/5) |
762 | * | 517 | * |
763 | */ | 518 | */ |
764 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI1, | ||
765 | "ccfg is %lx, PCIDIVMODE is %x\n", | ||
766 | (unsigned long) tx4927_ccfgptr->ccfg, | ||
767 | (unsigned long) tx4927_ccfgptr->ccfg & | ||
768 | (mips_machtype == MACH_TOSHIBA_RBTX4937 ? | ||
769 | TX4937_CCFG_PCIDIVMODE_MASK : | ||
770 | TX4927_CCFG_PCIDIVMODE_MASK)); | ||
771 | |||
772 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_PCI1, | ||
773 | "PCI66 mode is %lx, PCI mode is %lx, pci arb is %lx\n", | ||
774 | (unsigned long) tx4927_ccfgptr-> | ||
775 | ccfg & TX4927_CCFG_PCI66, | ||
776 | (unsigned long) tx4927_ccfgptr-> | ||
777 | ccfg & TX4927_CCFG_PCIMIDE, | ||
778 | (unsigned long) tx4927_ccfgptr-> | ||
779 | ccfg & TX4927_CCFG_PCIXARB); | ||
780 | |||
781 | if (mips_machtype == MACH_TOSHIBA_RBTX4937) | 519 | if (mips_machtype == MACH_TOSHIBA_RBTX4937) |
782 | switch ((unsigned long)tx4927_ccfgptr-> | 520 | switch ((unsigned long)tx4927_ccfgptr-> |
783 | ccfg & TX4937_CCFG_PCIDIVMODE_MASK) { | 521 | ccfg & TX4937_CCFG_PCIDIVMODE_MASK) { |
@@ -818,49 +556,18 @@ void __init plat_mem_setup(void) | |||
818 | 556 | ||
819 | /* this is on ISA bus behind PCI bus, so need PCI up first */ | 557 | /* this is on ISA bus behind PCI bus, so need PCI up first */ |
820 | #ifdef CONFIG_TOSHIBA_FPCIB0 | 558 | #ifdef CONFIG_TOSHIBA_FPCIB0 |
821 | { | 559 | if (tx4927_using_backplane) { |
822 | if (tx4927_using_backplane) { | 560 | smsc_fdc37m81x_init(0x3f0); |
823 | TOSHIBA_RBTX4927_SETUP_DPRINTK | 561 | smsc_fdc37m81x_config_beg(); |
824 | (TOSHIBA_RBTX4927_SETUP_SETUP, | 562 | smsc_fdc37m81x_config_set(SMSC_FDC37M81X_DNUM, |
825 | ":fpcibo=yes\n"); | 563 | SMSC_FDC37M81X_KBD); |
826 | 564 | smsc_fdc37m81x_config_set(SMSC_FDC37M81X_INT, 1); | |
827 | TOSHIBA_RBTX4927_SETUP_DPRINTK | 565 | smsc_fdc37m81x_config_set(SMSC_FDC37M81X_INT2, 12); |
828 | (TOSHIBA_RBTX4927_SETUP_SETUP, | 566 | smsc_fdc37m81x_config_set(SMSC_FDC37M81X_ACTIVE, |
829 | ":smsc_fdc37m81x_init()\n"); | 567 | 1); |
830 | smsc_fdc37m81x_init(0x3f0); | 568 | smsc_fdc37m81x_config_end(); |
831 | |||
832 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
833 | (TOSHIBA_RBTX4927_SETUP_SETUP, | ||
834 | ":smsc_fdc37m81x_config_beg()\n"); | ||
835 | smsc_fdc37m81x_config_beg(); | ||
836 | |||
837 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
838 | (TOSHIBA_RBTX4927_SETUP_SETUP, | ||
839 | ":smsc_fdc37m81x_config_set(KBD)\n"); | ||
840 | smsc_fdc37m81x_config_set(SMSC_FDC37M81X_DNUM, | ||
841 | SMSC_FDC37M81X_KBD); | ||
842 | smsc_fdc37m81x_config_set(SMSC_FDC37M81X_INT, 1); | ||
843 | smsc_fdc37m81x_config_set(SMSC_FDC37M81X_INT2, 12); | ||
844 | smsc_fdc37m81x_config_set(SMSC_FDC37M81X_ACTIVE, | ||
845 | 1); | ||
846 | |||
847 | smsc_fdc37m81x_config_end(); | ||
848 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
849 | (TOSHIBA_RBTX4927_SETUP_SETUP, | ||
850 | ":smsc_fdc37m81x_config_end()\n"); | ||
851 | } else { | ||
852 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
853 | (TOSHIBA_RBTX4927_SETUP_SETUP, | ||
854 | ":fpcibo=not_found\n"); | ||
855 | } | ||
856 | } | ||
857 | #else | ||
858 | { | ||
859 | TOSHIBA_RBTX4927_SETUP_DPRINTK | ||
860 | (TOSHIBA_RBTX4927_SETUP_SETUP, ":fpcibo=no\n"); | ||
861 | } | 569 | } |
862 | #endif | 570 | #endif |
863 | |||
864 | #endif /* CONFIG_PCI */ | 571 | #endif /* CONFIG_PCI */ |
865 | 572 | ||
866 | #ifdef CONFIG_SERIAL_TXX9 | 573 | #ifdef CONFIG_SERIAL_TXX9 |
@@ -894,17 +601,12 @@ void __init plat_mem_setup(void) | |||
894 | } | 601 | } |
895 | #endif | 602 | #endif |
896 | 603 | ||
897 | |||
898 | #ifdef CONFIG_IP_PNP | 604 | #ifdef CONFIG_IP_PNP |
899 | argptr = prom_getcmdline(); | 605 | argptr = prom_getcmdline(); |
900 | if (strstr(argptr, "ip=") == NULL) { | 606 | if (strstr(argptr, "ip=") == NULL) { |
901 | strcat(argptr, " ip=any"); | 607 | strcat(argptr, " ip=any"); |
902 | } | 608 | } |
903 | #endif | 609 | #endif |
904 | |||
905 | |||
906 | TOSHIBA_RBTX4927_SETUP_DPRINTK(TOSHIBA_RBTX4927_SETUP_SETUP, | ||
907 | "+\n"); | ||
908 | } | 610 | } |
909 | 611 | ||
910 | void __init plat_time_init(void) | 612 | void __init plat_time_init(void) |