关于ADS容易出错的地方

EDA/IC设计

1065人已加入

描述

建立工程,编辑源文件,把文件加入工程,设置工程属性、编译与链接选项,make!

Error : A1163E: Unknown opcode

vector.s line 14

14 00000020 Reset_Addr DCD Reset_Handler

。。。

全国人民再次震惊了,世界人民傻眼了。。。

我这次的的确确是在ADS的CodeWarrior中编辑的代码~!为什么!?为什么armassembler又不认识DCD了呢?\

ADS1220

我一个字母一个字母的检查,没有发现错误。我狠狠地在出错的代码前后各敲了一次回车,确保正确换行,还是报错。。。我去掉了Reset_Addr DCD Reset_Handler这条伪操作语句前面的Tab符号,神奇了!!居然不再对它报错了~!!莫非上次也是这个Tab键在作怪,而让我错怪了vim编辑器?

ADS用它的固执再次向自卑的丑男和骄傲的傻妹证实了:好看有什么用?又不能当饭吃~!

天,我在语句前面加一个Tab符号,不过是想代码看起来整齐些,难道爱美也有错嘛~没有规矩,不成方圆,当兵就得有当兵的样,部队就有部队的规矩,要不去当文艺兵得了————写代码就是让代码去当兵,个个理成平头一个样,还谈啥好看哩~想不到,有些时候Tab也是不能乱加的,想让代码整齐清楚的一些小动作,到了ADS这里竟也成了壞習慣了~!

你甭说,这ADS的armassembler/compiler/linker有时候就TMD怪,尽出些只有机器能明白的错误!咋不做个开发环境让机器去coding呢~!看看这条代码:

MCR P15, 0, R1, C1, C0, 0

有错不?非常简单的写协处理器CP15寄存器1的指令,语法和拼写完全没错误!要是ADS对你报错了,你疯不?它还真报错了!

Error :A1151E: Bad register name symbol

boot.s line 107

还好我心理承受能力强,在我疯之前找出了这个用肉眼看不到的错误:将P15,C1,C0全部用小写字母表示就对了!

MCR p15, 0, R1, c1, c0, 0 ;correct now

说到这里,世界人民忍不住都在心里把ADS给***了一把。

原来,对于协处理器的寄存器符号,都必须用小写字母来表示~!My God!What a ***ing world!

天,又遇到新的毛病!前面说一些伪操作语句前面不要TAB,而又有一些伪操作(directive)前还必须要Tab符号或空格~!不信?把AREA还有与之配套的END语句顶格写试试?!ADS跟你报错没商量~!EXPORT/IMPORT前面也一样必须有Tab符号或空格!

使用ADS1.2时,对于汇编文件,如初始化的init.s,每条语句之前都要加一个“TAB”或空格,否则会出现“unkown opcode”错误。

碰到此类问题可以试试以下方法:

1、去掉语句前面的TAB或试试(已知一些伪操作如DCD,EQU语句前不可有TAB符号);

2、在语句前加空格或Tab符号试试(已知AREA,END,EXPORT/IMPORT前必须有空格或Tab符号);

3、大写改成小写(已知协处理器及协处理器寄存器必须用小写字母表示);

4、TAB换空格或空格换TAB等其他各种办法。

汇编中的注释以;开头,C或C++中用//

--------------------------------------------------

ADS下__main()是C语言的内部库函数,在进入用户main()之前完成内部RAM的初始化工作。

-------------------------

由于ARM采用三级流水线结构,因此,当SWI和未定义指令异常中断产生时,程序计数器PC的值还没有更新,它指向当前指令后面第2条指令(对于ARM指令,它指向当前指令地址加8个字节的位置;对于Thumb指令,它指向当前指令地址加4个字节的位置)。这就是为什么当SWI和未定义指令异常中断发生时,处理器将(PC-4)保存到异常模式下的寄存器lr_mode中,这时(PC-4)即指向当前指令的下一条指令。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分