asker160 发表于 2010-11-24 11:08

x86在内存不对齐的时候,为什么不会产生总线错误?

在有些机器上(例如sun的spark,intel的itanium),内存不对齐就会产生总线错误,例如下面这两行C代码:

char buf;
int* pi=buf+1;
(*pi)=2;

在spark上面就打印Bus error然后core dump。
但是在PC上面就能顺利通过,没有什么问题。

能否简单的解释一下呢,x86是怎么通过的,设计上有什么不一样?

我初学,请大虾就这个问题给个容易懂的解释,而不是建议我去啃某本大砖头,谢谢了!

snail_314 发表于 2010-11-24 14:43

the art of design is "TradeOff"

erlv 发表于 2010-11-24 14:44

X86上有些支持非对齐访存的指令,另外,操作系统也可以handle一些bus error错误。
没什么设计上的不同。这种非对齐访存基本内部实现都是用两条对齐操作,加一个拼装操作完成,效率很低。

dibug 发表于 2010-11-24 20:48

在x86里,如果寻址不align,首先效率上要打些折扣~

erazy0 发表于 2010-12-05 20:09

同意3楼

garyv 发表于 2010-12-07 15:45

楼主用spark平台?做什么的呢?

cjaizss 发表于 2010-12-08 08:35

本帖最后由 cjaizss 于 2010-12-08 08:39 编辑

X86是CISC机器,且支持奇数边界访问的CISC.这多少是牺牲了效率换来的,尽管有一套完备的比如cache机制什么的。不过现在似乎看起来也相差无几。而RISC,则一般不支持奇边界。

cjaizss 发表于 2010-12-08 08:35

另外,是SPARC,不是spark

qucklay 发表于 2010-12-11 13:36

从不关心奇地址,只注重实现,不注重效率:mrgreen:

qucklay 发表于 2010-12-11 13:49

记得书上说X86的内存地址的9位每字节,有一位奇偶校验位,是由硬件自动添上的。另外也煞有介事的说内存地址不对齐的代价是很大的。。
页: [1] 2
查看完整版本: x86在内存不对齐的时候,为什么不会产生总线错误?