ARM(44b0)初学者总结(转载)
arm的汇编,只看过它怎么执行,实在我不知道中断向量表地址是如何被放入0x0c000600等地址的。希望有高手能再详细解释一下具体的编写,编译方法和原理。)
在c程序中,我们需要给每个中断向量定义一个宏:
_ISR_STARTADDRESS是起始地址0X0c7fff00,假设ISR是以下函数:
void __irq SWI_UserIsr(void){……………}
则在系统初始化时用pISR_EINT0=(unsigned)SWI_UserIsr;这样的语句把ISR的地址填入中断向量表中,对所有中断作同样的处理,然后开中断,系统就能经过上面的宏把跳到ISR执行。
LDR
LDR
LDR
CMP
0
1
2
来看反汇编的代码:
0xc000c7c,开始的三个字的内容是:
这些反汇编的代码是一个点led的程序的,可以看出我的小程序代码到0x0c000e10就结束了,0x0c200000是我指定的数据区起始地址。这段程序把|Image$$RO$$Limit| 开始的,长|Image$$ZI$$Base| -|Image$$RW$$Base| 的数据区拷到|Image$$RW$$Base|的对应单元,就是0x0c200000开始的一段ram中。后面还有|Image$$ZI$$ Limit|,在我的代码中是0x0c000c88,内容是0x0c200004.这其实表明我的小程序并没有rw区,只有一个初始为0的变量。
由于44b0x要求13个控制寄存器要一次完成填入,所以先把参数设定在SMRDATA的地址中,一次载入通用寄存器,在一次填入RAM控制寄存器中。 4510的书上介绍调试前需要用SEMEM命令设置这些寄存器,但我自己没有那么做也可以跑的很好,也许是默认已经用了最保守的配置的原因吧!
LED程序中的44BINTT.S程序功能和LOAD中的44BINTT.S是重复的,主要是我懒得去修改这些汇编,由着他们占用一点时间吧!
void (*Run)(void) = (void (*)(void))RAM_ADDR;
void Main(void)
{
}
led程序把两个通用io上连的led作不断的亮和灭:
void Main(void)
{
}
最后是烧写的程序,详细的代码网上高手们写了不少,我只是给出最简单的实现。烧写时当程序执行到清理完0X0C30_0000到0X0C30_4000的 RAM后,让程序中断下来,通过LOAD MEMORY FORM FILE命令把LOAD.BIN导入0X0C30_0000,LED.BIN导入0X0C30_2000中,继续运行程序直到一个LED亮起,烧写就完成了。拔去仿真器后再上电,可以看到两个LED同时亮灭。
#include "option.h"
#include "44b.h"
#include "def.h"
//#include "romdef.h"
//#include "stdio.h"
//#include "stdlib.h"
   #define FLASH_START_ADDR
#define FLASH_ADDR_UNLOCK1
#define FLASH_ADDR_UNLOCK2
#define FLASH_DATA_UNLOCK1
#define FLASH_DATA_UNLOCK2
#define FLASH_DATA_WRITE
#define FLASH_ERASE
#define FLASH_ERASE_SECTOR
#define FLASH_ERASE_BLOCK
#define FLASH_ERASE_CHIP
#define FLASH_SID_QUERY
#define FLASH_CFI_QUERY
#define FLASH_SID_EXIT
#define FLASH_OP_TIMEOUT
ARM44b0初学者总 相关文章:
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)
- Windows CE 进程、线程和内存管理(二)(11-09)