百科问答小站 logo
百科问答小站 font logo



x86架构字节序是小端模式,其bit位序是类似小端模式还是大端模式? 第1页

  

user avatar   bei-ji-85 网友的相关建议: 
      

如果严格按照位序定义来说x86架构(单纯指的是CPU指令集),是不存在位序的概念的。

有位序概念的前提是:按位(bit)的方式串行收发、处理数据,然后组装成一个字节(byte)。比如USB 2.0的两条数据线发送数据的时候,需要把字节信号转换成电平信号,按位(bit)的方式发送。类似的有位序概念的还有以太网、RS232串口等。

但Intel架构上,不存在直接按照位(bit)组装成字节(bytes)的相关指令操作,CPU操作的最小数据单元是字节(byte),所以严格的说,x86不存在位序的定义

同样的,在其它架构的CPU上,CPU以字节作为最小单位的方式访问数据,都没有位序的概念

CPU层面上,唯一可能有位序概念的是GPIO管脚,但多数现代的CPU的GPIO都是外挂的,一般是用MMIO方式访问,所以也可以排除。

下图是Intel 80386的逻辑图,可以看到数据总线和地址总线都是并行总线,不是串行总线。所以不存在位序的概念(甚至在硬件层面上,连字节序的概念都不存在,地址请求是一次发送的)。

以MSB/LSB/bit order位关键词,在Intel的《Intel 64 and IA-32 Architectures Software Developer's Manual》里搜索,并不能找到有效的内容,唯一有点关于bit order的描述:

所以事实上,Intel CPU没有位序的概念。


user avatar   netwarm007 网友的相关建议: 
      

这是一个好问题,回答其实也没有那么简单。

总的来说,对于绝大部分CPU,bit位序是和字节序保持一致的。因为大部分CPU命令的操作最小单位都是字节,通过一系列位操作命令将一个字节内的位进行调转,是非常耗费性能的。

所以,简单回答的话,x86架构的bit位序也是小端模式。这意味着CPU的D0线是lsb,而D7线是msb。

但是,除了CPU之外,一个计算机系统其实还有缓存、总线、外设等等很多东西。这些东西同样是有字节序/位序的。

为了简化设计和连接,大部分时候,计算机系统内的其它周边设备,也都会和CPU保持一致。但是有一个设备除外,那就是网卡。

Ethernet的PHY(物理层)是大端的字节序,小端的位序。所以对于网卡在收发数据的时候,需要根据需要进行重排。(一般由网卡自己完成)

然后OSI更加上层的协议,其实也都有各自的Endian。比如IP协议,就是大端的。所以如果你要去解析IP协议的协议头里面的东西,往往就需要进行进行一下字节的重排。




  

相关话题

  采用32位cpu的系统,如果内存采用字编址方式能否支持更大的内存了? 
  为啥arm架构比x86 x64省电? 
  函数调用带来的 cache miss 会对 cpu 性能带来多大的影响? 
  为什么现在的芯片公司都在急需做编译器的人?这个职位是要去解决什么样的问题? 
  12600KF 和 5800X 选哪个? 
  汇编语言转换成机器语言,具体在机器这个层面是如何实现的? 
  主板上,什么叫USB控制器? 
  龙芯处理器还在发展吗? 
  用了几年的华为p10稍微有点卡顿,cpu是麒麟960,我希望开启强制GPU渲染解决卡顿,请问可行吗? 
  如何评价 AMD 正式公布锐龙 7000 系列桌面级处理器? 

前一个讨论
USB 3.0 速度远不如 SATA,为什么现在外接硬盘柜还是普遍用 USB 接口?
下一个讨论
Linux 为什么不是实时操作系统?





© 2025-03-31 - tinynew.org. All Rights Reserved.
© 2025-03-31 - tinynew.org. 保留所有权利