版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、ARM和LINUX系統(tǒng)下嵌入式USB主機(jī)的設(shè)計(jì)摘要:根據(jù)實(shí)際應(yīng)用中嵌入式系統(tǒng)常需要具備USB 主機(jī)功能而大多數(shù)微處理芯片沒有集 成這一功能的實(shí)際情況,提出了一套基于S3C44B0X 和SL811HST 的系統(tǒng)解決方案。本系統(tǒng)以 ARM7 核心板加USB 擴(kuò)展板為硬件實(shí)現(xiàn)方法;在ucLinux 系統(tǒng)下實(shí)現(xiàn)USB 驅(qū)動(dòng)程序的編寫和 加載。該系統(tǒng)成本低廉,運(yùn)行穩(wěn)定,適合應(yīng)用于手持式設(shè)備上及野外工作場(chǎng)合。 關(guān)鍵詞:ARM7,ucLinux,USB 主機(jī),驅(qū)動(dòng)程序1 引言 通用串行總線(Universal
2、;Serial Bus,即USB是一種新型的高速串行總線,作為一種 快速、靈活的總線接口,已經(jīng)在電子產(chǎn)品中廣泛應(yīng)用。同時(shí)人們對(duì)USB的期望也越來(lái)越高, 希望USB能應(yīng)用在各種計(jì)算機(jī)領(lǐng)域中。但是,由于USB通信模型是一種Host/Slave主從式結(jié)構(gòu), 經(jīng)由USB總線進(jìn)行通信的雙方必須有一方在通信控制中擔(dān)當(dāng)主機(jī),而兩個(gè)USB設(shè)備之間則無(wú)法 直接進(jìn)行基于USB的數(shù)據(jù)交換。這就大大限制了USB在嵌入式設(shè)備中的應(yīng)用。 ARM( Advanced RISC Machine作為一種低功耗、高性能的32位嵌入式微處理器,在中 高端嵌入式設(shè)備開發(fā)中有著廣泛的應(yīng)用。有些A
3、RM芯片的生產(chǎn)廠商在以ARM為內(nèi)核的微處理器 中集成了USB主機(jī)控制器,但是,更多的ARM處理器是不帶USB主機(jī)功能的。解決這一問題的 方法就是在需要使用USB設(shè)備的嵌入式系統(tǒng)中外擴(kuò)一片USB主機(jī)控制器芯片,使之具有與USB 設(shè)備進(jìn)行數(shù)據(jù)傳輸?shù)哪芰?。本設(shè)計(jì)考慮設(shè)計(jì)一種USB主、從機(jī)一體化的外部擴(kuò)展模塊,通過(guò) 簡(jiǎn)單地改變跳線,使得ARM核心的嵌入式設(shè)備既可作為USB主機(jī),又可以作為USB從機(jī)。 2 總體設(shè)計(jì) 由于目前USB從機(jī)的硬件及軟件方面的開發(fā)已經(jīng)比較成熟,可以直接使用現(xiàn)有的資源, 所以本設(shè)計(jì)主要討論USB主機(jī)功能的實(shí)現(xiàn),目標(biāo)任務(wù)是ARM核心板能夠讀寫外接USB設(shè)備,這 里選擇最常
4、用的U盤,實(shí)現(xiàn)讀、寫U盤數(shù)據(jù)。 系統(tǒng)分為ARM核心板和SL811HST擴(kuò)展板兩大部分。核心板是一個(gè)由ARM7微處理器、FLASH、 SDRAM 、JTAG口和串口組成的最小系統(tǒng)。ARM處理器選用的是三星公司的S3C44B0X,這是一 款基于ARM7TDMI內(nèi)核的微處理器,具有低功耗、高性能的特點(diǎn)。FLASH用來(lái)存放ucLinux操作 系統(tǒng)和一些十分重要的數(shù)據(jù),SDRAM則是操作系統(tǒng)和應(yīng)用程序的運(yùn)行空間、數(shù)據(jù)及堆棧區(qū), JTAG口和串口用于下載和調(diào)試。擴(kuò)展板主要由USB主控芯片及其外圍電路和USB主、從接口構(gòu) 成。USB主控制芯片選用的是Cypress公司的SL811HST,這是一款雙
5、功能的控制芯片,通過(guò)設(shè) 置開關(guān)既可以用來(lái)做主機(jī)又可以做從機(jī)。USB接口分為主機(jī)接口和從機(jī)接口,與主控芯片功 能配套。 3 硬件電路 Flash存儲(chǔ)器是一種可在系統(tǒng)進(jìn)行電擦寫,掉電后信息不丟失的存儲(chǔ)器。常用的Flash 為8位或16位的數(shù)據(jù)寬度,編程電壓為單3.3V。系統(tǒng)中選用一片16位的Flash存儲(chǔ)器 SST39VF1601,單片存儲(chǔ)容量2M,用于存放操作系統(tǒng)和程序代碼,系統(tǒng)上電或復(fù)位后從此獲 得第一條指令并開始執(zhí)行,因此,應(yīng)將Flash存儲(chǔ)器配置到BANK0,即將S3C44B0X的nGCS<0> 接到其片選引腳CE#端;將S3C44B0X的OM1:0置為10,選擇BA
6、NK0為16位工作方式。 與Flash存儲(chǔ)器不同,SDRAM不具有掉電保持?jǐn)?shù)據(jù)的特性,但其存取速度大大高于Flash 存儲(chǔ)器,因此,它在系統(tǒng)中主要用作程序的運(yùn)行空間、數(shù)據(jù)及堆棧區(qū),系統(tǒng)及用戶堆棧、運(yùn) 行數(shù)據(jù)也都存放在其中。系統(tǒng)中選用一片HY57V641620HG,它的存儲(chǔ)容量為8M,工作電壓為 3.3V,16位數(shù)據(jù)寬度。1620的CS與S3C44B0X的nGCS6連接。 JTAG接口主要是用來(lái)實(shí)現(xiàn)芯片的嵌入式調(diào)試及在系統(tǒng)編程的功能,如對(duì)Flash器件進(jìn)行 編程等。串口的主要作用是向計(jì)算機(jī)傳輸信息,這些信息可以在計(jì)算機(jī)的超級(jí)終端上顯示, 以便于調(diào)試程序時(shí)監(jiān)測(cè)程序的內(nèi)部變量值;在ucLinux操作
7、系統(tǒng)運(yùn)行時(shí),串口將用來(lái)顯示它的 啟動(dòng)信息和運(yùn)行狀態(tài),向操作系統(tǒng)發(fā)送命令對(duì)其進(jìn)行控制也需要通過(guò)串口來(lái)完成。 ARM核心板的硬件組成如圖1所示: Cypress公司的SL811HST芯片是一款嵌入式的USB主機(jī)/從機(jī)控制器,它的雙功能端口既 可作為USB主機(jī)又可作為從機(jī)來(lái)支持全速或低速的USB器件,能夠與單片機(jī)、DSP和ARM等實(shí)現(xiàn) 無(wú)縫接口。數(shù)據(jù)線為8位,只需要9根線用于系統(tǒng)的數(shù)據(jù)通訊,16個(gè)內(nèi)部寄存器,可以對(duì)USB Host進(jìn)行充分的控制。內(nèi)部多達(dá)256字節(jié)的RAM,為USB傳輸建立了足夠的緩沖區(qū)。它的主要 優(yōu)點(diǎn)有:通過(guò)其M/S引腳對(duì)主/從模式方便的進(jìn)行選擇;提供全速和低速2種USB總線速度方
8、式; 硬件自動(dòng)產(chǎn)生幀起始包SOF和CRC5/16校驗(yàn);片上集成了接口引擎(SIE)、單端口根Hub、USB 收發(fā)器和256B的SRAM,其中0x000x0F共16個(gè)字節(jié)是寄存器區(qū),其余的240B是數(shù)據(jù)緩沖區(qū)。 SL811HS只有一根地址線A0。A0=1用于設(shè)定偏移量,A0=0用于讀寫數(shù)據(jù)。讀寫數(shù)據(jù)應(yīng)該首先 指定偏移量,然后實(shí)現(xiàn)讀取時(shí)序。A0與ARM的ADDR0相連。nCS和ARM的nGCS2相連,即把SL811HST 分配到ARM的外部I/O口02。 SL811HST與S3C44B0X的連接如圖2所示: 圖 2 SL811HST 與S3C44B0X 連接
9、圖 4 軟件系統(tǒng) 本設(shè)計(jì)的軟件系統(tǒng)是在Linux環(huán)境下編寫調(diào)試運(yùn)行的,前期工作為下載ucLinux內(nèi)核包, 打補(bǔ)丁包等。ucLinux是專門針對(duì)如ARM7這類無(wú)MMU的CPU而設(shè)計(jì)的,它主要由以下幾個(gè)部分 構(gòu)成:BootLoader、內(nèi)核初始化、系統(tǒng)調(diào)用函數(shù)/捕獲函數(shù)、設(shè)備驅(qū)動(dòng)和文件系統(tǒng)。其中 BootLoader被用來(lái)初始化系統(tǒng)板上的硬件資源,必須根據(jù)系統(tǒng)板上不同的硬件資源進(jìn)行相應(yīng) 的配置。本系統(tǒng)中主要是更改了FLASH和SDRAM的容量及數(shù)據(jù)寬度,開啟了外部I/O口2并設(shè)定 為8位數(shù)據(jù)寬度以用來(lái)配置SL811HST,并把它的基地址設(shè)定為0x012000000完成對(duì)源代
10、碼的修 改之后就可以進(jìn)行內(nèi)核的編譯。編譯是在裝有Linux及所需的交叉編譯工具鏈的計(jì)算機(jī)上來(lái) 進(jìn)行的,編譯生成的image.ram文件可以下載到SDRAM中直接運(yùn)行,image.rom文件可以燒寫 到FLASH中,系統(tǒng)上電或重啟后,將從FLASH的0x0地址處開始執(zhí)行,對(duì)硬件資源進(jìn)行初始化 后進(jìn)入ucLinux。 從Linux2.4內(nèi)核以后,Linux的設(shè)備驅(qū)動(dòng)中加入了對(duì)USB的支持,ucLinux也秉承了這一 特點(diǎn)。本設(shè)計(jì)采用內(nèi)核編譯的方式加載USB驅(qū)動(dòng),將驅(qū)動(dòng)程序的源代碼加進(jìn)ucLinux系統(tǒng)內(nèi)核, 編譯移植到嵌入式系統(tǒng),系統(tǒng)啟動(dòng)后將自動(dòng)加載驅(qū)動(dòng)。 編譯過(guò)程如下: 1:在ucLinux內(nèi)核
11、的USB驅(qū)動(dòng)目錄中添加如下三個(gè)文件:s181lhusb.c、sl8llh.h、 s1811husb.h。; 2:編輯/uclinux-s2cev40/linux-2.4.x/drivers/usb/config.in文件。修改這個(gè)文件 的內(nèi)容加入對(duì)SL811HST的描述語(yǔ)句: dep_tristateSupport for USBCONFIG_USB $CONFIG_PCI if“$CONFIG_USB”=“y” o“$CONFIG_USB”=“m”;then bool USB verbose debug mess
12、ages C0NFIG_USB_DEBUG comment Miscellaneous USB options bool Preliminary USB device filesys temCONFIG_USB_DEVICEFS if “$CONFIG_EXPERIMENTAL”= “Y”;then bool Enforce USB bandwidth allocation (EXPERIMENTALC0NFIG
13、_USB_BANDWIDTH else define_bool CONFIG_USB_BANDWIDTH n fi bool Long timeout for slow-responding devices(some MGE Ellipse UPSes CONFIG_USB_L0NG_TIME0UT 3:修改MAKEFILE文件,添加如下語(yǔ)句: ifeq ($(CONFIG-USB-DEBUG.y L_OBJS+=sl8llh-usb.O endif 4:編輯/uclinux-s3ce
14、v40/linux-2.4.x/drivers/usb/sl811h_usb.c文件,添加如下代 碼: #ifdef C0NFIG_USB_DEBUG #define DEBUG #else #undef DEBUG #endif #SL811HS/T-USB Host Controller driver INCLUDEDIR =usrsrc1inuxinclude CFLAGS=-D_KERNEL_-DM0DULE-0-Wall-static-I$(INCLUDEDIR VER=$(shell awk-F”
15、60;RELprint$2 $(INCLUDEDIR/linux/version.h all:sl8llh-usb.O sl8llh-USB.O:sl811h-usb.csl8llh-usbhsl8llh.h gcc s18llh-usb.c c $(CFLAGS #End this file 5:在/user/local/src/uClinux-s3cev40/fs/dev中增加一個(gè)設(shè)備文件。在 /user/local/src/uClinux-s3cev40/fs/devfs下執(zhí)行 mknod usb0 c 12
16、7 0 mknod usb1 c 127 1 6:執(zhí)行make xconfig,用戶內(nèi)核設(shè)置選擇y; 7:執(zhí)行make dep; 8:執(zhí)行make。 USB 設(shè)備驅(qū)動(dòng)程序被編譯進(jìn)ucLinux 內(nèi)核,包含在image.bin 文件中。在系統(tǒng)啟動(dòng)時(shí), USB 設(shè)備驅(qū)動(dòng)就自動(dòng)執(zhí)行了。 5 總結(jié) 本文作者創(chuàng)新點(diǎn):巧妙利用ucLinux 內(nèi)核模塊,簡(jiǎn)化開發(fā)過(guò)程,節(jié)約成本。 本設(shè)計(jì)以u(píng)clinux 嵌入式操作系統(tǒng)為平臺(tái),充分發(fā)揮了SL811HST 芯片的H
17、ost/Slave 兩種模式 的作用, 整套系統(tǒng)上電運(yùn)行結(jié)果證明,本系統(tǒng)設(shè)計(jì)能夠順利的讀寫U 盤數(shù)據(jù),并且達(dá)到USB1.1 的全速。此系統(tǒng)價(jià)格低廉,實(shí)現(xiàn)簡(jiǎn)單有效。為嵌入式系統(tǒng)添加USB 主機(jī)接口,使得USB 能應(yīng)用在沒 有PC 的領(lǐng)域中,真正實(shí)現(xiàn)USB 點(diǎn)對(duì)點(diǎn)的通訊。在需要野外大量采集記錄數(shù)據(jù)的場(chǎng)合,如勘測(cè),氣 象等領(lǐng)域,嵌入式USB 主機(jī)方便攜帶;在需要遠(yuǎn)距離傳輸數(shù)據(jù)的場(chǎng)合,在USB 設(shè)備上增加無(wú)線網(wǎng)卡, 數(shù)據(jù)就可以實(shí)時(shí)傳送,等等。 本設(shè)計(jì)如應(yīng)用于中等規(guī)模的電子公司,估計(jì)每年可節(jié)約成本100 萬(wàn)圓以上。 責(zé)任導(dǎo)師批注:論文敘述清楚,無(wú)文字錯(cuò)誤,不涉及機(jī)密,不是一稿多投。 粟梅 參考文獻(xiàn) 1 SL811
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 透水混凝土透水混凝土游樂場(chǎng)銷售合同
- 作文主題04 快樂游戲-四年級(jí)語(yǔ)文作文主題訓(xùn)練
- 九年級(jí)化學(xué)上冊(cè)《6.2 二氧化碳制取的研究》教學(xué)設(shè)計(jì) (新版)新人教版
- 二年級(jí)信息技術(shù)上冊(cè) 第19課帶變量的過(guò)程教案 北京版
- 2024秋高中化學(xué) 主題2 攝取益于健康的食物 課題2 平衡膳食教案 魯科版選修1
- 2024-2025學(xué)年高中歷史 專題一 中國(guó)傳統(tǒng)文化主流思想的演變 三 宋明理學(xué)教學(xué)教案 人民版必修3
- 2024年四年級(jí)英語(yǔ)上冊(cè) Unit 5 Dinner is ready The fourth period(第四課時(shí))教案 人教PEP
- 廣東省陽(yáng)東廣雅中學(xué)七年級(jí)信息技術(shù)《16網(wǎng)上交流信息》教案 新人教版
- 2024秋七年級(jí)英語(yǔ)上冊(cè) Unit 5 Family and Home Lesson 25 Jenny's Family教案 (新版)冀教版
- 2023七年級(jí)英語(yǔ)下冊(cè) Unit 10 I'd like some noodles說(shuō)課稿 (新版)人教新目標(biāo)版
- (完整版)英語(yǔ)高頻詞匯800詞
- DB31T 1249-2020 醫(yī)療廢物衛(wèi)生管理規(guī)范
- 《一年級(jí)語(yǔ)文拼音總復(fù)習(xí)》優(yōu)質(zhì)課課件
- 物業(yè)管理員(三級(jí))職業(yè)技能鑒定考試題庫(kù)(含答案)
- 生成式對(duì)抗網(wǎng)絡(luò)課件
- 恒生電子估值系統(tǒng)用戶手冊(cè) FD
- 采購(gòu)項(xiàng)目技術(shù)、服務(wù)和其他要求
- 腸梗阻護(hù)理和查房課件
- 世紀(jì)海上絲綢之路
- 蘇教版數(shù)學(xué)二年級(jí)上冊(cè)《觀察物體》課件(合肥市公開課)
- 八年級(jí)歷史上冊(cè)材料題匯編
評(píng)論
0/150
提交評(píng)論