1. /*
  2. * These are the generic versions of the spinlocks and read-write
  3. * locks..
  4. *///自旋锁加锁,irqsave表示把标志寄存器存储起来
  5. #define spin_lock_irqsave(lock, flags) do { local_irq_save(flags);//关闭本地中断,保存标志位 spin_lock(lock); } while (0)
  6. #define spin_lock_irq(lock) do { local_irq_disable(); spin_lock(lock); } while (0)
  7. #define spin_lock_bh(lock) do { local_bh_disable(); spin_lock(lock); } while (0)
  8. //读锁与下面写锁,构成读写锁
  9. #define read_lock_irqsave(lock, flags) do { local_irq_save(flags); read_lock(lock); } while (0)
  10. #define read_lock_irq(lock) do { local_irq_disable(); read_lock(lock); } while (0)
  11. #define read_lock_bh(lock) do { local_bh_disable(); read_lock(lock); } while (0)
  12. //写锁,与上面构成读写锁
  13. #define write_lock_irqsave(lock, flags) do { local_irq_save(flags); write_lock(lock); } while (0)
  14. #define write_lock_irq(lock) do { local_irq_disable(); write_lock(lock); } while (0)
  15. #define write_lock_bh(lock) do { local_bh_disable(); write_lock(lock); } while (0)
  16. //自旋锁解锁
  17. #define spin_unlock_irqrestore(lock, flags) do { spin_unlock(lock); local_irq_restore(flags); } while (0)
  18. #define spin_unlock_irq(lock) do { spin_unlock(lock); local_irq_enable(); } while (0)
  19. #define spin_unlock_bh(lock) do { spin_unlock(lock); local_bh_enable(); } while (0)
  20. //读锁解锁
  21. #define read_unlock_irqrestore(lock, flags) do { read_unlock(lock); local_irq_restore(flags); } while (0)
  22. #define read_unlock_irq(lock) do { read_unlock(lock); local_irq_enable(); } while (0)
  23. #define read_unlock_bh(lock) do { read_unlock(lock); local_bh_enable(); } while (0)
  24. //写锁解锁
  25. #define write_unlock_irqrestore(lock, flags) do { write_unlock(lock); local_irq_restore(flags); } while (0)
  26. #define write_unlock_irq(lock) do { write_unlock(lock); local_irq_enable(); } while (0)
  27. #define write_unlock_bh(lock) do { write_unlock(lock); local_bh_enable(); } while (0)


自旋锁加锁解析
  1. static inline void spin_lock(spinlock_t *lock)
  2. {
  3. #if SPINLOCK_DEBUG
  4. __label__ here;
  5. here:
  6. if (lock->magic != SPINLOCK_MAGIC) {//判断是否等于魔数
  7. printk("eip: %p\n", &&here);
  8. BUG();
  9. }
  10. #endif
  11. __asm__ __volatile__(
  12. spin_lock_string
  13. :"=m" (lock->lock) : : "memory");
  14. }
其中spin_lock_string为一个宏
  1. #define spin_lock_string \
  2. "\n1:\t" \
  3. "lock ; decb %0\n\t" \ //将lock->lock减1,指令带lock表示把总线锁住,禁止其他cpu访问
  4. "js 2f\n" \//不是非负数,直接进入临界区
  5. ".section .text.lock,\"ax\"\n" \
  6. "2:\t" \
  7. "cmpb $0,%0\n\t" \//如果-1结果为负数,那就循环检测
  8. "rep;nop\n\t" \
  9. "jle 2b\n\t" \//如果检测依旧是负数,跳转到2
  10. "jmp 1b\n" \//否则检测
  11. ".previous"


互斥锁,读写锁,条件变量,自旋锁(用于线程互斥)
信号量,文件锁用于进程同步


linux内核情景分析之锁机制的更多相关文章

  1. Linux内核情景分析之消息队列

    早期的Unix通信只有管道与信号,管道的缺点: 所载送的信息是无格式的字节流,不知道分界线在哪,也没通信规范,另外缺乏控制手段,比如保温优先级,管道机制的大小只有1页,管道很容易写满而读取没有及时,发 ...

  2. linux内核情景分析之execve()

    用来描述用户态的cpu寄存器在内核栈中保存情况.可以获取用户空间的信息 struct pt_regs { long ebx; //可执行文件路径的指针(regs.ebx中 long ecx; //命令 ...

  3. linux内核情景分析之内核中的互斥操作

    信号量机制: struct sempahore是其结构,定义如下 struct semaphore { atomic_t count;//资源数目 int sleepers;//等待进程数目 wait ...

  4. Linux内核情景分析的alloc_pages

    NUMA结构的alloc_pages ==================== mm/numa.c 43 43 ==================== 43 #ifdef CONFIG_DISCON ...

  5. Linux内核情景分析之异常访问,用户堆栈的扩展

    情景假设: 在堆内存中申请了一块内存,然后释放掉该内存,然后再去访问这块内存.也就是所说的野指针访问. 当cpu产生页面错误时,会把失败的线性地址放在cr2寄存器.线性地址缺页异常的4种情况 1.如果 ...

  6. linux内核情景分析之exit与Wait

    //第一层系统调用 asmlinkage long sys_exit(int error_code) { do_exit((error_code&0xff)<<8); } 其主体是 ...

  7. linux内核情景分析之匿名管道

    管道的机制由pipe()创建,由pipe()所建立的管道两端都在同一进程.所以必须在fork的配合下,才可以在具有亲缘关系的进程通信 /* * sys_pipe() is the normal C c ...

  8. linux内核情景分析之命名管道

    管道是一种"无名","无形文件,只可以近亲进程使用,不可以再任意两个进程通信使用,所以只能实现"有名","有形"的文件来实现就可以 ...

  9. linux内核情景分析之信号实现

    信号在进程间通信是异步的,每个进程的task_struct结构有一个sig指针,指向一个signal_struct结构 定义如下 struct signal_struct { atomic_t cou ...

随机推荐

  1. python面向对象之反射和内置方法

    一.静态方法(staticmethod)和类方法(classmethod) 类方法:有个默认参数cls,并且可以直接用类名去调用,可以与类属性交互(也就是可以使用类属性) 静态方法:让类里的方法直接被 ...

  2. kettle Spoon.bat闪退解决办法!

    1.Java环境配置问题: java_home:D:\Program Files\Java\jdk1.7.0_25(安装jdk路径) classpath:.;%java_home%\lib\dt.ja ...

  3. pycharm中某些方法被标黄的原因及解决办法

    在编辑python文件时,会遇到上图所示,函数方法被标黄的问题,但是不影响使用. 引起原因:,如果不报错说明,这是因为你配置的python解释器中有该方法,但是pycharm没有找到这个方法,即加载失 ...

  4. MySQL基础7-分页查询

    1.分页查询(MySQL特有的,oracle中没有) 栗子1: 每页最多3条记录:pageSize=3:第一页:SELECT * FROM product LIMIT 0,3第二页:SELECT * ...

  5. mof格式的文件怎么打开?用什么工具?

    托管对象格式 (MOF) 文件是创建和注册提供程序.事件类别和事件的简便方法.在 MOF 文件中创建类实例和类定义后,可以对该文件进行编译.有关更多信息,请参见编译托管对象格式 (MOF) 文件.编译 ...

  6. 深入浅出Hyper-V网络虚拟化(序)

    服务器虚拟化已经越来越普及,很多企业也都在尝试着将现有业务转换成虚拟化的方式来运行,即在一个物理服务器上虚拟出多个实例,而每个实例彼此隔离,就好像在使用一台真实主机一样:网络虚拟化也同样如此,在同一条 ...

  7. R语言分析朝阳医院数据

    R语言分析朝阳医院数据 本次实践通过分析朝阳医院2016年销售数据,得出“月均消费次数”.“月均消费金额”.“客单价”.“消费趋势”等结果,并据此作出可视化图形. 一.读取数据: library(op ...

  8. leetcode 【 Remove Duplicates from Sorted Array 】python 实现

    题目: Given a sorted array, remove the duplicates in place such that each element appear only once and ...

  9. IOS开发学习笔记041-UITableView总结1

    一.UITableView的常用属性 1.分割线 // 分割线 self.tableView.separatorColor = [UIColorredColor]; // 隐藏分割线 self.tab ...

  10. ios开发学习笔记001-C语言基础知识

    先来学习一下C语言基础知识,总结如下: 在xcode下编写代码. 1.编写代码 2.编译:cc –c 文件名.c 编译成功会生成一个 .o的目标文件 3.链接:把目标文件.o和系统自带的库合并在一起, ...