| /* |
| * This file is subject to the terms and conditions of the GNU General Public |
| * License. See the file "COPYING" in the main directory of this archive |
| * for more details. |
| * |
| * Copyright (C) 2004 Montavista Software Inc. |
| * Author: Manish Lachwani (mlachwani@mvista.com) |
| * |
| * Looking at the schematics for the Ocelot-3 board, there are |
| * two PCI busses and each bus has two PCI slots. |
| */ |
| #include <linux/kernel.h> |
| #include <linux/init.h> |
| #include <linux/pci.h> |
| #include <asm/mipsregs.h> |
| |
| /* |
| * Do platform specific device initialization at |
| * pci_enable_device() time |
| */ |
| int pcibios_plat_dev_init(struct pci_dev *dev) |
| { |
| return 0; |
| } |
| |
| int __init pcibios_map_irq(struct pci_dev *dev, u8 slot, u8 pin) |
| { |
| int bus = dev->bus->number; |
| |
| if (bus == 0 && slot == 1) |
| return 2; /* PCI-X A */ |
| if (bus == 0 && slot == 2) |
| return 3; /* PCI-X B */ |
| if (bus == 1 && slot == 1) |
| return 4; /* PCI A */ |
| if (bus == 1 && slot == 2) |
| return 5; /* PCI B */ |
| |
| return 0; |
| panic("Whooops in pcibios_map_irq"); |
| } |