X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=drivers%2Fisdn%2Fdivert%2Fdivert_init.c;h=2f7c9fc2e898b5d52fc20b628b1d4d5a7d7fac31;hb=43bc926fffd92024b46cafaf7350d669ba9ca884;hp=ede2b7eb75ea129c13088a209f1a0894803a2403;hpb=5273a3df6485dc2ad6aa7ddd441b9a21970f003b;p=linux-2.6.git diff --git a/drivers/isdn/divert/divert_init.c b/drivers/isdn/divert/divert_init.c index ede2b7eb7..2f7c9fc2e 100644 --- a/drivers/isdn/divert/divert_init.c +++ b/drivers/isdn/divert/divert_init.c @@ -10,19 +10,15 @@ */ #include -#include #include +#include + #include "isdn_divert.h" MODULE_DESCRIPTION("ISDN4Linux: Call diversion support"); MODULE_AUTHOR("Werner Cornelius"); MODULE_LICENSE("GPL"); -/********************/ -/* needed externals */ -/********************/ -extern int printk(const char *fmt,...); - /****************************************/ /* structure containing interface to hl */ /****************************************/ @@ -59,23 +55,23 @@ static int __init divert_init(void) /* Module deinit code */ /**********************/ static void __exit divert_exit(void) -{ unsigned long flags; +{ + unsigned long flags; int i; - save_flags(flags); - cli(); + spin_lock_irqsave(&divert_lock, flags); divert_if.cmd = DIVERT_CMD_REL; /* release */ if ((i = DIVERT_REG_NAME(&divert_if)) != DIVERT_NO_ERR) { printk(KERN_WARNING "dss1_divert: error %d releasing module\n",i); - restore_flags(flags); + spin_unlock_irqrestore(&divert_lock, flags); return; } if (divert_dev_deinit()) { printk(KERN_WARNING "dss1_divert: device busy, remove cancelled\n"); - restore_flags(flags); + spin_unlock_irqrestore(&divert_lock, flags); return; } - restore_flags(flags); + spin_unlock_irqrestore(&divert_lock, flags); deleterule(-1); /* delete all rules and free mem */ deleteprocs(); printk(KERN_INFO "dss1_divert module successfully removed \n");