fixups-sh03.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. #include <linux/kernel.h>
  2. #include <linux/init.h>
  3. #include <linux/types.h>
  4. #include <linux/pci.h>
  5. /*
  6. * IRQ functions
  7. */
  8. int __init pcibios_map_platform_irq(u8 slot, u8 pin, struct pci_dev *dev)
  9. {
  10. int irq;
  11. if (dev->bus->number == 0) {
  12. switch (slot) {
  13. case 4: return 5; /* eth0 */
  14. case 8: return 5; /* eth1 */
  15. case 6: return 2; /* PCI bridge */
  16. default:
  17. printk("PCI: Bad IRQ mapping request for slot %d\n", slot);
  18. return 2;
  19. }
  20. } else {
  21. switch (pin) {
  22. case 0: irq = 2; break;
  23. case 1: irq = 2; break;
  24. case 2: irq = 2; break;
  25. case 3: irq = 2; break;
  26. case 4: irq = 2; break;
  27. default: irq = -1; break;
  28. }
  29. }
  30. return irq;
  31. }
  32. static u8 __init sh03_no_swizzle(struct pci_dev *dev, u8 *pin)
  33. {
  34. /* no swizzling */
  35. return PCI_SLOT(dev->devfn);
  36. }
  37. static int sh03_pci_lookup_irq(struct pci_dev *dev, u8 slot, u8 pin)
  38. {
  39. int irq = -1;
  40. /* now lookup the actual IRQ on a platform specific basis (pci-'platform'.c) */
  41. irq = pcibios_map_platform_irq(slot, pin, dev);
  42. if( irq < 0 ) {
  43. pr_debug("PCI: Error mapping IRQ on device %s\n", pci_name(dev));
  44. return irq;
  45. }
  46. pr_debug("Setting IRQ for slot %s to %d\n", pci_name(dev), irq);
  47. return irq;
  48. }
  49. void __init pcibios_fixup_irqs(void)
  50. {
  51. pci_fixup_irqs(sh03_no_swizzle, sh03_pci_lookup_irq);
  52. }