[PATCH] Driver Core: pm diagnostics update, check for errors
[linux-2.6/verdex.git] / arch / mips / vr41xx / nec-cmbvr4133 / init.c
blob87f06b3f5a9cbf29a6ceb8a6eb496cd3937fcd67
1 /*
2 * arch/mips/vr41xx/nec-cmbvr4133/init.c
4 * PROM library initialisation code for NEC CMB-VR4133 board.
6 * Author: Yoichi Yuasa <yyuasa@mvista.com, or source@mvista.com> and
7 * Jun Sun <jsun@mvista.com, or source@mvista.com> and
8 * Alex Sapkov <asapkov@ru.mvista.com>
10 * 2001-2004 (c) MontaVista, Software, Inc. This file is licensed under
11 * the terms of the GNU General Public License version 2. This program
12 * is licensed "as is" without any warranty of any kind, whether express
13 * or implied.
15 * Support for NEC-CMBVR4133 in 2.6
16 * Manish Lachwani (mlachwani@mvista.com)
18 #include <linux/config.h>
19 #include <linux/init.h>
20 #include <linux/kernel.h>
21 #include <linux/string.h>
23 #include <asm/bootinfo.h>
25 #ifdef CONFIG_ROCKHOPPER
26 #include <asm/io.h>
27 #include <linux/pci.h>
29 #define PCICONFDREG 0xaf000c14
30 #define PCICONFAREG 0xaf000c18
31 #endif
33 const char *get_system_type(void)
35 return "NEC CMB-VR4133";
38 #ifdef CONFIG_ROCKHOPPER
39 void disable_pcnet(void)
41 u32 data;
44 * Workaround for the bug in PMON on VR4133. PMON leaves
45 * AMD PCNet controller (on Rockhopper) initialized and running in
46 * bus master mode. We have do disable it before doing any
47 * further initialization. Or we get problems with PCI bus 2
48 * and random lockups and crashes.
51 writel((2 << 16) |
52 (PCI_DEVFN(1,0) << 8) |
53 (0 & 0xfc) |
54 1UL,
55 PCICONFAREG);
57 data = readl(PCICONFDREG);
59 writel((2 << 16) |
60 (PCI_DEVFN(1,0) << 8) |
61 (4 & 0xfc) |
62 1UL,
63 PCICONFAREG);
65 data = readl(PCICONFDREG);
67 writel((2 << 16) |
68 (PCI_DEVFN(1,0) << 8) |
69 (4 & 0xfc) |
70 1UL,
71 PCICONFAREG);
73 data &= ~4;
75 writel(data, PCICONFDREG);
77 #endif