免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 11732 | 回复: 14
打印 上一主题 下一主题

x86在内存不对齐的时候,为什么不会产生总线错误? [复制链接]

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-11-24 11:08 |只看该作者 |倒序浏览
在有些机器上(例如sun的spark,intel的itanium),内存不对齐就会产生总线错误,例如下面这两行C代码:

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

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

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

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

论坛徽章:
0
2 [报告]
发表于 2010-11-24 14:43 |只看该作者
the art of design is "TradeOff"

论坛徽章:
0
3 [报告]
发表于 2010-11-24 14:44 |只看该作者
X86上有些支持非对齐访存的指令,另外,操作系统也可以handle一些bus error错误。
没什么设计上的不同。这种非对齐访存基本内部实现都是用两条对齐操作,加一个拼装操作完成,效率很低。

论坛徽章:
0
4 [报告]
发表于 2010-11-24 20:48 |只看该作者
在x86里,如果寻址不align,首先效率上要打些折扣~

论坛徽章:
0
5 [报告]
发表于 2010-12-05 20:09 |只看该作者
同意3楼

论坛徽章:
0
6 [报告]
发表于 2010-12-07 15:45 |只看该作者
楼主用spark平台?做什么的呢?

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
7 [报告]
发表于 2010-12-08 08:35 |只看该作者
本帖最后由 cjaizss 于 2010-12-08 08:39 编辑

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

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
8 [报告]
发表于 2010-12-08 08:35 |只看该作者
另外,是SPARC,不是spark

论坛徽章:
0
9 [报告]
发表于 2010-12-11 13:36 |只看该作者
从不关心奇地址,只注重实现,不注重效率

论坛徽章:
0
10 [报告]
发表于 2010-12-11 13:49 |只看该作者
记得书上说X86的内存地址的9位每字节,有一位奇偶校验位,是由硬件自动添上的。另外也煞有介事的说内存地址不对齐的代价是很大的。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP