1 --- driver/modules/hostap_pci.c.orig 2004-11-30 06:41:48.000000000 +0100
2 +++ driver/modules/hostap_pci.c 2005-01-17 19:47:33.710400496 +0100
7 +#define DEFERRED_IRQ_INITIALIZATION
9 +#ifdef DEFERRED_IRQ_INITIALIZATION
10 +struct net_device *devb[MAX_PARM_DEVICES];
14 #ifdef PRISM2_IO_DEBUG
16 static inline void hfa384x_outb_debug(struct net_device *dev, int a, u8 v)
19 pci_set_drvdata(pdev, dev);
21 +#ifdef DEFERRED_IRQ_INITIALIZATION
22 + printk("%s: deferred initialization of IRQs\n", dev_info);
23 + devb[cards_found-1] = dev;
25 if (request_irq(dev->irq, prism2_interrupt, SA_SHIRQ, dev->name,
27 printk(KERN_WARNING "%s: request_irq failed\n", dev->name);
30 printk(KERN_INFO "%s: Intersil Prism2.5 PCI: "
31 "mem=0x%lx, irq=%d\n", dev->name, phymem, dev->irq);
34 return hostap_hw_ready(dev);
41 +#ifdef DEFERRED_IRQ_INITIALIZATION
42 +static void deferred_init(int num_devices)
45 + for (n=0; n<num_devices && n<MAX_PARM_DEVICES; n++)
47 + if (request_irq(devb[n]->irq, prism2_interrupt, SA_SHIRQ, devb[n]->name,
49 + printk(KERN_WARNING "%s: request_irq failed\n", devb[n]->name);
51 + if (prism2_hw_config(devb[n], 1)) {
52 + printk(KERN_DEBUG "%s: hardware initialization failed\n", devb[n]->name)
55 + printk(KERN_INFO "%s: Intersil Prism2.5 PCI: irq=%d\n", devb[n]->name, devb[n]->
61 static int __init init_prism2_pci(void)
63 printk(KERN_INFO "%s: %s\n", dev_info, version);
65 #if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10))
66 - if (pci_register_driver(&prism2_pci_drv_id) <= 0) {
68 + if ((n=pci_register_driver(&prism2_pci_drv_id)) <= 0) {
69 printk("hostap_pci: No devices found, driver not "
71 pci_unregister_driver(&prism2_pci_drv_id);
75 +#ifdef DEFERRED_IRQ_INITIALIZATION
81 return pci_register_driver(&prism2_pci_drv_id);