ARM7(lpc2146)學(xué)習筆記-0606
1.保存文件名要全名(即包括擴展名)
2.*.tdt文件刪除則整個(gè)工程都會(huì )重新編譯
3.*.axf為工程的調試文件
4.*.scf 分散加載描述文件
5.ADS的RelinFLASH版本設置了JTAG的加密,下載這個(gè)版本的代碼之后,JTAG調試就不能用了,通過(guò)周立功提供的LCP的ISP軟件,擦除掉芯片內的程序就OK了。
二.ARM指令
6.小端方式:較低字節存放在較低地址(arm7)
7.通過(guò)對一個(gè)單元執行兩次相同的寫(xiě)操作,可保證復位后數據的寫(xiě)入。因為人SRAM控制器包含一下回寫(xiě)緩沖區,要在進(jìn)行第二次寫(xiě)時(shí)上一次的數據才真正被寫(xiě)入SRAM
8.VHB:0xffe00000~0xffffffff,每個(gè)外設16KB
9.存儲器映射的基本概念是:每個(gè)存儲器組在存儲器映射中都有有下“物理上的”位置.
10.BOOT Block是芯片設計廠(chǎng)家在LPC2000系列ARM內部固化的一段代碼,它在芯片復位后被首先運行,其功能主要是判斷運行哪個(gè)存儲器上的程序、檢查用戶(hù)代碼是否有效、判斷芯片是否被加密、芯片的在應用編程(IAP)以及在系統編程功能(ISP)。這其中有些程序是可以被用戶(hù)調用的,比如擦寫(xiě)片內FLASH的IAP代碼。為了增加用戶(hù)代碼的可移植性,所以最好能把BOOT Block的代碼固定在某個(gè)地址上。但是因為各個(gè)芯片的片內FLASH大小不盡相同,如果把BOOT Block的地址安排在片內FLASH結束的位置上,那么就無(wú)法實(shí)現BOOT Block地址的固定。所以芯片生產(chǎn)商就把BOOT Block的地址重映射到片內存儲器空間的最高處,即接近2G(0x80000000)的地方,這樣無(wú)論片內存儲器大小如何,都不會(huì )影響B(tài)OOT Block的地址??梢宰尠蠭AP操作的用戶(hù)代碼,不用修改IAP操作地址,就可以在不同的LPC2000系列ARM上運行。
11.
MSR 指令的格式為:
MSR{條件} 程序狀態(tài)寄存器(CPSR 或SPSR);域,操作數
MSR 指令用于將操作數的內容傳送到程序狀態(tài)寄存器的特定域中。其中,操作數可以為通用寄存器或立即數。域用于設置程序狀態(tài)寄存器中需要操作的位,32 位的程序狀態(tài)寄存器可分為4 個(gè)域:
位[31:24]為條件標志位域,用f 表示;
位[23:16]為狀態(tài)位域,用s 表示;
位[15:8]為擴展位域,用x 表示;
位[7:0]為控制位域,用c 表示;
該指令通常用于恢復或改變程序狀態(tài)寄存器的內容,在使用時(shí),一般要在MSR 指令中指明將要操作的域。
12.BIC 指令用于清除操作數1 的某些位,并把結果放置到目的寄存器中。
13.SPACE 偽指令用于分配一片連續的存儲區域并初始化為0。其中表達式為要分配的字節數。
評論