在使用这两个函数的时候,想了想他们之间的不同,从函数的功能来看,他们都是在驱动代码中读虚拟地址。但是通过他们的实现的源码,可以看到,他们之间是有不同的;
在ARM架构下他们的实现:
#define __raw_readl(a) (__chk_io_ptr(a), *(volatile unsigned int __force *)(a))
#define ioread32(p) ({ unsigned int __v = le32_to_cpu((__force __le32)__raw_readl(p)); __v; })
___raw_readl() 不进行端序的检查,ioread32()会检查体系机构的端序。其中__force作用如下:
# define __force __attribute__((force))
表示所定义的变量类型是可以做强制类型转换的,在进行Sparse分析的时候,使其不用产生告警信息。
本文探讨了Linux驱动代码中__raw_readl()和ioread32()两个函数的差异。尽管它们都用于读取虚拟地址,但__raw_readl()不处理端序检查,而ioread32()会根据体系结构进行端序转换。此外,__force关键字在__raw_readl()的定义中用于允许强制类型转换,避免Sparse静态分析工具发出警告。

630

被折叠的 条评论
为什么被折叠?



