强力卸载内核模块(一).doc
文本预览下载声明
内核为2.6.32。
卸载模块target时,不管是否为强制卸载,都输出:
ERROR:Module?target is in use.
用lsmod查看target,发现Used by计数为1,而据我所知,没有其它模块依赖target。
编写模块检查target的module结构,发现:
target-state == 0 // 模块存活
module_refcount(target) == 1 // 模块引用计数为1
list_empty(target-modules_which_use_me) == 1 // 模块依赖列表为空
这个就很奇怪,模块的引用计数为1,却没有引用者。
这可能是模块插入内核时出错而引起的,这里先不研究,先关注怎么把它强制卸载掉,虽然
insmod加载是临时的,所以通过重启电脑可以解决一些问题,但是不能总是依靠重启啊。
解决方法:编写模块mymod中把问题模块target的引用计数置为0,就可以顺利卸载掉target了!
?
代码
?
[java] view plaincopy
#includelinux/init.h??
#includelinux/module.h??
#includelinux/kernel.h??
#includelinux/list.h??
#includelinux/cpumask.h??
??
static?int?__init?mymod_init(void)??
{??
????????struct?module?*mod,*relate;??
????????int?cpu;??
??
????????//?打印本模块的模块名和模块状态??
????????printk(KERN_ALERT[insmod?mymod]?name:%s?state:%d\n,THIS_MODULE-name,THIS_MODULE-state);??
??
???????//?遍历模块列表,查找target模块??
????????list_for_each_entry(mod,THIS_MODULE-list.prev,list)??
????????{??
????????????????if(strcmp(mod-name,target)==0)?{???
??
????????????????????????//?打印target的模块名、模块状态、引用计数??
????????????????????????printk(KERN_ALERTname:%s?state:%d?refcnt:%u?,mod-name,mod-state,module_refcount(mod));??
??
????????????????????????//?打印出所有依赖target的模块名??
????????????????????????if(!list_empty(mod-modules_which_use_me))?{???
????????????????????????????????list_for_each_entry(relate,mod-modules_which_use_me,modules_which_use_me)??
????????????????????????????????????????printk(KERN_ALERT%s?,relate-name);??
????????????????????????}?else??
????????????????????????????????printk(KERN_ALERTused?by?NULL\n);??
??
????????????????????????//?把target的引用计数置为0??
????????????????????????for_each_possible_cpu(cpu)??
????????????????????????????????local_set(__module_ref_addr(mod,cpu),0);??
??
????????????????????????//?再看看target的名称、状态、引用计数??
????????????????????????printk(KERN_ALERTname:%s?state:%d?refcnt:%u\n,mod-name,mod-state,module_refcount(mod));??
????????????????}??
????????}??
????????return?0;??
}??
??
static?void?__exit?mymod_exit(void)??
{??
????????pr
显示全部