| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #include <linux/pci.h> | 
|  | 2 | #include <linux/init.h> | 
|  | 3 |  | 
|  | 4 | int pci_range_ck(unsigned char bus, unsigned char dev) | 
|  | 5 | { | 
|  | 6 | if (((bus == 0) || (bus == 1)) && (dev >= 6) && (dev <= 8)) | 
|  | 7 | return 0; | 
|  | 8 |  | 
|  | 9 | return -1; | 
|  | 10 | } | 
|  | 11 |  | 
|  | 12 | /* | 
|  | 13 | * After detecting all agents over the PCI , this function is called | 
|  | 14 | * in order to give an interrupt number for each PCI device starting | 
|  | 15 | * from IRQ 20. It does also enables master for each device. | 
|  | 16 | */ | 
|  | 17 | void __devinit pcibios_fixup_bus(struct pci_bus *bus) | 
|  | 18 | { | 
|  | 19 | unsigned int irq = 20; | 
|  | 20 | struct pci_bus *current_bus = bus; | 
|  | 21 | struct pci_dev *dev; | 
|  | 22 | struct list_head *devices_link; | 
|  | 23 |  | 
|  | 24 | list_for_each(devices_link, &(current_bus->devices)) { | 
|  | 25 | dev = pci_dev_b(devices_link); | 
|  | 26 | if (dev != NULL) { | 
|  | 27 | dev->irq = irq++; | 
|  | 28 |  | 
|  | 29 | /* Assign an interrupt number for the device */ | 
|  | 30 | pci_write_config_byte(dev, PCI_INTERRUPT_LINE, irq); | 
|  | 31 | pcibios_set_master(dev); | 
|  | 32 | } | 
|  | 33 | } | 
|  | 34 | } |