當(dāng)前位置:首頁(yè) > 智能硬件 > 智能硬件
[導(dǎo)讀]引言越來(lái)越多的嵌入式設(shè)備與外部連接要求更簡(jiǎn)潔、方便、智能化,所以,USB接口在嵌入式設(shè)備中的應(yīng)用會(huì)越來(lái)越廣泛。本文是“信息家電網(wǎng)絡(luò)控制平臺(tái)技術(shù)”項(xiàng)目中USB接口的實(shí)際設(shè)計(jì)部分。在該項(xiàng)目中,硬件平臺(tái)

引言

越來(lái)越多的嵌入式設(shè)備與外部連接要求更簡(jiǎn)潔、方便、智能化,所以,USB接口在嵌入式設(shè)備中的應(yīng)用會(huì)越來(lái)越廣泛。本文是“信息家電網(wǎng)絡(luò)控制平臺(tái)技術(shù)”項(xiàng)目中USB接口的實(shí)際設(shè)計(jì)部分。在該項(xiàng)目中,硬件平臺(tái)采用了S3C4510B微處理器,軟件系統(tǒng)是在mClinux下開(kāi)發(fā)的,項(xiàng)目結(jié)題后,組建了USB總線的家居網(wǎng)絡(luò)系統(tǒng),實(shí)現(xiàn)了信息家電的上網(wǎng)。本文介紹了該嵌入式系統(tǒng)設(shè)計(jì)中的USB模塊軟硬件設(shè)計(jì)。

USB接口硬件設(shè)計(jì)

S3C4510B沒(méi)有內(nèi)置的USB控制器,但提供了兩個(gè)GDMA通道,可以滿足USB高速數(shù)據(jù)傳遞的要求。本著與S3C4510B能銜接工作、自身適合在嵌入式設(shè)備中應(yīng)用的原則,確定采用ISP1581高速USB接口芯片。

ISP1581概述和設(shè)計(jì)分析

ISP1581是一款低功耗、功能強(qiáng)的高速USB接口器件,它完全符合USB 2.0 規(guī)范,并為基于微控制器或微處理器的系統(tǒng)提供了高速USB通信能力。ISP1581支持高速USB系統(tǒng)的自動(dòng)檢測(cè),內(nèi)部通用DMA 模塊使得數(shù)據(jù)流很方便地集成。另外,多種結(jié)構(gòu)的DMA模塊實(shí)現(xiàn)了海量存儲(chǔ)的應(yīng)用。這種實(shí)現(xiàn)USB 接口的標(biāo)準(zhǔn)組件使得使用者可以結(jié)合微控制器,通過(guò)使用已有的結(jié)構(gòu)和減少固件上的投資,從而用最快捷的方法實(shí)現(xiàn)了最經(jīng)濟(jì)的USB外設(shè)解決方案。此外,ISP1581可理想地用于許多嵌入式外設(shè),例如打印機(jī)、掃描儀、DVD 和數(shù)碼相機(jī)等等。

ISP1581與S3C4510B電路的設(shè)計(jì)實(shí)現(xiàn)

了解了芯片引腳的使用方法,則可以設(shè)計(jì)出它和S3C4510B的連接電路,如圖1所示。

USB接口電路如圖2所示。在該圖中,1.5kW的電阻要求較高,阻值范圍必須是1.5kW±5%內(nèi)。

采用12MHz的晶振,以便與S3C4510B的晶振相匹配,電容的值一般為20pF左右,以使晶振更好地起振和消噪。

此外,設(shè)計(jì)印制電路板時(shí)要考慮減小信號(hào)之間的交叉干擾、電源干擾,降低噪聲對(duì)電路的影響,提高整個(gè)系統(tǒng)的可靠性。在本系統(tǒng)的電路板上,晶體振蕩電路對(duì)噪聲比較敏感,因此在設(shè)計(jì)這部分電路時(shí)特別注意使晶振電阻、電容等相關(guān)器件與微控制器盡可能靠近。在布線時(shí),使這部分電路的信號(hào)線不與其他任何信號(hào)線交叉。此外還采用了一些常規(guī)的降低噪聲和干擾影響的手段,包括盡可能增加地線和電源線的寬度,使用去耦電容,以及盡量減小元器件引腳長(zhǎng)度等等。

USB接口軟件設(shè)計(jì)

USB系統(tǒng)有三個(gè)基本組件:主控制器驅(qū)動(dòng)程序HCD、USB驅(qū)動(dòng)程序USBD和主機(jī)軟件。在嵌入式操作系統(tǒng)中,USB驅(qū)動(dòng)程序和操作系統(tǒng)內(nèi)核的框圖如圖3所示,其中USB類驅(qū)動(dòng)程序可以分別驅(qū)動(dòng)兩種類型的控制器UHCI和OHCI。當(dāng)PCI枚舉器發(fā)現(xiàn)USB主機(jī)控制器后,就會(huì)裝入相關(guān)的驅(qū)動(dòng)程序。在此基礎(chǔ)上開(kāi)發(fā)驅(qū)動(dòng)程序,實(shí)際上就是USB功能驅(qū)動(dòng)程序,即是控制一個(gè)給定的功能設(shè)備。本項(xiàng)目中的信息家電組網(wǎng),是用USB總線組建的家居網(wǎng)絡(luò),連接到USB設(shè)備的每一種類型的功能單元都必須要有功能驅(qū)動(dòng)程序。

ISP1581為微控制器接口提供了靈活的配置,在設(shè)計(jì)中采用了直接存儲(chǔ)器存取(DMA)方式。由于USB設(shè)備通過(guò)快速DMA方式來(lái)讀寫(xiě)數(shù)據(jù),因此在此作為字符設(shè)備進(jìn)行處理。

在mClinux系統(tǒng)內(nèi)核中有USB子系統(tǒng),它的作用是提供支持USB設(shè)備驅(qū)動(dòng)程序的API和USB的主機(jī)驅(qū)動(dòng)程序。它提供了許多數(shù)據(jù)結(jié)構(gòu)、宏定義和功能函數(shù)來(lái)對(duì)硬件或設(shè)備進(jìn)行支持。在mClinux下編寫(xiě)USB設(shè)備的驅(qū)動(dòng)程序,從嚴(yán)格意義上講,就是使用這些USB核心的子系統(tǒng)定義的數(shù)據(jù)結(jié)構(gòu)、宏和函數(shù)來(lái)編寫(xiě)數(shù)據(jù)的處理功能。

一般來(lái)說(shuō),在mClinux環(huán)境中編寫(xiě)USB分為如下幾個(gè)部分。

向系統(tǒng)注冊(cè)和注銷驅(qū)動(dòng)子程序

在mClinux系統(tǒng)里,通過(guò)調(diào)用register_chrdev向系統(tǒng)注冊(cè)字符型設(shè)備驅(qū)動(dòng)程序。還需定義一個(gè)__init usbdriver_init(void)的注冊(cè)函數(shù),如下:

int __init usbdriver_init(void)

{ int rc;

rc = register_chrdev(usbdevice _Major, "usbdevice", &usbdriver_fops);

if (rc < 0) {

printk(KERN_WARNING "usbdevice: can't get Major %dn",usbdevice_Major);

return rc; }

return 0; }

中斷服務(wù)子程序

中斷服務(wù)子程序完成對(duì)數(shù)據(jù)的處理,主要包括讀、寫(xiě)等操作,這些操作都是通過(guò)數(shù)據(jù)結(jié)構(gòu)file_operations中的open、write、close、read等命令進(jìn)行的。系統(tǒng)通過(guò)調(diào)用request_irq函數(shù)來(lái)申請(qǐng)中斷,通過(guò)free_irq來(lái)釋放中斷。為防止其他中斷的干擾,用save_flags(flags) cli()來(lái)關(guān)閉中斷,相關(guān)處理完畢,用restore_flags(flags) sti()來(lái)恢復(fù)。其中,填充驅(qū)動(dòng)程序子函數(shù)集struct file_operation結(jié)構(gòu)如下:

struct file_operations { loff_t (*llseek) (struct file *, loff_t, int);

ssize_t (*read) (struct file *, char *, size_t, loff_t *);

ssize_t (*write) (struct file *, const char *, size_t, loff_t *);

int (*readdir) (struct file *, void *, filldir_t);

unsigned int (*poll) (struct file *, struct poll_table_struct *);

int (*open) (struct inode *, struct file *);

int (*release) (struct inode *, struct file *);

int (*fsync) (struct file *, struct dentry *);}

I/O服務(wù)子程序

通過(guò)已注冊(cè)在系統(tǒng)/dev目錄下的設(shè)備文件,把設(shè)備映射為一個(gè)特別文件,其它程序使用這個(gè)設(shè)備的時(shí)候,只要對(duì)此特別文件進(jìn)行I/O操作就可以了。當(dāng)用戶調(diào)用時(shí),因?yàn)檫M(jìn)程的運(yùn)行狀態(tài)由用戶態(tài)變?yōu)楹诵膽B(tài),地址空間也變?yōu)楹诵牡刂房臻g。此時(shí),read、write中參數(shù)buf指向用戶程序的私有地址空間,所以不能直接訪問(wèn),必須通過(guò)memcpy_fromfs、memcpy_tofs系統(tǒng)函數(shù)來(lái)訪問(wèn)用戶程序的私有地址空間。

結(jié)語(yǔ)

鑒于USB的諸多優(yōu)點(diǎn)和靈活的數(shù)據(jù)傳輸方式,嵌入式USB設(shè)備必將在信息家電、工控等領(lǐng)域得到更廣闊的應(yīng)用。本文從硬件接口設(shè)計(jì)和驅(qū)動(dòng)程序編寫(xiě)兩個(gè)方面對(duì)嵌入式設(shè)備中USB的設(shè)計(jì)做了簡(jiǎn)要的介紹,研究成果已經(jīng)用在基于USB總線的智能家居網(wǎng)絡(luò)中,測(cè)試結(jié)果表明該接口運(yùn)行正常,數(shù)據(jù)傳輸?shù)雀鞣矫婢_(dá)到了技術(shù)標(biāo)準(zhǔn)要求。

參考文獻(xiàn)

1 蕭世文. USB2.0硬件設(shè)計(jì). 清華大學(xué)出版社,2002.10

2 廣州周立功單片機(jī)發(fā)展有限公司. ISP1581

更多計(jì)算機(jī)與外設(shè)信息請(qǐng)關(guān)注21ic計(jì)算機(jī)與外設(shè)頻道

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉