Linux源码 volatile类型

阅读数:156 评论数:0

跳转到新版页面

分类

Linux

正文

C程序员通常认为volatile表示某个变量可以在当前执行的线程外被改变,因此在内核中用到共享数据结构时,常常会有C程序员使用volatile这类变量,然而在内核中使用volatile几乎总是错误的。

理解volatile的关键是知道它的目的用来消除优化,在内核中,程序员必须防止意外的并发访问破坏共享的数据结构,这其实是一个完全不同的任务。

像volatile一样,内核提供了很多原语来保证并发访问时的数据安全(自旋锁、互斥量、内存屏障等),同样也可以防止意外的优化。如果可以正确的使用这些内核原语,那么就没有必要再使用volatile。在正确的内核代码中,volatile能带来的仅仅是使事情变慢。

思考一下这段典型的内核代码

spin_lock(&the_lock);

do_something_on(&shared_data);

do_something_else_with(&shared_data);

spin_unlock(&the_lock);

如果所有的代码都遵循加锁规则,当持有the_lock的时候,不可能意外的改变shared_data的值。任何可能访问该数据的其他代码都会在这个锁上等待。自旋锁原语和内存屏障一样,它们显式的用来书写这样,意味着数据访问不会跨越它们页被优化。所以本来编译器认为它知道在shared_data里面将有什么,但是因为spin_lock()调用跟内存屏障一样,会强制编译器忘记它所知道的一切,那么在访问这些数据时不会有优你给的问题。

volatile的存储类型最初是为那些内存映射的I/O寄存器而定义。在内核里,寄存器访问也应该被锁保护,但是人们也不希望编译器“优化”临界区内的寄存器访问。内核里的I/O的内存访问是通过访问函数完成的,不赞成通过指针对I/O内存的直接访问,并且不是所有体系架构上都能工作。那些访问函数正是为了防止意外优化而写的,因些,再说一次,volatile类型不是必须的。

在内核中,一些稀少的情况下volatile仍然有意义的:

 

  • 在一些体系架构的系统上,允许直接的I/O内存访问,那么前面提到访问函数可以使用volatile。
  • 某些会改变内存的内联汇编代码虽然没有什么其他明显的附作用,理是有被GCC删除的可能性。在汇编声明中加上volatile关键字可以防止这种删除操作。
  • Jiffies变量是一种特殊情况,虽然每次引用它的时候都可以有不同的值,但读jiffies变量时不需要任何特殊的加锁保护。所以jiffies变量可以使用volatile,但不赞成其他跟jiffies相同类型变量使用volatile。jiffies被认为是一种“愚蠢的遗留物”,因为解决这个问题比保持现状要麻烦的多。
  • 由于某些I/O设备可能会悠 连续一致的内存,所以有时,指向连续内存的数据结构的指针需要正确的使用volatile。网络适配器使用的环状缓存区正是这类情形的一个例子,其中适配器用改变指针来表示哪些描述符已经处理过了。



相关推荐

一、概述 1、为什么Linus不使用GPLv3 在 PC 上,只要你得到了某个程序的源代码,就可以自行编译生成二进制程序,然后替换掉原有的二进制程序,你的程序自由很容易得到保证。然而 iPod、iPh

说明:这种方式只是用于方便阅读代码,因为可以在源代间快速索引跳跃。但是最后可能会有一些warning,可以不必关心,如果是强迫症,可以使用下面这种方式来去掉。

一、概述 在Linux系统中,/usr/bin和/usr/local/bin是两个常见的目录,用于存放可执行文件(二进制文件)。 很多应用都安装在/usr/local下面,先看一下automake工具

  一、概述 vmstat命令是最常见的Linux/Unix监控工具,可以监控给定时间间隔服务器的CPU使用率、内存使用、IO情况。相比top命令,可以查看到整个机器的CPU、内存、IO的使用情况,而

一、概述 sar,System Activity Reporter。是目前 Linux 上最为全面的系统性能分析工具之一,可以从多方面对系统的活动进行报告,包括:文件的读写情况、系统调用的使用情况、磁

一、简介 简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。 二、使用方法 1、基本语法  awk '条件类型1 {动作1} 条件类型2{动作2} ...

一、概述 列出目标目录中所有的子目录和文件。 二、 语法 ls [选项] [目录名] -a, –all 列出目录下的所有文件,包括以 . 开头的隐含文件 -A 同-a,但不列出“.”(表示当前目录)

一、概述 cd全称是change directory,用于切换当前工作目录。 注意的是,cd命令是一个内建命令,它是由 shell 提供的。因此,不同的 shell 可能会有一些差异,但基本的用法和功

一、概述 全称为print working directory,查看”当前工作目录“的完整路径,一般情况下不带任何参数 二、语法 pwd [选项] -L 即logical,逻辑路径 -P 即

一、概述 通过 mkdir 命令可以实现在指定位置创建以 DirName(指定的文件名)命名的文件夹或目录。要创建文件夹或目录的用户必须对所创建的文件夹的父文件夹具有写权限。并且,所创建的文件夹(目录