[patch] powerpc: Remove redundant pci_read_irq_line() function for 85xx platform
Benjamin Herrenschmidt
benh at kernel.crashing.org
Sat Jun 2 09:23:44 EST 2007
On Fri, 2007-06-01 at 16:05 +0800, Zang Roy-r61911 wrote:
> From: Roy Zang <tie-fei.zang at freescale.com>
>
> Remove redundant pci_read_irq_line() function for
> 85xx CDS board.
> This function has been realized in common pci_32.c.
>
> Signed-off-by: Roy Zang <tie-fei.zang at freescale.com>
Acked-by: Benjamin Herrenschmidt <benh at kernel.crashing.org>
> ---
> arch/powerpc/platforms/85xx/mpc85xx_cds.c | 76 +++++++++++++----------------
> 1 files changed, 34 insertions(+), 42 deletions(-)
>
> diff --git a/arch/powerpc/platforms/85xx/mpc85xx_cds.c b/arch/powerpc/platforms/85xx/mpc85xx_cds.c
> index 1490eb3..27b81ff 100644
> --- a/arch/powerpc/platforms/85xx/mpc85xx_cds.c
> +++ b/arch/powerpc/platforms/85xx/mpc85xx_cds.c
> @@ -78,52 +78,44 @@ static int mpc85xx_exclude_device(u_char bus, u_char devfn)
> return PCIBIOS_SUCCESSFUL;
> }
>
> -static void __init mpc85xx_cds_pcibios_fixup(void)
> +static void __init mpc85xx_cds_pci_irq_fixup(struct pci_dev *dev)
> {
> - struct pci_dev *dev;
> - u_char c;
> -
> - if ((dev = pci_get_device(PCI_VENDOR_ID_VIA,
> - PCI_DEVICE_ID_VIA_82C586_1, NULL))) {
> + u_char c;
> + if (dev->vendor == PCI_VENDOR_ID_VIA) {
> + switch (dev->device) {
> + case PCI_DEVICE_ID_VIA_82C586_1:
> + /*
> + * U-Boot does not set the enable bits
> + * for the IDE device. Force them on here.
> + */
> + pci_read_config_byte(dev, 0x40, &c);
> + c |= 0x03; /* IDE: Chip Enable Bits */
> + pci_write_config_byte(dev, 0x40, c);
> +
> + /*
> + * Since only primary interface works, force the
> + * IDE function to standard primary IDE interrupt
> + * w/ 8259 offset
> + */
> + dev->irq = 14;
> + pci_write_config_byte(dev, PCI_INTERRUPT_LINE, dev->irq);
> + break;
> /*
> - * U-Boot does not set the enable bits
> - * for the IDE device. Force them on here.
> + * Force legacy USB interrupt routing
> */
> - pci_read_config_byte(dev, 0x40, &c);
> - c |= 0x03; /* IDE: Chip Enable Bits */
> - pci_write_config_byte(dev, 0x40, c);
> -
> - /*
> - * Since only primary interface works, force the
> - * IDE function to standard primary IDE interrupt
> - * w/ 8259 offset
> + case PCI_DEVICE_ID_VIA_82C586_2:
> + /* There are two USB controllers.
> + * Identify them by functon number
> */
> - dev->irq = 14;
> - pci_write_config_byte(dev, PCI_INTERRUPT_LINE, dev->irq);
> - pci_dev_put(dev);
> - }
> -
> - /*
> - * Force legacy USB interrupt routing
> - */
> - if ((dev = pci_get_device(PCI_VENDOR_ID_VIA,
> - PCI_DEVICE_ID_VIA_82C586_2, NULL))) {
> - dev->irq = 10;
> - pci_write_config_byte(dev, PCI_INTERRUPT_LINE, 10);
> - pci_dev_put(dev);
> - }
> -
> - if ((dev = pci_get_device(PCI_VENDOR_ID_VIA,
> - PCI_DEVICE_ID_VIA_82C586_2, dev))) {
> - dev->irq = 11;
> - pci_write_config_byte(dev, PCI_INTERRUPT_LINE, 11);
> - pci_dev_put(dev);
> + if (PCI_FUNC(dev->devfn))
> + dev->irq = 11;
> + else
> + dev->irq = 10;
> + pci_write_config_byte(dev, PCI_INTERRUPT_LINE, dev->irq);
> + default:
> + break;
> + }
> }
> -
> - /* Now map all the PCI irqs */
> - dev = NULL;
> - for_each_pci_dev(dev)
> - pci_read_irq_line(dev);
> }
>
> #ifdef CONFIG_PPC_I8259
> @@ -259,7 +251,7 @@ static void __init mpc85xx_cds_setup_arch(void)
> for (np = NULL; (np = of_find_node_by_type(np, "pci")) != NULL;)
> add_bridge(np);
>
> - ppc_md.pcibios_fixup = mpc85xx_cds_pcibios_fixup;
> + ppc_md.pci_irq_fixup = mpc85xx_cds_pci_irq_fixup;
> ppc_md.pci_exclude_device = mpc85xx_exclude_device;
> #endif
> }
More information about the Linuxppc-dev
mailing list