函数:module_put ( )【转】
转自:http://book.2cto.com/201307/27049.html
文件包含:
#include <linux/module.h>
函数定义:
函数在内核源码中的位置:linux-2.6.30/kernel/module.c
函数定义格式:void module_put(struct module *module)
函数功能描述:
该函数的功能是将一个特定模块module的引用计数减1 ,这样当一个模块的引用计数因为不为0而不能从内核中卸载时,可以调用此函数一次或多次,实现对模块计数的清零,从而实现模块卸载。
输入参数说明:
module:指向模块结构体的指针,结构体中包含模块的名称、状态、所属的模块链表等。关
于结构体struct module 的定义,请参见本章中find_module( ) 函数的分析。
返回参数说明:
该函数没有返回值。
实例解析:
编写测试文件:module_put.c
头文件及全局变量声明如下:
#include <linux/module.h>
#include <linux/init.h>
MODULE_LICENSE("GPL");
static int __init module_put_init(void);
static void __exit module_put_exit(void);
模块加载函数:
int __init module_put_init(void)
{
const char *name = "test_module"; //定义待查找的模块名为"test_module"
struct module * fmodule = find_module( name ); //调用查找模块函数
if( fmodule != NULL )
{
/*调用module_put( )函数之前,输出模块test_moudule的引用计数*/
printk("<0>before calling module_put,\n");
printk("<0>refs of %s is: %d\n",name,module_refcount(fmodule));
module_put(fmodule); // 调用module_put( )函数
/*调用module_put( )函数之前,输出模块test_moudule的引用计数*/
printk("<0>after calling module_put,\n");
printk("<0>refs of %s is: %d\n",name,module_refcount(fmodule));
}
else
{
printk("<0>find %s failed!",name);
}
return 0;
}
模块退出函数:
void __exit module_put_exit(void)
{
printk("<0>module exit ok!\n");
}
模块加载、退出函数调用:
module_init(module_put_init);
module_exit(module_put_exit);
实例运行结果及分析:
首先执行命令lsmod | head -4 ,然后编译模块,执行命令insmod module_put.ko 插入模块,再执行命令dmesg -c ,将出现如图2-17 所示的结果。
结果分析:
在该测试程序中,首先通过“lsmod | head -4 ”命令获取一些模块的信息,这里主要关注模块“test_module ”,该模块是笔者动态插入的模块。在图2-17中上方的白色部分,可以看到模块“test_module ”的引用计数为1 。
然后测试module_put( )函数的功能。首先调用find_module( ) 内核函数查找名为“test_module”的模块,查找模块返回不为空后,再调用module_put( ) 函数实现对模块“test_module ”的引用计数减1 。图2-17中的黑色部分为运行结果,从中可以看到,在调用module_put( )之前,引用计数为1 ,调用module_put( )之后,模块“test_module”的引用计数因减1 而变为了0 。
最后,再通过“lsmod | head -4 ”命令获取模块“test_module ”的信息,从图2-17 中下方白色部分的显示结果可知,模块“test_module”的引用计数确实变为了0 。
实例程序中调用了函数find_module( ) 和函数module_refcount( )。函数find_module( ) 是根据模块名查找模块并返回查找到的模块,函数module_refcount( )则是用来获得模块被引用的次数。关于这两个函数的详细说明见本章中关于它们的分析。
函数:module_put ( )【转】的更多相关文章
- Python 小而美的函数
python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况 any any(iterable) ...
- 探究javascript对象和数组的异同,及函数变量缓存技巧
javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...
- JavaScript权威指南 - 函数
函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...
- C++对C的函数拓展
一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...
- 菜鸟Python学习笔记第一天:关于一些函数库的使用
2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...
- javascript中的this与函数讲解
前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...
- 复杂的 Hash 函数组合有意义吗?
很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...
- JS核心系列:浅谈函数的作用域
一.作用域(scope) 所谓作用域就是:变量在声明它们的函数体以及这个函数体嵌套的任意函数体内都是有定义的. function scope(){ var foo = "global&quo ...
- C++中的时间函数
C++获取时间函数众多,何时该用什么函数,拿到的是什么时间?该怎么用?很多人都会混淆. 本文是本人经历了几款游戏客户端和服务器开发后,对游戏中时间获取的一点总结. 最早学习游戏客户端时,为了获取最精确 ...
随机推荐
- C++内置类型如何存放于计算机内存中
摘要:内置类型的机器实现.字/字节/比特.内存 一.概念 计算机以比特序列存储数据,每个比特非0即1,如:00011011011100010110010000111011... 二.计算机以块来处理内 ...
- DFS——CodeForces740DAlyona and a tree
一.题目回顾 题目链接:Alyona and a tree Examples Input 52 5 1 4 61 71 13 53 6 Output 1 0 1 0 0 Input 59 7 8 ...
- 对TDD的实践感悟
文章:我的TDD实践:可测试性驱动开发(上) 文章表达的思想是,达到一个目的并非只有一种套路,作者用写代码时,时刻考虑代码的可测试性,来推动项目的合理开发.
- 个人作业4——alpha阶段个人总结(201521123103 吴雅娟)
一.个人总结 在alpha 结束之后, 每位同学写一篇个人博客, 总结自己的alpha 过程: 请用自我评价表:http://www.cnblogs.com/xinz/p/3852177.html 有 ...
- 使用emit发出信号
1. 信号声明 在发送信号的模块类头文件中声明信号函数 signals: void sendRate(QString rate); 2. 在发送模块的成员函数中发出信号 emit sendRate(u ...
- WCF身份验证二:基于消息安全模式的自定义身份验证
使用X509证书进行身份验证应该说是WCF安全模型中最”正常”的做法, 因为WCF强制要求使用证书加密身份数据, 离开了证书, 所有的身份验证机制拒绝工作, WCF支持的身份验证机制也相当复杂, 这里 ...
- JavaScript页面跳转
<%@ page contentType="text/html;charset=UTF-8" language="java" pageEncoding=& ...
- 【bzoj2384】[Ceoi2011]Match 特殊匹配条件的KMP+树状数组
题目描述 给出两个长度分别为n.m的序列A.B,求出B的所有长度为n的连续子序列(子串),满足:序列中第i小的数在序列的Ai位置. 输入 第一行包含两个整数n, m (2≤n≤m≤1000000). ...
- [bzoj1052] [HAOI2007]覆盖问题
Description 某人在山上种了N棵小树苗.冬天来了,温度急速下降,小树苗脆弱得不堪一击,于是树主人想用一些塑料薄膜把这些小树遮盖起来,经过一番长久的思考,他决定用3个L * L的正方形塑料薄膜 ...
- 《软件调试的艺术》学习笔记——GDB使用技巧摘要
<软件调试的艺术>学习笔记——GDB使用技巧摘要 <软件调试的艺术>,因为名是The Art of Debugging with GDB, DDD, and Eclipse. ...