pci.c
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:2k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /*
  2.  * Copyright 2001 MontaVista Software Inc.
  3.  * Author: Jun Sun, jsun@mvista.com or jsun@junsun.net
  4.  *
  5.  * arch/mips/gt64120/momenco_ocelot/pci.c
  6.  *     Board-specific PCI routines for gt64120 controller.
  7.  *
  8.  * This program is free software; you can redistribute  it and/or modify it
  9.  * under  the terms of  the GNU General  Public License as published by the
  10.  * Free Software Foundation;  either version 2 of the  License, or (at your
  11.  * option) any later version.
  12.  */
  13. #include <linux/types.h>
  14. #include <linux/pci.h>
  15. #include <linux/kernel.h>
  16. #include <linux/version.h>
  17. #include <linux/init.h>
  18. #include <asm/pci.h>
  19. void __init gt64120_board_pcibios_fixup_bus(struct pci_bus *bus)
  20. {
  21. struct pci_bus *current_bus = bus;
  22. struct pci_dev *devices;
  23. struct list_head *devices_link;
  24. u16 cmd;
  25. list_for_each(devices_link, &(current_bus->devices)) {
  26. devices = pci_dev_b(devices_link);
  27. if (devices == NULL)
  28. continue;
  29. if (PCI_SLOT(devices->devfn) == 1) {
  30. /*
  31.  * Slot 1 is primary ether port, i82559
  32.  * we double-check against that assumption
  33.  */
  34. if ((devices->vendor != 0x8086) ||
  35.     (devices->device != 0x1209) ) {
  36. panic("gt64120_board_pcibios_fixup_bus: found "
  37.       "unexpected PCI device in slot 1.");
  38. }
  39. devices->irq = 2;       /* irq_nr is 2 for INT0 */
  40. } else if (PCI_SLOT(devices->devfn) == 2) {
  41. /*
  42.  * Slot 2 is secondary ether port, i21143 
  43.  * we double-check against that assumption
  44.  */
  45. if ((devices->vendor != 0x1011) ||
  46.     (devices->device != 0x19) ) {
  47. panic("galileo_pcibios_fixup_bus: "
  48.       "found unexpected PCI device in slot 2.");
  49. }
  50. devices->irq = 3;       /* irq_nr is 3 for INT1 */
  51. } else if (PCI_SLOT(devices->devfn) == 4) {
  52. /* PMC Slot 1 */
  53. devices->irq = 8;       /* irq_nr is 8 for INT6 */
  54. } else if (PCI_SLOT(devices->devfn) == 5) {
  55. /* PMC Slot 1 */
  56. devices->irq = 9;       /* irq_nr is 9 for INT7 */
  57. } else {
  58. /* We don't have assign interrupts for other devices. */
  59. devices->irq = 0xff;
  60. }
  61. /* Assign an interrupt number for the device */
  62. bus->ops->write_byte(devices, PCI_INTERRUPT_LINE, devices->irq);
  63. /* enable master */
  64. bus->ops->read_word(devices, PCI_COMMAND, &cmd);
  65. cmd |= PCI_COMMAND_MASTER;
  66. bus->ops->write_word(devices, PCI_COMMAND, cmd);
  67. }
  68. }