static int set_debug(const char *val, struct kernel_param *kp) { int ret; struct sfax_hw *card; ret = param_set_uint(val, kp); if (!ret) { read_lock(&card_lock); list_for_each_entry(card, &Cards, list) _set_debug(card); read_unlock(&card_lock); } return ret; }
static int __devinit setup_instance(struct sfax_hw *card) { const struct firmware *firmware; int i, err; u_long flags; snprintf(card->name, MISDN_MAX_IDLEN - 1, "Speedfax.%d", sfax_cnt + 1); write_lock_irqsave(&card_lock, flags); list_add_tail(&card->list, &Cards); write_unlock_irqrestore(&card_lock, flags); _set_debug(card); spin_lock_init(&card->lock); card->isac.hwlock = &card->lock; card->isar.hwlock = &card->lock; card->isar.ctrl = (void *)&sfax_ctrl; card->isac.name = card->name; card->isar.name = card->name; card->isar.owner = THIS_MODULE; err = request_firmware(&firmware, "isdn/ISAR.BIN", &card->pdev->dev); if (err < 0) { pr_info("%s: firmware request failed %d\n", card->name, err); goto error_fw; } if (debug & DEBUG_HW) pr_notice("%s: got firmware %zu bytes\n", card->name, firmware->size); mISDNisac_init(&card->isac, card); card->isac.dch.dev.D.ctrl = sfax_dctrl; card->isac.dch.dev.Bprotocols = mISDNisar_init(&card->isar, card); for (i = 0; i < 2; i++) { set_channelmap(i + 1, card->isac.dch.dev.channelmap); list_add(&card->isar.ch[i].bch.ch.list, &card->isac.dch.dev.bchannels); } err = setup_speedfax(card); if (err) goto error_setup; err = card->isar.init(&card->isar); if (err) goto error; err = mISDN_register_device(&card->isac.dch.dev, &card->pdev->dev, card->name); if (err) goto error; err = init_card(card); if (err) goto error_init; err = card->isar.firmware(&card->isar, firmware->data, firmware->size); if (!err) { release_firmware(firmware); sfax_cnt++; pr_notice("SpeedFax %d cards installed\n", sfax_cnt); return 0; } disable_hwirq(card); free_irq(card->irq, card); error_init: mISDN_unregister_device(&card->isac.dch.dev); error: release_region(card->cfg, 256); error_setup: card->isac.release(&card->isac); card->isar.release(&card->isar); release_firmware(firmware); error_fw: pci_disable_device(card->pdev); write_lock_irqsave(&card_lock, flags); list_del(&card->list); write_unlock_irqrestore(&card_lock, flags); kfree(card); return err; }
static int setup_instance(struct w6692_hw *card) { int i, err; u_long flags; snprintf(card->name, MISDN_MAX_IDLEN - 1, "w6692.%d", w6692_cnt + 1); write_lock_irqsave(&card_lock, flags); list_add_tail(&card->list, &Cards); write_unlock_irqrestore(&card_lock, flags); card->fmask = (1 << w6692_cnt); _set_debug(card); spin_lock_init(&card->lock); mISDN_initdchannel(&card->dch, MAX_DFRAME_LEN_L1, W6692_ph_bh); card->dch.dev.Dprotocols = (1 << ISDN_P_TE_S0); card->dch.dev.D.send = w6692_l2l1D; card->dch.dev.D.ctrl = w6692_dctrl; card->dch.dev.Bprotocols = (1 << (ISDN_P_B_RAW & ISDN_P_B_MASK)) | (1 << (ISDN_P_B_HDLC & ISDN_P_B_MASK)); card->dch.hw = card; card->dch.dev.nrbchan = 2; for (i = 0; i < 2; i++) { mISDN_initbchannel(&card->bc[i].bch, MAX_DATA_MEM); card->bc[i].bch.hw = card; card->bc[i].bch.nr = i + 1; card->bc[i].bch.ch.nr = i + 1; card->bc[i].bch.ch.send = w6692_l2l1B; card->bc[i].bch.ch.ctrl = w6692_bctrl; set_channelmap(i + 1, card->dch.dev.channelmap); list_add(&card->bc[i].bch.ch.list, &card->dch.dev.bchannels); } err = setup_w6692(card); if (err) goto error_setup; err = mISDN_register_device(&card->dch.dev, &card->pdev->dev, card->name); if (err) goto error_reg; err = init_card(card); if (err) goto error_init; err = create_l1(&card->dch, w6692_l1callback); if (!err) { w6692_cnt++; pr_notice("W6692 %d cards installed\n", w6692_cnt); return 0; } free_irq(card->irq, card); error_init: mISDN_unregister_device(&card->dch.dev); error_reg: release_region(card->addr, 256); error_setup: mISDN_freebchannel(&card->bc[1].bch); mISDN_freebchannel(&card->bc[0].bch); mISDN_freedchannel(&card->dch); write_lock_irqsave(&card_lock, flags); list_del(&card->list); write_unlock_irqrestore(&card_lock, flags); kfree(card); return err; }