4947|1

1170

帖子

0

TA的资源

至上芯片

楼主
 

ARM编程值得注意的地方 [复制链接]

1、ARM是一个32位处理器,通常情况下,如果没有特殊要求,C语言中的结构体要求4 字节对齐。 2、在实际代码中,会存在以下两问题: a、要求多个数据紧缩在4个字节中。 b、而有些数据是4个字节长度,但并不是4字节对齐存储的。 3、作为32位处理器,与X86不同点是:ARM不支持非对其字节的数据传输,也就是说,在C语言中,一旦使用了32位的指针操作一个非4字节对齐的数据,ARM就会陷入一异常。该问题会给一些软件的移植带来麻烦,一定要特别留心处理这些问题。(现在的常用ARM版本中,都不支持未对齐数据的传输,如ARMv4,ARMv5,但从ARMv6开始支持非对齐数据传输) 4、在ARM汇编语言编程时,须注意流水线的影响,比如ARM9的五级流水线会导致所读取的PC(程序计数器)指针总比当前执行的汇编代码地址多16. 例如:(arm9汇编中) mov pc,pc 执行以上指令后,程序会跳转到当前指令的往后的第四条指令去执行。 而: sub pc,pc,#12 执行的才是当前指令的下一条指令。 若: sub pc,pc,#16 该指令执行,是一个死循环。
此帖出自ARM技术论坛

最新回复

不看不知道,一看吓一跳!还好看见了  详情 回复 发表于 2009-11-2 22:07
点赞 关注
 

回复
举报

1290

帖子

0

TA的资源

五彩晶圆(初级)

沙发
 
不看不知道,一看吓一跳!还好看见了
此帖出自ARM技术论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表