module_param_named(wc_pat, qib_wc_pat, uint, S_IRUGO);
MODULE_PARM_DESC(wc_pat, "enable write-combining via PAT mechanism");
-struct workqueue_struct *qib_cq_wq;
-
static void verify_interrupt(unsigned long);
static struct idr qib_unit_table;
dd->intrchk_timer.function = verify_interrupt;
dd->intrchk_timer.data = (unsigned long) dd;
+ ret = qib_cq_init(dd);
done:
return ret;
}
if (ret)
goto bail;
- qib_cq_wq = create_singlethread_workqueue("qib_cq");
- if (!qib_cq_wq) {
- ret = -ENOMEM;
- goto bail_dev;
- }
-
/*
* These must be called before the driver is registered with
* the PCI subsystem.
ret = pci_register_driver(&qib_driver);
if (ret < 0) {
pr_err("Unable to register driver: error %d\n", -ret);
- goto bail_unit;
+ goto bail_dev;
}
/* not fatal if it doesn't work */
pr_err("Unable to register ipathfs\n");
goto bail; /* all OK */
-bail_unit:
+bail_dev:
#ifdef CONFIG_INFINIBAND_QIB_DCA
dca_unregister_notify(&dca_notifier);
#endif
idr_destroy(&qib_unit_table);
- destroy_workqueue(qib_cq_wq);
-bail_dev:
qib_dev_cleanup();
bail:
return ret;
#endif
pci_unregister_driver(&qib_driver);
- destroy_workqueue(qib_cq_wq);
-
qib_cpulist_count = 0;
kfree(qib_cpulist);
}
kfree(tmp);
kfree(dd->boardname);
+ qib_cq_exit(dd);
}
/*