atomic原子操作
1、前言
上一篇文章说到了Linux是多任务的操作系统,所以有可能会存在多个应用程序使用到同一个驱动程序,那么如果不加以任何控制的话,就有可能会导致一些错误的结果。
针对这些问题,内核早就有所准备,内核里面提供了原子操作、自旋锁、互斥锁、信号量等方案,这里的锁和信号量和应用层的线程同步使用的有点类似,这篇文章就先在上一篇LED的驱动上添加原子操作,锁和信号量后面文章接着讲。
2、atomic原子操作是什么
2.1 作用
原子操作就是通过原子变量的值来控制程序的访问,比如通过对原子变量的值进行加1或者减1来判断,每个程序操作的时候都会对它进行判断一下是否有程序已经在使用了,如果已经在使用了,为避免多个程序的同时操作,就直接退出了。
既然是通过加1或减1来控制,那么和普通的变量有什么区别呢?那必须有,要不然也不叫原子变量。原子操作的意思就是不能再进一步分割的操作,而普通变量的赋值操作在编译时的汇编代码是会被分成三个步骤,每个步骤都有可能会被打断,所以原子操作就适合这种情景。
简而言之,使用原子变量可以控制一个设备同一时间只能有一个程序在使用。
2.2 定义
2.2.1 原子变量的定义:include/linux/types.h