From: Benjamin Herrenschmidt <benh@kernel.crashing.org>
To: Bartlomiej Zolnierkiewicz <B.Zolnierkiewicz@elka.pw.edu.pl>
Cc: list linux-ide <linux-ide@vger.kernel.org>
Subject: [RFC] pci_get_legacy_ide_irq()
Date: Tue, 19 Oct 2004 17:04:48 +1000 [thread overview]
Message-ID: <1098169487.15029.58.camel@gaston> (raw)
Hi !
As discussed earlier, this is a proposed patch that adds the function
to include/asm-generic/pci.h and ppc64's own pci.h. I also only call
it from the amd7xxx.c driver for now, I want to let Bart decide if we
should add a call to it from every driver that don't see an irq when
we sort-of know what we are doing, or if we could just call it from the
generic pci-ide code when the controller is in legacy mode ... maybe
after a probe pass ? (thoug archs like ppc don't do irq probe).
The patch also uses NO_IRQ which is currently not defined on a lot of
archs. This is ok as I'm currently collecting definitions for it and
will send a patch adding those before this patch gets submited.
This patch adds a pci_get_legacy_ide_irq() function to
include/asm-generic/pci.h that returns the interrupt to use for a PCI
IDE controller that is set to "legacy mode". It also adds a ppc64 specific
implementation that allows the platform code to provide it's own number.
Finally, it adds a call to this routine to the amd7xxx driver (instead
of hard coding the numbers) when no interrupt was found.
I decided to fix individual drivers rather
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Index: linux-maple/drivers/ide/pci/amd74xx.c
===================================================================
--- linux-maple.orig/drivers/ide/pci/amd74xx.c 2004-10-19 13:38:08.000000000 +1000
+++ linux-maple/drivers/ide/pci/amd74xx.c 2004-10-19 17:04:20.243498048 +1000
@@ -416,8 +416,8 @@
{
int i;
- if (!hwif->irq)
- hwif->irq = hwif->channel ? 15 : 14;
+ if (hwif->irq == NO_IRQ)
+ hwif->irq = pci_get_legacy_ide_irq(hwif->pci_dev, hwif->channel);
hwif->autodma = 0;
Index: linux-maple/include/asm-ppc64/pci.h
===================================================================
--- linux-maple.orig/include/asm-ppc64/pci.h 2004-10-19 13:37:31.000000000 +1000
+++ linux-maple/include/asm-ppc64/pci.h 2004-10-19 17:03:43.151545320 +1000
@@ -13,6 +13,7 @@
#include <linux/slab.h>
#include <linux/string.h>
#include <linux/dma-mapping.h>
+#include <asm/machdep.h>
#include <asm/scatterlist.h>
#include <asm/io.h>
#include <asm/prom.h>
@@ -20,6 +21,8 @@
#define PCIBIOS_MIN_IO 0x1000
#define PCIBIOS_MIN_MEM 0x10000000
+struct pci_dev;
+
#ifdef CONFIG_PPC_ISERIES
#define pcibios_scan_all_fns(a, b) 0
#else
@@ -36,7 +39,13 @@
/* We don't do dynamic PCI IRQ allocation */
}
-struct pci_dev;
+#define HAVE_ARCH_PCI_GET_LEGACY_IDE_IRQ
+static inline int pci_get_legacy_ide_irq(struct pci_dev *dev, int channel)
+{
+ if (ppc_md.pci_get_legacy_ide_irq)
+ return ppc_md.pci_get_legacy_ide_irq(dev, channel);
+ return channel ? 15 : 14;
+}
#define HAVE_ARCH_PCI_MWI 1
static inline int pcibios_prep_mwi(struct pci_dev *dev)
Index: linux-maple/include/asm-generic/pci.h
===================================================================
--- linux-maple.orig/include/asm-generic/pci.h 2004-10-19 13:37:39.000000000 +1000
+++ linux-maple/include/asm-generic/pci.h 2004-10-19 17:03:43.152545168 +1000
@@ -24,4 +24,11 @@
#define pcibios_scan_all_fns(a, b) 0
+#ifndef HAVE_ARCH_PCI_GET_LEGACY_IDE_IRQ
+static inline int pci_get_legacy_ide_irq(struct pci_dev *dev, int channel)
+{
+ return channel ? 15 : 14;
+}
+#endif /* HAVE_ARCH_PCI_GET_LEGACY_IDE_IRQ */
+
#endif
Index: linux-maple/include/asm-ppc64/machdep.h
===================================================================
--- linux-maple.orig/include/asm-ppc64/machdep.h 2004-10-19 16:44:18.907474272 +1000
+++ linux-maple/include/asm-ppc64/machdep.h 2004-10-19 17:03:43.152545168 +1000
@@ -117,6 +117,9 @@
/* Check availability of legacy devices like i8042 */
int (*check_legacy_ioport)(unsigned int baseport);
+ /* Get legacy PCI/IDE interrupt mapping */
+ int (*pci_get_legacy_ide_irq)(struct pci_dev *dev, int channel);
+
};
extern struct machdep_calls ppc_md;
next reply other threads:[~2004-10-19 7:09 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-10-19 7:04 Benjamin Herrenschmidt [this message]
2004-10-19 17:25 ` [RFC] pci_get_legacy_ide_irq() Bartlomiej Zolnierkiewicz
2004-10-19 23:31 ` Benjamin Herrenschmidt
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1098169487.15029.58.camel@gaston \
--to=benh@kernel.crashing.org \
--cc=B.Zolnierkiewicz@elka.pw.edu.pl \
--cc=linux-ide@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).