基于ARM芯片的PDA系統(tǒng)中硬件設計實現(xiàn)
完成硬件電路設計并調試通過后主要針對以下3方面的軟件編程功能實現(xiàn):
對硬件電路(CPU及主要外圍電路)的初始化,NAND_FLASH驅動程序和LCD驅動程序的編寫及實現(xiàn)。
2.1 系統(tǒng)的初始化
初始化硬件電路主要完成STR7lO各寄存器的配置及內存映射和中斷向量配置、處理器與外芯片的初始化以及功能庫函數(shù)加載等。其主要步驟是首先調用71x_init.s源文件完成CPU各寄存器的初始化配置后中斷異常的處理實現(xiàn)及中斷優(yōu)先級設置、系統(tǒng)堆棧和變量的初始化最后完成初始化后使用BL語句跳轉至MAIN功能函數(shù):IMPORT main;B main;main為C語言主函數(shù)入口。初始化流程圖如圖4所示。本文引用地址:http://www.ex-cimer.com/article/152519.htm
2.2 NAND_FLASH驅動程序
NAND_FLASH的驅動主要包括芯片的復位,ID的正確讀取,塊的擦除,和頁的寫入和讀取幾個操作。此外NAND_FLASH允許要2%的壞塊,在編寫驅動時要做好NANDFLASH的壞塊的統(tǒng)計與管理,壞塊的識別主要是讀取塊中第一頁的第6字節(jié)的1個WORD是否為FF來判斷塊的好壞。為了便于統(tǒng)計壞塊和存儲管理須在調用NAND_FLASH內存管理函數(shù)時建立壞塊統(tǒng)計表,系統(tǒng)不斷使用會增加壞塊的數(shù)量,在每次系統(tǒng)啟動時都可以通過調用內存管理函數(shù)來更新壞塊表實現(xiàn)對內存的最優(yōu)管理以提高系統(tǒng)的性能。壞塊管理流程如圖5所示。
NAND_FLASH驅動主要步驟:
(1)向指令寄存器寫入0xFF使芯片復位;
(2)調用Unsigned int check_Flash_Id(void)函數(shù)讀取芯片ID:
For(i=0;i10;i++);id=Nand_IO8;id+=Nand_IO; //讀出2個字節(jié)即芯片ID
(3)調用NAND_manage()函數(shù)做壞塊管理;
(4)調用Unsigned int Erase_Block(unsigned intblock)實現(xiàn)塊的擦除;
(5)調用int Write_page()和int Read_page()寫入和讀出頁數(shù)據(jù)。
2.3 LCD驅動程序設計
在系統(tǒng)中LCD驅動程序主要是對屏幕顯示的初始化包括字符顯示高度和寬度、行字符顯示數(shù)、顯示頻率的設置以及顯示點位移設置、顯示合成設置、休眠模式設置、光標形狀設置、光標指針設置等操作。
LCD驅動LCD_Initialize(void)主要步驟:
(1)調用LCD_WriteCommand(SYSTEM_SET);用于系統(tǒng)初始化。
(2)調用LCD_WriteCommand(SCROLL);用于顯示域設置。
(3)調用LCD_WriteCommand(HDOT_SCR);用于光標點位移設置。
(4)調用LCD_WriteCommand(OVLAY);用于顯示合成設置。
(5)調用LCD_WriteCommand(CSRFORM);
LCD_WriteData(0x07);LCD_WriteData(0x87);用于初始化光標形狀。
設計好驅動后利用ADSl.2編譯器將程序燒至RAM進行調試,可根據(jù)屏幕顯示字符尺寸大小及適宜程度再做修改驅動程序直至滿意。
3 系統(tǒng)調試
當設計好硬件系統(tǒng)后,要對電路板進行整體調試看各功能模塊是否正常,值得注意的是在設計NAND_FLASH接口電路時不能將ALE,CLE,WP,R/B全部連接到STR710的地址線上否則會引起兩者間的時序不匹配。在設計NAND_FLASH文件系統(tǒng)時采用F16系統(tǒng)可根據(jù)系統(tǒng)需要修改ST公司提供的F16文件系統(tǒng)代碼。
4 結 語
該設計是基于ARM芯片的STR710嵌入式PDA系統(tǒng),很好實現(xiàn)了硬件系統(tǒng)的設計以及LCD顯示器、NAND_FLASH的驅動程序、基于F16文件系統(tǒng)在NAND_FLASH大容量數(shù)據(jù)的文件存儲管理。隨著信息化、智能化、網(wǎng)絡化的快速發(fā)展,嵌入式PDA技術也將獲得廣闊的發(fā)展空間。
評論