The ide_init_default_hwifs() function in include/asm-*/ide.h fails to
initialise the "hw_regs_t hw" variable, thus leaving uninitialised data
in some fields. Specifically, the "chipset" field is uninitialised which
causes the "if (hwif->chipset != ide_unknown)" test in drivers/block/ide.c
to always fail with the error message " -- BAD OPTION".
Cheers,
Andrew Pam
Patch follows:
diff -Nurd linux-2.2.20+ide-orig/include/asm-alpha/ide.h linux-2.2.20+ide/include/asm-alpha/ide.h
--- linux-2.2.20+ide-orig/include/asm-alpha/ide.h Wed May 22 14:35:58 2002
+++ linux-2.2.20+ide/include/asm-alpha/ide.h Wed May 22 14:47:15 2002
@@ -74,6 +74,11 @@
hw_regs_t hw;
int index;
+ /*
+ * Initialise before use!
+ * memset added 2002/05/22 by Andrew Pam <xanni@sericyb.com.au>
+ */
+ memset(&hw, 0, sizeof(hw_regs_t));
for (index = 0; index < MAX_HWIFS; index++) {
ide_init_hwif_ports(&hw, ide_default_io_base(index), 0, NULL);
hw.irq = ide_default_irq(ide_default_io_base(index));
diff -Nurd linux-2.2.20+ide-orig/include/asm-i386/ide.h linux-2.2.20+ide/include/asm-i386/ide.h
--- linux-2.2.20+ide-orig/include/asm-i386/ide.h Wed May 22 14:35:59 2002
+++ linux-2.2.20+ide/include/asm-i386/ide.h Wed May 22 14:46:49 2002
@@ -77,6 +77,11 @@
hw_regs_t hw;
int index;
+ /*
+ * Initialise before use!
+ * memset added 2002/05/22 by Andrew Pam <xanni@sericyb.com.au>
+ */
+ memset(&hw, 0, sizeof(hw_regs_t));
for(index = 0; index < MAX_HWIFS; index++) {
ide_init_hwif_ports(&hw, ide_default_io_base(index), 0, NULL);
hw.irq = ide_default_irq(ide_default_io_base(index));
diff -Nurd linux-2.2.20+ide-orig/include/asm-mips/ide.h linux-2.2.20+ide/include/asm-mips/ide.h
--- linux-2.2.20+ide-orig/include/asm-mips/ide.h Wed May 22 14:36:00 2002
+++ linux-2.2.20+ide/include/asm-mips/ide.h Wed May 22 14:48:54 2002
@@ -70,6 +70,11 @@
hw_regs_t hw;
int index;
+ /*
+ * Initialise before use!
+ * memset added 2002/05/22 by Andrew Pam <xanni@sericyb.com.au>
+ */
+ memset(&hw, 0, sizeof(hw_regs_t));
for (index = 0; index < MAX_HWIFS; index++) {
ide_init_hwif_ports(&hw, ide_default_io_base(index), 0, 0);
hw.irq = ide_default_irq(ide_default_io_base(index));
diff -Nurd linux-2.2.20+ide-orig/include/asm-ppc/ide.h linux-2.2.20+ide/include/asm-ppc/ide.h
--- linux-2.2.20+ide-orig/include/asm-ppc/ide.h Wed May 22 14:36:00 2002
+++ linux-2.2.20+ide/include/asm-ppc/ide.h Wed May 22 14:49:10 2002
@@ -89,6 +89,11 @@
hw_regs_t hw;
int index;
+ /*
+ * Initialise before use!
+ * memset added 2002/05/22 by Andrew Pam <xanni@sericyb.com.au>
+ */
+ memset(&hw, 0, sizeof(hw_regs_t));
for(index = 0; index < MAX_HWIFS; index++) {
base = ide_default_io_base(index);
if (base == 0)
diff -Nurd linux-2.2.20+ide-orig/include/asm-sparc64/ide.h linux-2.2.20+ide/include/asm-sparc64/ide.h
--- linux-2.2.20+ide-orig/include/asm-sparc64/ide.h Wed May 22 14:36:00 2002
+++ linux-2.2.20+ide/include/asm-sparc64/ide.h Wed May 22 14:49:14 2002
@@ -57,6 +57,11 @@
hw_regs_t hw;
int index;
+ /*
+ * Initialise before use!
+ * memset added 2002/05/22 by Andrew Pam <xanni@sericyb.com.au>
+ */
+ memset(&hw, 0, sizeof(hw_regs_t));
for (index = 0; index < MAX_HWIFS; index++) {
ide_init_hwif_ports(&hw, ide_default_io_base(index), 0, 0);
hw.irq = ide_default_irq(ide_default_io_base(index));
-- mailto:xanni@xanadu.net Andrew Pam http://www.xanadu.com.au/ Chief Scientist, Xanadu http://www.glasswings.com.au/ Technology Manager, Glass Wings http://www.sericyb.com.au/ Manager, Serious Cybernetics http://two-cents-worth.com/?105347&EG Donate two cents to our work! P.O. Box 477, Blackburn VIC 3130 Australia Phone +61 401 258 915 - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/