函数atomic_dec_and_test()的功能是将原子类型的变量v的值原子地递减1,并判断执行该操作后v的值是否为0。
atomic_dec_and_test文件包含
#include <asm/atomic.h>
atomic_dec_and_test函数定义
在内核源码中的位置:linux-3.19.3/arch/x86/include/asm/atomic.h
函数定义格式:
static inline int atomic_dec_and_test(atomic_t *v)
atomic_dec_and_test输入参数说明
v
:原子类型变量指针。关于原子类型atomic_t的定义参考极客笔记网atomic_set()函数的分析。
atomic_dec_and_test返回参数说明
- 函数atomic_dec_and_test()返回一个整型值,如果原子类型v在减1后变为0,则返回1,否则返回0。
atomic_dec_and_test实例解析
编写测试文件:atomic_dec_and_test.c
头文件及全局变量声明如下:
#include <linux/types.h>
#include <linux/init.h>
#include <linux/module.h>
MODULE_LICENSE("GPL");
static int __init atomic_dec_and_test_init(void);
static void __exit atomic_dec_and_test_exit(void);
atomic_t my_atomic ;
模块初始化函数:
int __init atomic_dec_and_test_init(void)
{
int ret, num;
ret = num = 0;
atomic_set( &my_atomic, 3 );
printk("after atomic_set, my_atomic.counter = %d\n", atomic_read( &my_atomic));
/*将原子类型的变量my_atomic原子地减去1*/
while( ( ret = atomic_dec_and_test( &my_atomic ) ) == 0 )
{
num ++ ;
}
printk("num = %d\n", num);
return 0;
}
模块退出函数:
void __exit atomic_dec_and_test_exit(void)
{
printk("exit! \n");
}
模块初始化及退出函数调用:
module_init(atomic_dec_and_test_init);
module_exit(atomic_dec_and_test_exit);
实例运行结果及分析:
首先编译模块,执行命令insmod atomic_dec_and_test.ko插入模块,然后执行命令dmesg -c,会出现如图所示的结果。
结果分析:
测试程序中调用了函数atomic_set()和函数atomic_read(),关于其功能参考极客笔记网关于它们的分析。
首先定义一个原子类型my_atomic,调用函数atomic_set()将其值设置为3,并通过函数atomic_read()将原子类型my_atomic的counter字段读出为3。然后在一个while循环中调用函数atomic_dec_and_test()将my_atomic的值递减1,并判断其值是否变为0。由输出信息可知,num = 2,即循环体中执行了两次,这是因为在第三次减1操作后,my_atomic的值变为0,函数atomic_dec_and_test()返回1,循环体中将不再执行。