CPU大小端问题

 做嵌入式开发的伙计们不可能不补知道大小端的概念吧,这个是一个没有谁绝对的对,谁绝对的错的世界,记得在做Powerpc的一款CPU的时候,CPU对于内存和flash的操作甚至可以自由的进行大小端的配置。这里搜罗一些资料,供大家参考。

 大端小端的概念(以下均来源于网络)

 端模式(Endian)的这个词出自Jonathan Swift书写的《格列佛游记》。这本书根据将鸡蛋敲开的方法不同将所有的人分为两类,从圆头开始将鸡蛋敲开的人被归为Big Endian,从尖头开始将鸡蛋敲开的人被归为Littile Endian。小人国的内战就源于吃鸡蛋时是究竟从大头(Big-Endian)敲开还是从小头(Little-Endian)敲开。在计算机业Big Endian和Little Endian也几乎引起一场战争。在计算机业界,Endian表示数据在存储器中的存放顺序。下文举例说明在计算机中大小端模式的区别。

 如果将一个32位的整数0x12345678存放到一个整型变量(int)中,这个整型变量采用大端或者小端模式在内存中的存储由下表所示。为简单起见,本书使用OP0表示一个32位数据的最高字节MSB(Most Significant Byte),使用OP3表示一个32位数据最低字节LSB(Least Significant Byte)。

地址偏移 大端模式 小端模式
4000 12 78
4001 34 56
4002 56 34
4003 78 12

 如果将一个16位的整数0x1234存放到一个短整型变量(short)中。这个短整型变量在内存中的存储在大小端模式由下表所示。


地址偏移 大端模式 小端模式
4000 12 34
4001 34 12

 

 判断CPU的经典代码,在linux内核中,也是用该思想进行判断的。

如果ENDIANNESS=’l’表示系统为little endian,为’b’表示big endian
int main(void)
{
    static union {
        char c[4];
        unsigned long l;
    } endian_test = {{'l', '?', '?', 'b'}};
    #define ENDIANNESS ((char)endian_test.l)
    printf("ENDIANNESS:%c/n", ENDIANNESS); // Output "ENDIANNESS:l"
     
    return 0;
}

发表评论

电子邮件地址不会被公开。 必填项已用*标注

112 views 暂无评论