diff options
author | Ralf Baechle <ralf@linux-mips.org> | 2007-08-07 12:18:28 -0400 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2007-08-26 21:16:55 -0400 |
commit | b5438582090406e2ccb4169d9b2df7c9939ae42b (patch) | |
tree | 46fb2e427e4159ff3e831137fc55acda6c4a7af0 | |
parent | de4b21474053513d9ad41994c95dade3e6b3362f (diff) |
[MIPS] SMTC: Fix crash on bootup with idebus= command line argument.
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
-rw-r--r-- | include/asm-mips/mach-generic/ide.h | 76 |
1 files changed, 25 insertions, 51 deletions
diff --git a/include/asm-mips/mach-generic/ide.h b/include/asm-mips/mach-generic/ide.h index 6eba2e576aaa..2b928577be5d 100644 --- a/include/asm-mips/mach-generic/ide.h +++ b/include/asm-mips/mach-generic/ide.h | |||
@@ -29,68 +29,42 @@ | |||
29 | 29 | ||
30 | #define IDE_ARCH_OBSOLETE_DEFAULTS | 30 | #define IDE_ARCH_OBSOLETE_DEFAULTS |
31 | 31 | ||
32 | static __inline__ int ide_probe_legacy(void) | ||
33 | { | ||
34 | #ifdef CONFIG_PCI | ||
35 | struct pci_dev *dev; | ||
36 | if ((dev = pci_get_class(PCI_CLASS_BRIDGE_EISA << 8, NULL)) != NULL || | ||
37 | (dev = pci_get_class(PCI_CLASS_BRIDGE_ISA << 8, NULL)) != NULL) { | ||
38 | pci_dev_put(dev); | ||
39 | |||
40 | return 1; | ||
41 | } | ||
42 | return 0; | ||
43 | #elif defined(CONFIG_EISA) || defined(CONFIG_ISA) | ||
44 | return 1; | ||
45 | #else | ||
46 | return 0; | ||
47 | #endif | ||
48 | } | ||
49 | |||
50 | static __inline__ int ide_default_irq(unsigned long base) | 32 | static __inline__ int ide_default_irq(unsigned long base) |
51 | { | 33 | { |
52 | if (ide_probe_legacy()) | 34 | switch (base) { |
53 | switch (base) { | 35 | case 0x1f0: return 14; |
54 | case 0x1f0: | 36 | case 0x170: return 15; |
55 | return 14; | 37 | case 0x1e8: return 11; |
56 | case 0x170: | 38 | case 0x168: return 10; |
57 | return 15; | 39 | case 0x1e0: return 8; |
58 | case 0x1e8: | 40 | case 0x160: return 12; |
59 | return 11; | ||
60 | case 0x168: | ||
61 | return 10; | ||
62 | case 0x1e0: | ||
63 | return 8; | ||
64 | case 0x160: | ||
65 | return 12; | ||
66 | default: | 41 | default: |
67 | return 0; | 42 | return 0; |
68 | } | 43 | } |
69 | else | ||
70 | return 0; | ||
71 | } | 44 | } |
72 | 45 | ||
73 | static __inline__ unsigned long ide_default_io_base(int index) | 46 | static __inline__ unsigned long ide_default_io_base(int index) |
74 | { | 47 | { |
75 | if (ide_probe_legacy()) | 48 | /* |
49 | * If PCI is present then it is not safe to poke around | ||
50 | * the other legacy IDE ports. Only 0x1f0 and 0x170 are | ||
51 | * defined compatibility mode ports for PCI. A user can | ||
52 | * override this using ide= but we must default safe. | ||
53 | */ | ||
54 | if (no_pci_devices()) { | ||
76 | switch (index) { | 55 | switch (index) { |
77 | case 0: | 56 | case 2: return 0x1e8; |
78 | return 0x1f0; | 57 | case 3: return 0x168; |
79 | case 1: | 58 | case 4: return 0x1e0; |
80 | return 0x170; | 59 | case 5: return 0x160; |
81 | case 2: | ||
82 | return 0x1e8; | ||
83 | case 3: | ||
84 | return 0x168; | ||
85 | case 4: | ||
86 | return 0x1e0; | ||
87 | case 5: | ||
88 | return 0x160; | ||
89 | default: | ||
90 | return 0; | ||
91 | } | 60 | } |
92 | else | 61 | } |
62 | switch (index) { | ||
63 | case 0: return 0x1f0; | ||
64 | case 1: return 0x170; | ||
65 | default: | ||
93 | return 0; | 66 | return 0; |
67 | } | ||
94 | } | 68 | } |
95 | 69 | ||
96 | #define IDE_ARCH_OBSOLETE_INIT | 70 | #define IDE_ARCH_OBSOLETE_INIT |