ARM7(lpc2146)学习笔记-0606
1.保存文件名要全名(即包括扩展名)
2.*.tdt文件删除则整个工程都会重新编译
3.*.axf为工程的调试文件
4.*.scf
5.ADS的RelinFLASH版本设置了JTAG的加密,下载这个版本的代码之后,JTAG调试就不能用了,通过周立功提供的LCP的ISP软件,擦除掉芯片内的程序就OK了。
二.ARM指令
6.小端方式:较低字节存放在较低地址(arm7)
7.通过对一个单元执行两次相同的写操作,可保证复位后数据的写入。因为人SRAM控制器包含一下回写缓冲区,要在进行第二次写时上一次的数据才真正被写入SRAM
8.VHB:0xffe00000~0xffffffff,每个外设16KB
9.存储器映射的基本概念是:每个存储器组在存储器映射中都有有下“物理上的”位置.
10.BOOT Block是芯片设计厂家在LPC2000系列ARM内部固化的一段代码,它在芯片复位后被首先运行,其功能主要是判断运行哪个存储器上的程序、检查用户代码是否有效、判断芯片是否被加密、芯片的在应用编程(IAP)以及在系统编程功能(ISP)。这其中有些程序是可以被用户调用的,比如擦写片内FLASH的IAP代码。为了增加用户代码的可移植性,所以最好能把BOOT Block的代码固定在某个地址上。但是因为各个芯片的片内FLASH大小不尽相同,如果把BOOT Block的地址安排在片内FLASH结束的位置上,那么就无法实现BOOT Block地址的固定。所以芯片生产商就把BOOT Block的地址重映射到片内存储器空间的最高处,即接近2G(0x80000000)的地方,这样无论片内存储器大小如何,都不会影响BOOT Block的地址。可以让包含有IAP操作的用户代码,不用修改IAP操作地址,就可以在不同的LPC2000系列ARM上运行。
11.
MSR 指令的格式为:
MSR{条件} 程序状态寄存器(CPSR 或SPSR);域,操作数
MSR 指令用于将操作数的内容传送到程序状态寄存器的特定域中。其中,操作数可以为通用寄存器或立即数。域用于设置程序状态寄存器中需要操作的位,32 位的程序状态寄存器可分为4 个域:
位[31:24]为条件标志位域,用f 表示;
位[23:16]为状态位域,用s 表示;
位[15:8]为扩展位域,用x 表示;
位[7:0]为控制位域,用c 表示;
该指令通常用于恢复或改变程序状态寄存器的内容,在使用时,一般要在MSR 指令中指明将要操作的域。
12.BIC 指令用于清除操作数1 的某些位,并把结果放置到目的寄存器中。
13.SPACE 伪指令用于分配一片连续的存储区域并初始化为0。其中表达式为要分配的字节数。
ARM7lpc2146学习笔 相关文章:
- ARM7(lpc2146)学习笔记-0607(11-25)
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)