[PATCH] IDE: correct partially initialised hw structures

Peter Denison (lkml@marshadder.uklinux.net)
Sun, 27 Oct 2002 20:09:03 +0000 (GMT)


Summary: Initialise all parts of hw_regs_t structures before passing them
to ide_register_hw

The hw structure (specifically the hw->chipset field) held uninitialised
data. This (before the initialisation order fixup recently posted) meant
that no chipset could ever get selected by an idex=<chipset> commandline
(silently!).

Only occurs on non-PCI platforms. All ARM platforms have already been
fixed - though slightly differently.

I'm not sure how valid a lot of the code I patched actually is. Does it
make sense on e.g. ia64 or x86_64 to specify CONFIG_PCI = n? Or even to
have the concept of default interfaces? The interfaces should get probed
anyway, and the ide_init_hwif_ports() part is called from init_hwif_data()
already. The only thing these arch-specific routines do extra is calling
ide_register_hw, which probably wants to happen from the probes, not here.

Applies: 2.5.44 (and probably others)

--- linux/include/asm-ia64/ide.h.old 2002-10-06 10:11:35.000000000 +0100
+++ linux/include/asm-ia64/ide.h 2002-10-27 18:47:26.000000000 +0000
@@ -82,6 +82,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-x86_64/ide.h.old 2002-10-19 12:43:40.000000000 +0100
+++ linux/include/asm-x86_64/ide.h 2002-10-27 18:47:46.000000000 +0000
@@ -69,6 +69,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-ppc/ide.h.old 2002-10-06 10:11:33.000000000 +0100
+++ linux/include/asm-ppc/ide.h 2002-10-27 18:48:20.000000000 +0000
@@ -89,6 +89,8 @@
int index;
ide_ioreg_t base;

+ memset(&hw, 0, sizeof(hw_regs_t));
+
for (index = 0; index < MAX_HWIFS; index++) {
base = ide_default_io_base(index);
if (base == 0)
--- linux/include/asm-mips/ide.h.old 2002-08-25 13:26:53.000000000 +0100
+++ linux/include/asm-mips/ide.h 2002-10-27 19:37:39.000000000 +0000
@@ -55,6 +55,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-parisc/ide.h.old 2002-08-25 13:26:53.000000000 +0100
+++ linux/include/asm-parisc/ide.h 2002-10-27 18:48:54.000000000 +0000
@@ -71,6 +71,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-i386/ide.h.old 2002-10-06 10:02:03.000000000 +0100
+++ linux/include/asm-i386/ide.h 2002-10-19 00:17:05.000000000 +0100
@@ -68,6 +68,8 @@
#ifndef CONFIG_PCI
hw_regs_t hw;
int index;
+
+ 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);
--- linux/include/asm-sparc64/ide.h.old 2002-10-06 10:02:03.000000000 +0100
+++ linux/include/asm-sparc64/ide.h 2002-10-27 18:50:10.000000000 +0000
@@ -59,6 +59,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-alpha/ide.h.old 2002-10-06 10:11:37.000000000 +0100
+++ linux/include/asm-alpha/ide.h 2002-10-27 18:50:58.000000000 +0000
@@ -72,6 +72,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-sparc/ide.h.old 2002-10-06 10:02:03.000000000 +0100
+++ linux/include/asm-sparc/ide.h 2002-10-27 18:52:12.000000000 +0000
@@ -63,6 +63,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-cris/ide.h.old 2002-08-25 13:26:53.000000000 +0100
+++ linux/include/asm-cris/ide.h 2002-10-27 18:52:48.000000000 +0000
@@ -79,6 +79,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-mips64/ide.h.old 2002-08-25 13:26:53.000000000 +0100
+++ linux/include/asm-mips64/ide.h 2002-10-27 19:38:04.000000000 +0000
@@ -58,6 +58,8 @@
hw_regs_t hw;
int index;

+ 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));
--- linux/include/asm-sh/ide.h.old 2002-08-25 13:26:53.000000000 +0100
+++ linux/include/asm-sh/ide.h 2002-10-27 18:53:46.000000000 +0000
@@ -97,6 +97,8 @@
hw_regs_t hw;
int index;

+ 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));

-- 
Peter Denison <peterd at marshadder dot uklinux dot net>
Please use the address above only for personal mail, not copied to any lists
that are gatewayed to news or web pages unless the addresses are removed.

- 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/