Use common function for setting the revision strings.
}
/* b1.c */
+void b1_set_revision(struct capi_driver *driver, char *rev);
avmcard *b1_alloc_card(int nr_controllers);
void b1_free_card(avmcard *card);
int b1_detect(unsigned int base, enum avmcardtype cardtype);
long rsize, long ssize);
void avmcard_dma_free(avmcard_dmainfo *);
-
/* b1dma.c */
int b1pciv4_detect(avmcard *card);
int t1pci_detect(avmcard *card);
/* ------------------------------------------------------------- */
+void b1_set_revision(struct capi_driver *driver, char *rev)
+{
+ char *p;
+
+ if ((p = strchr(rev, ':')) != 0 && p[1]) {
+ strncpy(driver->revision, p + 2, sizeof(driver->revision));
+ driver->revision[sizeof(driver->revision)-1] = 0;
+ if ((p = strchr(driver->revision, '$')) != 0 && p > driver->revision)
+ *(p-1) = 0;
+ }
+ printk(KERN_INFO "%s: revision %s\n", driver->name, driver->revision);
+}
+
+/* ------------------------------------------------------------- */
+
avmcard *b1_alloc_card(int nr_controllers)
{
avmcard *card;
EXPORT_SYMBOL(b1_irq_table);
+EXPORT_SYMBOL(b1_set_revision);
EXPORT_SYMBOL(b1_alloc_card);
EXPORT_SYMBOL(b1_free_card);
EXPORT_SYMBOL(b1_detect);
static int __init b1isa_init(void)
{
- struct capi_driver *driver = &b1isa_driver;
- char *p;
-
MOD_INC_USE_COUNT;
- if ((p = strchr(revision, ':')) != 0 && p[1]) {
- strncpy(driver->revision, p + 2, sizeof(driver->revision));
- driver->revision[sizeof(driver->revision)-1] = 0;
- if ((p = strchr(driver->revision, '$')) != 0 && p > driver->revision)
- *(p-1) = 0;
- }
-
- printk(KERN_INFO "%s: revision %s\n", driver->name, driver->revision);
+ b1_set_revision(&b1isa_driver, revision);
+ attach_capi_driver(&b1isa_driver);
- attach_capi_driver(driver);
MOD_DEC_USE_COUNT;
return 0;
}
static int __init b1pci_init(void)
{
- struct capi_driver *driver = &b1pci_driver;
-#ifdef CONFIG_ISDN_DRV_AVMB1_B1PCIV4
- struct capi_driver *driverv4 = &b1pciv4_driver;
-#endif
- char *p;
int retval;
MOD_INC_USE_COUNT;
- if ((p = strchr(revision, ':')) != 0 && p[1]) {
- strncpy(driver->revision, p + 2, sizeof(driver->revision));
- driver->revision[sizeof(driver->revision)-1] = 0;
- if ((p = strchr(driver->revision, '$')) != 0 && p > driver->revision)
- *(p-1) = 0;
- }
-#ifdef CONFIG_ISDN_DRV_AVMB1_B1PCIV4
- if ((p = strchr(revision, ':')) != 0 && p[1]) {
- strncpy(driverv4->revision, p + 2, sizeof(driverv4->revision));
- driverv4->revision[sizeof(driverv4->revision)-1] = 0;
- if ((p = strchr(driverv4->revision, '$')) != 0 && p > driverv4->revision)
- *(p-1) = 0;
- }
-#endif
-
- printk(KERN_INFO "%s: revision %s\n", driver->name, driver->revision);
-
- attach_capi_driver(driver);
+ b1_set_revision(&b1pci_driver, revision);
+ attach_capi_driver(&b1pci_driver);
#ifdef CONFIG_ISDN_DRV_AVMB1_B1PCIV4
- printk(KERN_INFO "%s: revision %s\n", driverv4->name, driverv4->revision);
-
- attach_capi_driver(driverv4);
+ b1_set_revision(&b1pciv4_driver, revision);
+ attach_capi_driver(&b1pciv4_driver);
#endif
retval = pci_module_init(&b1pci_pci_driver);
goto err;
printk(KERN_INFO "%s: %d B1-PCI card(s) detected\n",
- driver->name, retval);
+ b1pci_driver.name, retval);
retval = 0;
goto out;
err:
- detach_capi_driver(driver);
+ detach_capi_driver(&b1pci_driver);
#ifdef CONFIG_ISDN_DRV_AVMB1_B1PCIV4
- detach_capi_driver(driverv4);
+ detach_capi_driver(&b1pciv4_driver);
#endif
out:
MOD_DEC_USE_COUNT;
- return -ENODEV;
+ return retval;
}
static void __exit b1pci_exit(void)
{
pci_unregister_driver(&b1pci_pci_driver);
+
detach_capi_driver(&b1pci_driver);
#ifdef CONFIG_ISDN_DRV_AVMB1_B1PCIV4
detach_capi_driver(&b1pciv4_driver);
static int __init b1pcmcia_init(void)
{
- struct capi_driver *driver = &b1pcmcia_driver;
- char *p;
- int retval = 0;
-
MOD_INC_USE_COUNT;
- if ((p = strchr(revision, ':')) != 0 && p[1]) {
- strncpy(driver->revision, p + 2, sizeof(driver->revision));
- driver->revision[sizeof(driver->revision)-1] = 0;
- if ((p = strchr(driver->revision, '$')) != 0 && p > driver->revision)
- *(p-1) = 0;
- }
-
- printk(KERN_INFO "%s: revision %s\n", driver->name, driver->revision);
-
- attach_capi_driver(driver);
+ b1_set_revision(&b1pcmcia_driver, revision);
+ attach_capi_driver(&b1pcmcia_driver);
MOD_DEC_USE_COUNT;
- return retval;
+ return 0;
}
static void __exit b1pcmcia_exit(void)
add_card: 0, /* no add_card function */
};
-static void c4_attach_driver (struct capi_driver * driver)
-{
- char *p;
- if ((p = strchr(revision, ':')) != 0 && p[1]) {
- strncpy(driver->revision, p + 2, sizeof(driver->revision));
- driver->revision[sizeof(driver->revision)-1] = 0;
- if ((p = strchr(driver->revision, '$')) != 0 && p > driver->revision)
- *(p-1) = 0;
- }
-
- printk(KERN_INFO "%s: revision %s\n", driver->name, driver->revision);
-
- attach_capi_driver(driver);
-}
-
static int __devinit c4_probe(struct pci_dev *dev,
const struct pci_device_id *ent)
{
MOD_INC_USE_COUNT;
- c4_attach_driver (&c4_driver);
- c4_attach_driver (&c2_driver);
+ b1_set_revision(&c2_driver, revision);
+ attach_capi_driver(&c2_driver);
+
+ b1_set_revision(&c4_driver, revision);
+ attach_capi_driver(&c4_driver);
retval = pci_module_init(&c4_pci_driver);
if (retval < 0)
static int __init t1isa_init(void)
{
- struct capi_driver *driver = &t1isa_driver;
- char *p;
- int retval = 0;
-
MOD_INC_USE_COUNT;
- if ((p = strchr(revision, ':')) != 0 && p[1]) {
- strncpy(driver->revision, p + 2, sizeof(driver->revision));
- driver->revision[sizeof(driver->revision)-1] = 0;
- if ((p = strchr(driver->revision, '$')) != 0 && p > driver->revision)
- *(p-1) = 0;
- }
-
- printk(KERN_INFO "%s: revision %s\n", driver->name, driver->revision);
-
- attach_capi_driver(driver);
+ b1_set_revision(&t1isa_driver, revision);
+ attach_capi_driver(&t1isa_driver);
MOD_DEC_USE_COUNT;
- return retval;
+ return 0;
}
static void __exit t1isa_exit(void)
{
- detach_capi_driver(&t1isa_driver);
+ detach_capi_driver(&t1isa_driver);
}
module_init(t1isa_init);
static int __init t1pci_init(void)
{
- struct capi_driver *driver = &t1pci_driver;
- char *p;
int retval;
MOD_INC_USE_COUNT;
- if ((p = strchr(revision, ':')) != 0 && p[1]) {
- strncpy(driver->revision, p + 2, sizeof(driver->revision) - 1);
- if ((p = strchr(driver->revision, '$')) != 0 && p > driver->revision)
- *(p-1) = 0;
- }
-
- printk(KERN_INFO "%s: revision %s\n", driver->name, driver->revision);
-
+ b1_set_revision(&t1pci_driver, revision);
attach_capi_driver(&t1pci_driver);
retval = pci_register_driver(&t1pci_pci_driver);
goto err;
printk(KERN_INFO "%s: %d T1-PCI card(s) detected\n",
- driver->name, retval);
+ t1pci_driver.name, retval);
retval = 0;
goto out;