Github: atomic_cmpxchg_relaxed
Email: BuddyZhang1 buddy.zhang@aliyun.com
Architecture: ARMv7 Cortex A9-MP
目录
源码分析
atomic_cmpxchg_relaxed() 函数用于对 atmoic 变量的值进行对比,如果与内存中的值
相等,那么就替换成新值。参数 ptr 指向一个 atomic_t 变量;参数 old 代表与内存中对比
的值;new 代表替换的值。函数首先调用 prefetchw() 函数将 ptr->counter 值从内存预取
到 cache 里面,然后调用一个内嵌汇编。在内嵌汇编中,首先低啊用 ldrex 指令设置
独占标志,并将 ptr->counter 的值从内存读取到 oldval 变量里,接着将 res 变量清零。
接着调用 teq 指令对比 ptr->counter 的值是否和 old 参数相同,如果不相同,则直接
返回;如果相同,那么调用 strexeq 指令,如果此时独占标志还存在,那么 strexeq 指令就
将 new 参数的值写入到 ptr->counter 对应的内存中,并将 res 设置为 0;如果此时
独占标志被清零,那么 strexeq 不会将 new 值写入 ptr->counter 对应的内存,而是
仅仅将 res 设置为 1。由于 res 的值为 1,那么 while 循环继续循环重复之前的操作。
实践
驱动源码
驱动安装
驱动的安装很简单,首先将驱动放到 drivers/BiscuitOS/ 目录下,命名为 atomic.c,
然后修改 Kconfig 文件,添加内容参考如下:
接着修改 Makefile,请参考如下修改:
驱动配置
驱动配置请参考下面文章中关于驱动配置一节。在配置中,勾选如下选项,如下:
具体过程请参考:
Linux 5.0 开发环境搭建 – 驱动配置
驱动编译
驱动编译也请参考下面文章关于驱动编译一节:
Linux 5.0 开发环境搭建 – 驱动编译
驱动运行
驱动的运行,请参考下面文章中关于驱动运行一节:
Linux 5.0 开发环境搭建 – 驱动运行
启动内核,并打印如下信息:
驱动分析
在需要交换 atomic_t 变量值的地方可以使用 atomic_cmpxchg_relaxed() 函数。
附录
BiscuitOS Home
BiscuitOS Driver
BiscuitOS Kernel Build
Linux Kernel
Bootlin: Elixir Cross Referencer
搭建高效的 Linux 开发环境
赞赏一下吧 🙂