1.并发是指多个执行单元同时、并行的执行。并发的执行单元对共享资源的访问很容易导致竞态。

在 Linux 内核中,主要的竞态发生于如下几种情况:

①对称多处理器(SMP)的多个 CPU

②单CPU内进程与抢占它的进程

③中断(硬中断、软中断、Tasklet、底半部)与进程之间

2.解决竞态的方法

中断屏蔽

中断屏蔽的使用方法为:

local_irq_disable() //屏蔽中断

critical section //临界区

local_irq_enable() //开中断

原子操作:原子操作指的是在执行过程中不会被别的代码路径所中断的操作。

void atomic_set(atomic_t *v, int i); //设置原子变量的值为 i

atomic_read(atomic_t *v);//读取原子变量的值

void atomic_add(int i,atomic_t *v);//原子变量加i

void atomic_sub(int i,atomic_t *v);//原子变量减i

void atomic_inc(atomic_t *v);//自加

void atomic_dec(atomic_t *v);//自减

操作并测试

int atomic_inc_and_test(atomic_t *v);

int atomic_dec_and_test(atomic_t *v);

int atomic_sub_and_test(int i, atomic_t *v);

上述操作对原子变量执行自增、自减和减操作后(注意没有加)测试其是否为 0,为 0 则返回 true,否则返回 false。

位原子操作

void set_bit(nr,void *addr);//设置位,nr为地址的第nr位

void clear_bit(nr,void *addr);//清除位

void change_bit(nr, void *addr);//改变位

test_bit(nr, void *addr);//测试位

自旋锁:一种对临界资源进行互斥手访问的典型手段.、

spinlock_t spin;//自定义自旋锁

spin_lock_init(lock);//初始化

spin_lock(lock)//获得自旋锁、

spin_unlock(lock)//释放自旋锁

驱动工程师应谨慎使用自旋锁,而且在使用中还要特别注意 自旋锁实际上是忙等锁,自旋锁可能导致系统死锁 这两个问题.

读写自旋锁

rwlock_t lock;//定义rwlock

rwlock_init(&lock);//初始化

read_lock(&lock);//读时获取锁

read_ulock(&lock);//

write_lock_irqsave(&lock, flags);//写时获取锁
write_unlock_irqrestore(&lock, flags);

顺序锁:顺序锁(seqlock)是对读写锁的一种优化,若使用顺序锁,读执行单元绝不会被写执行单元阻塞------略

信号量的使用:与自旋锁不同的是,当获取不到信号量时,进程不会原地打转而是进入休眠等待状态。

struct semaphore sem;//定义信号量

void sema_init(struct semaphore *sem,int var);//初始化信号量

void down(struct semaphore * sem);//获取信号量、进入睡眠状态的进程不能被信号打断

void up(struct semaphore * sem);//释放信号量

完成量用于同步

struct completion my_completion;//定义完成量

init_completion(&my_completion);//初始化完成量

void wait_for_completion(struct completion *c);//等待完成量

void complete_all(struct completion *c);//唤醒完成量

信号量vs自旋锁

信号量是进程间用于对资源的互斥,如果竞争失败,进程进入睡眠状态

自旋锁访问时间要短,节省上下文切换的时间。CPU得不到自旋锁不停止。

11互斥体

struct mutex my_mutex;//定义

mutex_init(&my_mutex);//初始化

mutex_lock(&my_mutex); //获取 mutex、

mutex_unlock(&my_mutex); //释放 mutex

Linux设备驱动中的并发控制的更多相关文章

  1. 蜕变成蝶~Linux设备驱动中的并发控制

    并发和竞争发生在两类体系中: 对称多处理器(SMP)的多个CPU 内核可抢占的单CPU系统 访问共享资源的代码区域称为临界区(critical sections),临界区需要以某种互斥机制加以保护.在 ...

  2. linux设备驱动中的并发控制【转】

    转自:http://www.cnblogs.com/plinx/archive/2013/01/28/2873121.html 在linux内核中,主要的静态发生于以下几种情况: 1.对称多处理器(S ...

  3. Linux设备驱动中的阻塞和非阻塞I/O

    [基本概念] 1.阻塞 阻塞操作是指在执行设备操作时,托不能获得资源,则挂起进程直到满足操作所需的条件后再进行操作.被挂起的进程进入休眠状态(不占用cpu资源),从调度器的运行队列转移到等待队列,直到 ...

  4. 蜕变成蝶~Linux设备驱动中的阻塞和非阻塞I/O

    今天意外收到一个消息,真是惊呆我了,博客轩给我发了信息,说是俺的博客文章有特色可以出本书,,这简直让我受宠若惊,俺只是个大三的技术宅,写的博客也是自己所学的一些见解和在网上看到我一些博文以及帖子里综合 ...

  5. Linux设备驱动中的阻塞和非阻塞I/O <转载>

    Green 博客园 首页 新随笔 联系 订阅 管理 Linux设备驱动中的阻塞和非阻塞I/O   [基本概念] 1.阻塞 阻塞操作是指在执行设备操作时,托不能获得资源,则挂起进程直到满足操作所需的条件 ...

  6. Linux设备驱动中的IO模型---阻塞和非阻塞IO【转】

    在前面学习网络编程时,曾经学过I/O模型 Linux 系统应用编程——网络编程(I/O模型),下面学习一下I/O模型在设备驱动中的应用. 回顾一下在Unix/Linux下共有五种I/O模型,分别是: ...

  7. Linux设备驱动中的软件架构思想

    目录 更新记录 一.Linux驱动的软件架构 1.1 出发点 1.2 分离思想 1.3 分层思想 二.platform设备驱动 2.1 platform设备 2.2 platform驱动 2.3 pl ...

  8. Linux设备驱动中的异步通知与异步I/O

    异步通知概念: 异步通知的意识是,一旦设备就绪,则主动通知应用程序,这样应用程序根本就不需要查询设备状态,这一点非常类似于硬件上的“中断”概念,比较准确的称谓是“信号驱动的异步IO”,信号是在软件层次 ...

  9. Linux设备驱动中的ioctl

    memdev.h #ifndef _MEMDEV_H #define _MEMDEV_H #define MEM_MAGIC 'm' #define MEM_RESTART _IO(MEM_MAGIC ...

随机推荐

  1. transform原点

    Safari 4 Firefox3.5 Opera10.5 Chrome Internet Explorer 目前这两个属性得到了除去ie以外各个主流浏览器webkit,firefox,opera的支 ...

  2. 从NSGA到 NSGA II

    NSGA(非支配排序遗传算法).NSGAII(带精英策略的非支配排序的遗传算法),都是基于遗传算法的多目标优化算法,都是基于pareto最优解讨论的多目标优化,遗传算法已经做过笔记,下面介绍paret ...

  3. javascript中的自增与自减

    一直都对自增与自减的执行顺序有点糊涂,今天查了资料,来总结一下 a++(a--),就是指当时计算a,当下一次使用这个变量的时候才执行++或者-- ++a(--a),就是指当时就计算++或者-- 例1: ...

  4. oracle 面试题

    1.对数据库SQL2005.ORACLE熟悉吗?   SQL2005是微软公司的数据库产品.是一个RDBMS数据库,一般应用在一些中型数据库的应用,不能跨平台.   ORACLE是ORACLE公司的数 ...

  5. Python之反射

    一.引言 有时候我们会碰到类似这样的需求,就是想要执行类的某个方法,或者需要对对象的某个参数赋值,而方法名或参数名已经包装在类中并不能去顶,需要通过参数传递字符串的形式输入.在这样的情况你会选择什么样 ...

  6. 移动端网站的内容触摸滑动-Swiper插件

    手机平板等大多移动端站点都会有触摸滑动内容的功能,公司移动端站点(m.muzhiwan.com)的标题广告滑动以及轮播效果就是用的Swiper插件. Swiper就是常用于移动端网站的内容触摸滑动的一 ...

  7. javascript 设计模式2----策略模式

    1.定义:定义一系类的算法,把它们一个个封装起来,并且使它们可以相互替换 2.解释:就是把算法和一个规则单独分封,在使用时单独调用. 简单例子: var strategies = { "S& ...

  8. Flowplayer-Skin

    SOURCE URL: https://flowplayer.org/docs/skinning.html Skinning with CSS3 Flowplayer skin design is C ...

  9. file以及文件大小转化问题

    android 获取文件夹.文件的大小 以B.KB.MB.GB 为单位             public class FileSizeUtil { public static final int ...

  10. linux文件上传,给文件或目录添加apache权限

    系统环境:ubuntu11.10/apache2/php5.3.6 在LAMP环境中,测试一个简单的php文件上传功能时,发现/var/log/apache2/error.log中出现如下php警告: ...