共2条
1/1 1 跳转至页
KEIL,PC 请教KEIL中关于PC的正确值
问
近来用KEIL软件仿真ARM,纸上谈兵,搞得常非常头痛,请大侠指教一下:
1. 书上说:
因为ARM的pipeline结构"PC is running eight bytes ahead of the current instruction being executed,
so care must be taken when calculating offsets used in PC relative addressing."
例如:
0x4000 LDR PC,[PC,#4]
实际上是到0x400C地址上取值赋于PC,而非0x4004;
2. Keil中仿真结果:(下图)
0x00000156 4804 LDR R0,[PC,#0x0010]
如果如书所说,要到0x0000016E( 即0x00000156 + 0x0010 + 8 )上取值。但是仿真时,从反汇编结果上看,KEIL却是到0x00000168上取值的...
以上结果或者是书错误,或者是软件仿真错误,或者是生成的反汇编结果错误,还是...
最担心是反汇编结果错误,KEIL编译器就废了...
郁闷啊...
////////////////////////////////////////////////////////////////////////////////////
#include <LPC21xx.H> // Philips Peripheral Registers
//#include "LPC21xxDEF.H" //
void main (void) {
unsigned led;
while (1)
{ // endless loop
led = IOPIN1; //read the current state of the IO pins
}
} 答 1: 我也是郁闷的人...好象要让汽车电子同志帮忙才是...
周立功的人好象对Keil不感冒,只钟情ADS1.2....
但我总感觉到Keil应该比ADS好用,特别对像我们2个纸上谈兵的人...
在此等候"姜太公"的到来... 答 2: Keil在仿真功能上比ADS等强大很多。不过在代码效率方面(尤其是速度方面),Keil远比不上ADS。所以一般用Keil的界面,用GCC或ADS的编译器。
我用Keil是看上了它附带的ARTX,可惜它只能用Keil编译器编译。 答 3: 请问楼上先生如何用ADS编译器用GCC虽好但不能用ARTX,用Keil更好却不能用C++,...确实很郁闷... 答 4: re在Components, Environment and Books的Folders/Extensions那里可以选择编译器。还要设置编译器所在目录,例如C:\Program Files\ARM\ADSv1_2\Bin\。
不过不知道为什么,我总不能调用ADS的ASM编译器。 答 5: 非常感谢qwernet!!!等我装个ADS1.2试试...
看来用ADS1.2玩C++也不错,而且周立功也支持...
再次感谢!!! 答 6: Keil用自己的ADS例程可以但用ADS不行而且不支持ADS的C++... 答 7: keil没有错,是THUMB模式 答 8: 16/32可我还是算不来... 答 9: 谢谢yaodong_wu提示!!!谢谢yaodong_wu,我忽略了THUMB的模式!!!
修改了一下代码,仿真时一切正常!!!
#include <LPC21xx.H> // Philips Peripheral Registers
#pragma ARM
void main (void) {
unsigned led;
while (1)
{ // endless loop
led = IOPIN1; //read the current state of the IO pins
}
}
似乎Keil默认的形式是THUMB而不是ARM吗。
答 10: Keil可以配置THUMB/ARM选择THUMB肯定是THUMB/ARM代码混用,否则只能编译ARM代码.
前者代码长度少些... 答 11: 网上下的keil720版能防真ARM吗,我试过好象不行大虾能不能给一个可调ARM的keil 答 12: 是的,option->c->use thumb mode,默认使用thumb模式 答 13: 大虾,能给个keil for ARM的下载吗
1. 书上说:
因为ARM的pipeline结构"PC is running eight bytes ahead of the current instruction being executed,
so care must be taken when calculating offsets used in PC relative addressing."
例如:
0x4000 LDR PC,[PC,#4]
实际上是到0x400C地址上取值赋于PC,而非0x4004;
2. Keil中仿真结果:(下图)
0x00000156 4804 LDR R0,[PC,#0x0010]
如果如书所说,要到0x0000016E( 即0x00000156 + 0x0010 + 8 )上取值。但是仿真时,从反汇编结果上看,KEIL却是到0x00000168上取值的...
以上结果或者是书错误,或者是软件仿真错误,或者是生成的反汇编结果错误,还是...
最担心是反汇编结果错误,KEIL编译器就废了...
郁闷啊...
////////////////////////////////////////////////////////////////////////////////////
#include <LPC21xx.H> // Philips Peripheral Registers
//#include "LPC21xxDEF.H" //
void main (void) {
unsigned led;
while (1)
{ // endless loop
led = IOPIN1; //read the current state of the IO pins
}
} 答 1: 我也是郁闷的人...好象要让汽车电子同志帮忙才是...
周立功的人好象对Keil不感冒,只钟情ADS1.2....
但我总感觉到Keil应该比ADS好用,特别对像我们2个纸上谈兵的人...
在此等候"姜太公"的到来... 答 2: Keil在仿真功能上比ADS等强大很多。不过在代码效率方面(尤其是速度方面),Keil远比不上ADS。所以一般用Keil的界面,用GCC或ADS的编译器。
我用Keil是看上了它附带的ARTX,可惜它只能用Keil编译器编译。 答 3: 请问楼上先生如何用ADS编译器用GCC虽好但不能用ARTX,用Keil更好却不能用C++,...确实很郁闷... 答 4: re在Components, Environment and Books的Folders/Extensions那里可以选择编译器。还要设置编译器所在目录,例如C:\Program Files\ARM\ADSv1_2\Bin\。
不过不知道为什么,我总不能调用ADS的ASM编译器。 答 5: 非常感谢qwernet!!!等我装个ADS1.2试试...
看来用ADS1.2玩C++也不错,而且周立功也支持...
再次感谢!!! 答 6: Keil用自己的ADS例程可以但用ADS不行而且不支持ADS的C++... 答 7: keil没有错,是THUMB模式 答 8: 16/32可我还是算不来... 答 9: 谢谢yaodong_wu提示!!!谢谢yaodong_wu,我忽略了THUMB的模式!!!
修改了一下代码,仿真时一切正常!!!
#include <LPC21xx.H> // Philips Peripheral Registers
#pragma ARM
void main (void) {
unsigned led;
while (1)
{ // endless loop
led = IOPIN1; //read the current state of the IO pins
}
}
似乎Keil默认的形式是THUMB而不是ARM吗。
答 10: Keil可以配置THUMB/ARM选择THUMB肯定是THUMB/ARM代码混用,否则只能编译ARM代码.
前者代码长度少些... 答 11: 网上下的keil720版能防真ARM吗,我试过好象不行大虾能不能给一个可调ARM的keil 答 12: 是的,option->c->use thumb mode,默认使用thumb模式 答 13: 大虾,能给个keil for ARM的下载吗
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |