Linux 字节序

小心不要假设字节序. PC 存储多字节值是低字节为先(小端为先, 因此是小端), 一些高 级的平台以另一种方式(大端)工作. 任何可能的时候, 你的代码应当这样来编写, 它不在 乎它操作的数据的字节序. 但是, 有时候一个驱动需要使用单个字节建立一个整型数或者 相反, 或者它必须与一个要求一个特定顺序的设备通讯.

 

包含文件 <asm/byteorder.h> 定义了或者 BIG_ENDIAN 或者 LITTLE_ENDIAN, 依赖 处理器的字节序. 当处理字节序问题时, 你可能编码一堆 #ifdef LITTTLE_ENDIAN 条 件语句, 但是有一个更好的方法. Linux 内核定义了一套宏定义来处理之间的转换, 在处 理器字节序和你需要以特定字节序存储和加载的数据之间. 例如:

 

u32 cpu_to_le32 (u32); u32 le32_to_cpu (u32);

 

这 2 个宏定义转换一个值, 从无论 CPU 使用的什么到一个无符号的, 小端, 32 位数, 并且转换回. 它们不管你的 CPU 是小端还是大端, 不管它是不是 32-位 处理器. 在没有 事情要做的情况下它们原样返回它们的参数. 使用这些宏定义易于编写可移植的代码, 而 不必使用大量的条件编译建造.

 

有很多类似的函数; 你可以在 <linux/byteorder/big_endian.h> 和

<linux/byteorder/little_endian.h> 中见到完整列表. 一会儿之后, 这个模式不难遵循. be64_to_cpu 转换一个无符号的, 大端, 64-位 值到一个内部 CPU 表示. le16_to_cpus, 相反, 处理有符号的, 小端, 16 位数. 当处理指针时, 你也会使用如 cpu_to_le32p, 它 使用指向一个值的指针来转换, 而不是这个值自身. 剩下的看包含文件.

posted @ 2019-07-07 13:38  樊伟胜  阅读(901)  评论(0编辑  收藏  举报