隨著嵌入式式技術的不斷發展,ARM處理器憑借其高性能、廉價、耗能低的優質特性而得到廣泛應用。文中主要針對貨車動態稱重系統中大量實時載重數據存取的需求,在ARM9嵌入式處理器和μC/OS-II操作系統基礎上,設計實現了一種SD卡文件系統。該系統具有實時性強、存取速率高、易維護,易移植等特點。
1 硬件接口電路設計
本系統硬件開發平臺處理器為S3C2440A,是三星公司推出的16/32位RISC微處理器,ARM920T內核,主頻400 MHz,最高可達533 MHz,內部具有豐富的系統外圍控制器和多種通信接口。SD卡支持SPI和SD兩種通信模式,S3C2440A具有SD卡接口,支持SD總線模式,所以不再像低端的ARM處理器那樣采用SPI模式,而是采用SD總線模式,這樣可以大大提高SD卡的讀寫速度。S3C2440A與SD卡讀寫器的接口電路如圖1所示。
SD卡的DAT0~DAT3、CLK(時鐘線)和CMD(命令線)分別連接到S3C2440A的SDDATA0~SDDATA3、SDCLK和SDCMD引腳。SD卡支持單線和寬總線的數據傳輸,寬總線數據一次傳4位,數度更快,因此,此設計采用寬總線方式。
2 SD卡文件系統的設計與實現
μC/OS-II是一種可移植的,可植入ROM的,可裁剪的,搶占式的,實時多任務小型的嵌入式操作系統,它采用可剝離式內核實施任務調度,實時性很強,而且每個任務具有唯一的優先級,能夠保證就續表中任務優先級最高的任務優先執行。μC/OS-II大部分代碼是用移植性很高的C語言編寫的,只極少部分與處理器密切相關的部分代碼用匯編語言編寫,因此只需要做很少的工作就可以很方便地將它移植到各種不同構架的微處理器上。
為了增強軟件的可移植性,易維護性,程序設計時采用層次化,模塊化設計。模塊化結構如圖2所示,除了用來進行管理的操作系統外,共分為4個模塊,包括SD卡底層驅動,文件系統,API接口,用戶應用程序。底層驅動完成SD卡初始化,以及實質上的讀寫功能;文件系統采用PC機普遍支持的FAT32文件系統規范來設計,完成文件的創建,讀寫,刪除功能;API接口封裝文件系統提供的函數,供上層應用使用;用戶應用程序通過調用文件系統提供的API函數,完成相應的功能。各個模塊的具體實現下面會做以說明。
2.1 底層驅動設計
2.1.1 SD卡初始化
SD卡讀寫操作都是基于命令的,通過向SD卡發送命令并讀取命令的響應來實現對SD卡的控制。在SD卡讀寫之前,首先要進行初始化操作。這是確保SD卡能進行正常數據讀寫的前提,SD卡初始化完成了SD卡上電,確認,設置邏輯地址,使其進入傳輸狀態以及設置總線帶寬幾大主要工作。需要注意的是,在發送使SD卡空閑命令CMD0之前至少等待74個時鐘,確保SD卡進入SD總線模式。SD卡初始化代碼編寫如下:
2.1.2 SD卡讀寫實現
初始化完戚之后,就可對SD卡進行讀寫操作,通過設置SDI數據控制寄存器SDIDCON來確定SD卡的讀寫長度,讀操作時數據長度作沒有明確限制,寫操作時,每次寫的長度必須為BLOCK的倍數。SD卡的讀寫可以一次性讀寫單塊數據,也可以一次性讀寫多塊數據,多塊數據的讀寫結束時,要發送CMD12結束指令。主要實現函數:Write_Card_Block()-寫入單塊數據;Write_Card_Data()-寫入多塊數據;Read_Card_Block()-讀多塊數據;Read_Card-Data()-讀多塊數據。
2.2 文件系統設計
2.2.1 FAT32文件系統概述
Windows95 OSR2和Windows 98開始支持FAT32文件系統,它是對早期DOS的FAT文件系統的增強,由于文件系統的核心一文件分配表FAT擴充為32位,所以稱為FAT32文件系統。FAT32包含DBR、保留扇區、FAT1、FAT2(第一個FAT的備份)、根目錄、數據區5部分。DBR(Dos Boot Rec ord)是操作系統引導記錄區;保留扇區是為了對DBR作備份或留待以后升級時用;文件分配表區共保存了兩個相同的FAT表,文件所占用的存儲空間(簇鏈)及空閑空間的管理都是通過FAT實現的;FAT32根目錄區(ROOT區)不再是固定區域、固定大小,可看作是數據區的一部分;數據區用來存放真正要記錄的文件數據,本系統定義的一簇為4K個字節。
2.2.2 文件系統初始化
文件系統初始主要是讀取SD卡的DBR扇區(0扇區),并分析該扇區內容,從而獲取每扇區字節數,每簇扇區數,FAT開始扇區號,根目錄開始扇區號等關鍵信息,為文件的創建,讀寫等操作做準備,文件系統初始化函數代碼如下:
2.2.3 文件創建
SD卡上創建文件或目錄的過程就是在文件目錄表FDT中申請登記項的過程,為此程序設計時定義了如下結構體:
在文件目錄項FDT中申請登記項動作就是通過對上述結構體的操做來完成的,操作流程,也是文件創建流程如圖3所示,當把SD卡插入卡插槽時,系統首先初始化SD卡,即讀取SD卡的DBR扇區(0扇區)獲取相關信息,接下來打開所要創建文件的路徑,如果路徑不存在,創建該路徑,如果存在,搜尋FAT表,找空閑簇。再接下來把要創建的文件的相關信息(文件名,文件大小,創建時間,屬性等)填入上述結構體,把該結構體寫入文件目錄項FDT,相應的扇區寫入數據,最后更新FAT鏈表。文件創建實現函數為FAT32_Creat_File()。
2.2.4 文件讀寫
文件系統對SD卡上文件的管理都是以簇為單位進行的。要讀文件,就要首先找到文件,查找文件就是把文件名和文件目錄項FDT中的文件名匹配。如果匹配不成功,說明該文件不存,此時就可以利用函數FAT32_Creat_Flie()創建。如果匹配成功讀就找到了該文件,在匹配成功的那個目錄登記項中找到該文件的起始簇號,知道了該起始簇號,就可以根據FAT表中的簇鏈關系找到到第2簇,第3簇,直到最后一簇文件結束。寫文件時,由于FAT2是FAT1的備份,要保證兩者的一致性,就要對它們做同樣的寫操作。主要的函數有:FAT32_Open_File()-打開文件;FAT32_Read_File()-讀文件;FAT32_Write_File()-寫文件;FAT32_Close_File()-關閉文件。
2.2.5 文件刪除
FAT32文件系統中所謂的刪除實際上只是把文件名稱的第一個字母改成一個特殊字符(在文件目錄登記項上做一個刪除標記),把文件在FAT表中占用的簇標記為空簇,但文件包含的數據仍在磁盤上,下次將新的文件保存到磁盤時,這些簇可能被新的文件使用,從而覆蓋原來的數據。因此,只要不保存新的文件,被刪除文件的數據實際上仍舊完整無缺地保存在磁盤上。文件刪除函數為:FAT32_DeleteFile()。
2.3 API接口設計
API接口模塊要是向用戶應用程序提供文件的創建讀寫刪除功能,該模塊通過調用文件系統的相關函數來實現。主要的借口函數有:OS_ CreateFile()-創建文件;OS_OpenFile()-打開文件;OS_WriteFile()-文件寫入數據;OS_WriteFile()-讀文件數據;OS_CloseFile()-關閉文件;OS_DeleteFile-刪除文件。
2.4 用戶應用程序設計
該模塊通過直接運用文件系統提供的API接口函數完成對稱重數據信息的操作,只需要對μC/OS-II操作系統直接負責,并不需要考慮文件系統的具體實現問題以及底層硬件驅動問題。
3 結束語
本設計作為貨車車載動態稱重系統的數據存儲模塊,采用容量大、體積小、性價比高的存儲介質SD卡來存儲長時間段的測量數據,對FAT32進行了裁剪,并結合SD卡的底層的讀寫程序,從而實現了嵌入式SD卡文件系統,這樣就能很方便通過上位機對SD卡記錄貨車稱重數據進行查詢,綜合分析以及備份。同時該方法為其它數據采集系統提供了一種非易失性存儲器的解決方案,采集到的數據會以標準文件的格式記錄到SD卡上,便于文件的統一管理。
上一篇:基于RFID的醫療器械智能控制系統設計
下一篇:基于嵌入式Linux平臺的指紋門禁系統
推薦閱讀
史海拾趣
隨著業務的發展和市場的擴大,ETA-USA開始在全球范圍內布局。公司先后在中國、歐洲等地設立了分公司或辦事處,以更好地服務當地客戶。這一全球擴張策略不僅增強了公司的市場競爭力,也為其帶來了更多的商業機會和合作伙伴。
Bkc深知人才是企業發展的核心動力。因此,公司高度重視研發團隊的建設和人才培養。通過引進業內頂尖的技術人才和提供完善的培訓機制,Bkc逐漸打造出一支技術實力雄厚的研發團隊。這支團隊不僅為公司帶來了源源不斷的技術創新,也為公司的長遠發展奠定了堅實的基礎。
隨著電子技術的快速發展,廣東奧科公司意識到只有不斷創新才能在市場中立足。公司加大了對研發的投入,引進了一批高素質的研發人才,并建立了完善的研發體系。經過多次嘗試和實驗,廣東奧科公司成功開發出了多款具有創新性和競爭力的電子產品,這些產品不僅性能卓越,而且設計獨特,深受消費者的喜愛。這些技術突破和產品創新為廣東奧科公司贏得了市場的認可,也推動了公司的快速發展。
在國內市場取得一定成績后,廣東奧科公司開始積極拓展國際市場。公司參加了多個國際電子展會,與國際知名企業建立了合作關系,成功將產品打入國際市場。同時,廣東奧科公司還注重品牌建設,通過提升產品質量和服務水平,逐漸樹立了良好的品牌形象。這些努力使得廣東奧科公司在國際市場上也獲得了廣泛的認可和好評。
Artesyn Embedded Technologies自1981年成立以來,一直致力于電源產品的研發與創新。在20世紀90年代,公司推出了一款具有突破性的精密電源產品,該產品以其高效能、低能耗的特點迅速在市場中獲得了認可。這一成功不僅使公司獲得了更多的市場份額,也為后續產品的研發奠定了堅實的基礎。
在各位網友的支持下,HELLODSP 的QQ交流群聯盟又添新成員: 轉載請注明出自DSP交流網 DSP學習第一論壇 DSP技術應用與推廣平臺 DSP開發服務平臺 http://www.hellodsp.com/bbs/,本貼地址:http://www.hellodsp.com/bbs/viewthread.php?tid=7399 TMS3 ...… 查看全部問答∨ |
|
哪位高人給我傳下萬利STM3210B-LK1板子串口調試程序 本人菜鳥 我那個板子程序為兩個USART之間通信的程序,我想寫個與電腦通信的程序,寫了兩天了,都不成功,發收都沒有反應,無限郁悶中!也找了很多例子好像都不行,哪位大俠給個例子看看,最好是在萬利STM3210B-LK1板子跑通了的。先謝謝大家了! 我QQ ...… 查看全部問答∨ |
|
這里有做CE很多年的,也有剛入行不久的朋友。入行很久的朋友說說你對CE未來的看法,對自己職業生涯的看法。剛入行的朋友談談入這行的動機吧。 背景:MS做了CE, Mobile很多年,這兩個平臺一直不溫不火。最近android, iphone,還有新貴meego火得不 ...… 查看全部問答∨ |
現在我想自己做一個軟鍵盤,琢磨了好久現在僅只能修改PUBLIC下面的SIP代碼,這樣非常難調試,所以有以下問題請教大家: 1,我現在做到了用驅動的方式寫SIP,但還是沒有辦法調試,因為不是開 ...… 查看全部問答∨ |
今天wangfucong問到了使用CCS如下下載Hex文件,以前收集了一些資料是介紹這方面東西的,MSP430JTAG Adapter可以支持JTAG和BSL下載,其中MspFet.zip就是MSP430 Jtag Adapter的部分資料,其余的兩個技術文檔都介紹到了關于MSP430的Hex文件。… 查看全部問答∨ |
|
俺是新人,單位有可能用zigbee做產品,請問,需要支付什么費用么,還是說直接購買芯片比如TI的CC2530就可以呢,是不是需要加入什么zigbee聯盟,每年需要支付一定費用呢?… 查看全部問答∨ |
在開關電源設計中PCB板的物理設計都是最后一個環節,如果設計方法不當,PCB可能會輻射過多的電磁干擾,造成電源工作不穩定,以下針對各個步驟中所需注意的事項進行分析: 在開關電源設計中PCB板的物理設計都是最后一個環節,如果設計方法不當,PCB ...… 查看全部問答∨ |