]> err.no Git - linux-2.6/commitdiff
ide: fix hwif_to_node()
authorBartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Tue, 2 Sep 2008 18:18:47 +0000 (20:18 +0200)
committerBartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Tue, 2 Sep 2008 18:18:47 +0000 (20:18 +0200)
hwif_to_node() incorrectly assumes that hwif->dev always belongs to
a PCI device.  This results in ide-cs oopsing in init_irq() after
commit c56c5648a3bd15ff14c50f284b261140cd5b5472 accidentally fixed
device tree registration for ide-cs.  Fix it by using dev_to_node().

Thanks to Martin Michlmayr and Larry Finger for help with debugging
the issue.

Reported-by: Martin Michlmayr <tbm@cyrius.com>
Tested-by: Martin Michlmayr <tbm@cyrius.com>
Cc: Larry Finger <Larry.Finger@lwfinger.net>
Cc: Dominik Brodowski <linux@dominikbrodowski.net>
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
include/linux/ide.h

index fee4b157c53387894ccfc9cc97520c9359d09ea4..1524829f73f2cd8c5aa4fc9cbc6bd47c7a1fa48f 100644 (file)
@@ -1448,8 +1448,7 @@ static inline void ide_dump_identify(u8 *id)
 
 static inline int hwif_to_node(ide_hwif_t *hwif)
 {
-       struct pci_dev *dev = to_pci_dev(hwif->dev);
-       return hwif->dev ? pcibus_to_node(dev->bus) : -1;
+       return hwif->dev ? dev_to_node(hwif->dev) : -1;
 }
 
 static inline ide_drive_t *ide_get_paired_drive(ide_drive_t *drive)