當(dāng)前位置:首頁 > 工業(yè)控制 > 工業(yè)控制
[導(dǎo)讀]系統(tǒng)闡述了USB1.1 OHCI 主機(jī)控制器IP 的功能、結(jié)構(gòu)、各功能模塊的電路設(shè)計(jì)和實(shí)現(xiàn)方法,介紹了主機(jī)串行接口引擎模塊及其時(shí)鐘和數(shù)據(jù)恢復(fù)電路以及并行CRC 算法的設(shè)計(jì)。

摘要:系統(tǒng)闡述了USB1.1 OHCI 主機(jī)控制器IP 的功能、結(jié)構(gòu)、各功能模塊的電路設(shè)計(jì)和實(shí)現(xiàn)方法,介紹了主機(jī)串行接口引擎模塊及其時(shí)鐘和數(shù)據(jù)恢復(fù)電路以及并行CRC 算法的設(shè)計(jì)。為了驗(yàn)證OHCI 主機(jī)控制器功能正確性,在中科SoC 虛擬驗(yàn)證平臺上對該主機(jī)控制器做了系統(tǒng)級模擬驗(yàn)證,驗(yàn)證結(jié)果證明了設(shè)計(jì)的正確性。
關(guān)鍵詞:USB 主機(jī)控制器;開放主機(jī)總線接口;數(shù)字鎖相環(huán);CRC

IP 就其本質(zhì)來講是一個(gè)能提供正確接口信號的功能模塊。隨著EDA 技術(shù)和半導(dǎo)體工藝技術(shù)的發(fā)展,集成電路的規(guī)模越來越大,設(shè)計(jì)越來越復(fù)雜,使用IP 核是一個(gè)必然趨勢。研究開發(fā)超大規(guī)模集成電路設(shè)計(jì)業(yè)亟需的、具有良好應(yīng)用前景的IP 核,積極推動(dòng)IP 核的應(yīng)用,對于我國集成電路產(chǎn)業(yè)的良性發(fā)展將會起到極大的促進(jìn)作用。USB 通用串行總線是眾多計(jì)算機(jī)廠商和電信廠商共同開發(fā)的用于計(jì)算機(jī)外設(shè)連通到計(jì)算機(jī)的規(guī)范。它日益成為一種主流的計(jì)算機(jī)接口標(biāo)準(zhǔn)。它包含3 大技術(shù)要素:主機(jī),集線器和功能。國外一些公司近年來相繼開發(fā)出基于上述3 個(gè)技術(shù)要素的IP,國內(nèi)一些IC 設(shè)計(jì)公司也開始在這些領(lǐng)域內(nèi)作研究,但由于USB 主機(jī)控制器IP 的設(shè)計(jì)一直是USB 系統(tǒng)設(shè)計(jì)中的難點(diǎn),成果較少。

作者遵循USB 規(guī)范和開放主機(jī)總線接口(Open HostController Interface, OHCI)規(guī)范,基于ASIC 流程開發(fā)出了USB1.1 OHCI 主機(jī)控制器IP。

 

在所有的實(shí)現(xiàn)中,主機(jī)控制器都必須提供基本相同的功能,主要包含狀態(tài)處理、串行化與反串行化、幀產(chǎn)生、數(shù)據(jù)處理、協(xié)議引擎、傳輸差錯(cuò)控制、遠(yuǎn)程喚醒、集線器、主機(jī)系統(tǒng)接口。根據(jù)這些要求,參考USB 規(guī)范和OHCI 規(guī)范,通過定義一組與主機(jī)系統(tǒng)存儲器交互的虛擬主機(jī)總線接口以及收發(fā)器接口,作者將設(shè)計(jì)分成若干部分,將每一部分需要完成的目標(biāo)功能單獨(dú)描述并驗(yàn)證,在此基礎(chǔ)上再作頂層的整合。進(jìn)行功能劃分后OHCI 主機(jī)控制器IP 的結(jié)構(gòu)如圖1。

主機(jī)控制器功能模塊設(shè)計(jì)

主機(jī)系統(tǒng)接口模塊

該模塊由兩個(gè)部分組成,主要功能是在主機(jī)系統(tǒng)與OHCI主機(jī)控制器之間建立高速的數(shù)據(jù)通道。按照數(shù)據(jù)傳輸?shù)陌l(fā)起者不同,可以分為HCI 主模塊和HCI 從模塊,前者負(fù)責(zé)發(fā)起對系統(tǒng)存儲器的讀寫操作,后者負(fù)責(zé)響應(yīng)主機(jī)系統(tǒng)或CPU 的讀寫操作。針對不同的SoC(System on a Chip)片內(nèi)總線,可以在主機(jī)系統(tǒng)接口模塊與片內(nèi)總線之間實(shí)現(xiàn)簡單的膠合邏輯,從而實(shí)現(xiàn)USB 主機(jī)控制器IP 的重復(fù)使用。

狀態(tài)控制模塊(USB State Control

它是列表處理器層次結(jié)構(gòu)的上層模塊,直接由OHCI 寄存器來控制。它實(shí)現(xiàn)了主狀態(tài)機(jī),可用來觸發(fā)列表處理器中較低層次的狀態(tài)機(jī)。主狀態(tài)機(jī)還可以生成一些控制信號,以便控制下列操作:傳輸SOF(Start of Frame)標(biāo)示、復(fù)位/恢復(fù)、向系統(tǒng)存儲器中的HCCA(Host Controller CommunicationArea)寫回每微秒的幀序號等。該模塊還實(shí)現(xiàn)了優(yōu)先級算法,該算法基于OHCI 寄存器決定當(dāng)前需要處理周期性列表還是非周期性列表,如果非周期性列表獲得優(yōu)先權(quán),它可以確定當(dāng)前應(yīng)該執(zhí)行的傳輸是控制傳輸還是批傳輸。

列表處理器模塊

它是整個(gè)IP 核最關(guān)鍵的控制器,實(shí)現(xiàn)了OHCI 規(guī)范規(guī)定的絕大部分協(xié)議。按照OHCI 規(guī)范,它有多個(gè)狀態(tài)機(jī)實(shí)現(xiàn)列表服務(wù)流、列表優(yōu)先級、ED/TD 服務(wù)、狀態(tài)寫回、TD 撤退等功能。它充當(dāng)一個(gè)控制器,連接HCI Master 和Host SIE,幫助它們在系統(tǒng)存儲器和USB 之間實(shí)現(xiàn)數(shù)據(jù)傳輸。它包含4個(gè)子模塊:列表服務(wù)流程模塊、端點(diǎn)描述符服務(wù)流程模塊、傳輸描述符服務(wù)流程模塊以及HCI Master 接口模塊。

數(shù)據(jù)FIFO 和數(shù)據(jù)FIFO 控制模塊

數(shù)據(jù)FIFO 模塊實(shí)現(xiàn)了一個(gè)寬度為8bit、深度為64byte的FIFO,它的主要作用是同步Host SIE 和HCI Master 之間的數(shù)據(jù)傳輸。數(shù)據(jù)FIFO 控制模塊實(shí)現(xiàn)了主機(jī)控制器的內(nèi)部數(shù)據(jù)FIFO 的方向控制邏輯,以便在USB 和系統(tǒng)存儲器間傳輸數(shù)據(jù)。

對于IN Packet,當(dāng)數(shù)據(jù)從端點(diǎn)接收時(shí),Host SIE 將其存儲在數(shù)據(jù)FIFO 中。當(dāng)所有數(shù)據(jù)收到(對GTD/ITD 而言)或數(shù)據(jù)FIFO 中的數(shù)據(jù)超過一定的門限(≥16byte),TD 狀態(tài)機(jī)發(fā)起一個(gè)寫命令通知HCI Master 接口模塊。HCI Master 接口模塊提供寫的起始地址,同時(shí)本模塊提供寫回的字節(jié)數(shù),觸發(fā)HCI Master 執(zhí)行一個(gè)寫周期。HCI Master 寫操作結(jié)束以后,它將控制返回到TDSF 的TD 狀態(tài)機(jī)。

類似的,對于OUT Packet,TD 狀態(tài)機(jī)通知本模塊從系統(tǒng)存儲器讀取數(shù)據(jù)。讀操作的地址和字節(jié)數(shù)由HCI Master 模塊來提供。若數(shù)據(jù)超過16byte,它將通過HCI Master 執(zhí)行多次操作。

主機(jī)控制器串行接口引擎模塊

本模塊主要用來完成USB 規(guī)范中協(xié)議處理部分的功能。它用作主機(jī)控制器的協(xié)議引擎,并且與列表處理器、數(shù)據(jù)FIFO 以及OHCI 寄存器相連接,此外它還實(shí)現(xiàn)了用來同步HSIE 和端口狀態(tài)機(jī)之間接口的控制邏輯。本模塊的數(shù)據(jù)流框圖如圖2 所示, 圖中HSIE 模塊工作在48MHz、打包模塊和拆包模塊工作在12MHz,因此需要異步邏輯在不同的時(shí)鐘域之間實(shí)現(xiàn)同步,為簡單起見,圖中省去了異步邏輯模塊和控制邏輯。

 

在USB 數(shù)據(jù)接收期間,D+和D-信號經(jīng)由差分接收器變成單端字位流,然后經(jīng)由DPLL 模塊提取時(shí)鐘和數(shù)據(jù)信息。在HSIE 的接收器中實(shí)現(xiàn)了大部分協(xié)議解釋功能, 諸如NRZI-NRZ 的轉(zhuǎn)變、位填充拆除、同步域檢測、SE0 檢測、CRC16 計(jì)算、超時(shí)邏輯、串并轉(zhuǎn)換、速度控制等。在拆包模塊中還實(shí)現(xiàn)了狀態(tài)機(jī)來檢測USB 的功能是否收到有效的握手信號。

在USB 數(shù)據(jù)發(fā)送期間,打包模塊根據(jù)列表處理器的要求確定需要發(fā)送的包類型。有3 種類型的包:標(biāo)示,數(shù)據(jù),握手包。如果是數(shù)據(jù)包,則需要進(jìn)行CRC16 校驗(yàn);如果是標(biāo)示包,則需要進(jìn)行CRC5 校驗(yàn);握手包不需要進(jìn)行CRC 校驗(yàn)。打包模塊隨后將字節(jié)流傳送給HSIE 的發(fā)送器進(jìn)行同步域添加、并串轉(zhuǎn)換、位填充、NRZ-NRZI 轉(zhuǎn)換等工作。限于篇幅,僅介紹其中的關(guān)鍵模塊:時(shí)鐘恢復(fù)和數(shù)據(jù)提取電路以及并行CRC 算法。

(1)    數(shù)字鎖相環(huán)(Digital Phase Lock Loop,DPLL)

由于USB 主機(jī)與USB 設(shè)備所采用的工作時(shí)鐘完全分離性,唯一的交互信息是USB 總線上的字位流,為了正確提取字位流中包含的數(shù)據(jù)信息,必須有一套機(jī)制從接收到的字位流中恢復(fù)時(shí)鐘信息。本文采用一種超前滯后型數(shù)字鎖相環(huán)(Lead Lag DPLL)來實(shí)現(xiàn)上述功能。LL-DPLL 時(shí)鐘恢復(fù)環(huán)路的原理如圖3。

 

環(huán)路的工作原理如下: 數(shù)字鑒相器( Digital PhaseDetector)比較字位流數(shù)據(jù)Data 與本地跟隨時(shí)鐘Clk_out 的相位,給出相位誤差信號Lead Pulse 和Lag Pulse。數(shù)字環(huán)路濾波器對相對誤差進(jìn)行平滑濾波,并生成控制數(shù)控振蕩器的控制信號Deduct 和Insert。DCO 根據(jù)控制信號給出的指令,利用內(nèi)部高速振蕩器的產(chǎn)生的時(shí)鐘調(diào)整輸出時(shí)鐘Clk_out 的相位,使其跟隨輸入數(shù)據(jù)Data 的相位。按照恢復(fù)時(shí)鐘對輸入的字位流進(jìn)行采樣,即可提取數(shù)據(jù)。

(2)并行CRC 算法

為了提高串行數(shù)據(jù)的校驗(yàn)速率,在傳統(tǒng)的串行CRC基礎(chǔ)上,本文提出了一種并行CRC 算法,以CRC5 為例,該算法的Verilog 硬件描述如下:

module usbh_crc5(ci, d, co);

input [4:0] ci; //上一次輸入數(shù)據(jù)CRC 校驗(yàn)值或CRC 初值

input [10:0] d;//輸入的待校驗(yàn)數(shù)據(jù)

output [4:0] co;//本次輸入數(shù)據(jù)的CRC 校驗(yàn)輸出

assign co[0] = d[10]^d[9]^d[6]^d[5]^d[3]^d[0]^ci[0]^ci[3]^ci[4];

assign co[1] = d[10]^d[7]^d[6]^d[4]^d[1]^ci[0]^ci[1]^ci[4];

assign co[2] = d[10]^d[9]^d[8]^d[7]^d[6]^d[3]^d[2]^d[0]^ci[0]^ci[1]^ci[2]^ci[3]^ci[4];

assign co[3] = d[10]^d[9]^d[8]^d[7]^d[4]^d[3]^d[1]^ci[1]^ci[2]^ci[3] ^ci[4];

assign co[4] = d[10]^d[9]^d[8]^d[5]^d[4]^d[2]^ci[2]^ci[3]^ci[4];

endmodule

根集線器配置模塊

本模塊實(shí)現(xiàn)了針對根集線器部分的OHCI 寄存器堆,并為每個(gè)下行端口實(shí)現(xiàn)了一個(gè)狀態(tài)機(jī)以控制端口功能狀態(tài)。根集線器配置模塊可以根據(jù)不同的用戶需求做到端口數(shù)目可配置,最多可配置15 個(gè)下行端口,為用戶提供了很大的靈活性。

仿真與驗(yàn)證

USB 是一個(gè)復(fù)雜的系統(tǒng),包括上層應(yīng)用程序、USB 類驅(qū)動(dòng)程序、主機(jī)控制器驅(qū)動(dòng)程序、主機(jī)控制器以及USB 設(shè)備,為了對USB 主機(jī)控制器進(jìn)行全面的行為級驗(yàn)證,必須建立相對完整的虛擬驗(yàn)證平臺。本文的驗(yàn)證工作基于中科院計(jì)算所自行開發(fā)的SoC 虛擬驗(yàn)證平臺,主要驗(yàn)證下述內(nèi)容:

(1)主機(jī)控制器IP 的OHCI 寄存器堆的可編程性;

(2)主機(jī)控制器IP 與虛擬存儲器之間數(shù)據(jù)傳輸?shù)恼_性;

(3)主機(jī)控制器IP 內(nèi)部協(xié)議處理部分在不同種類傳輸情況下的正確性,包括幀管理、主狀態(tài)機(jī)在各種條件下的狀態(tài)轉(zhuǎn)換和管理、串行化與反串行化、位填充與位填充拆除、時(shí)鐘和數(shù)據(jù)信號提取、NRZ 和NRZI 碼相互轉(zhuǎn)化、中斷處理等;

(4)傳輸差錯(cuò)處理,包括CRC 校驗(yàn)錯(cuò)、PID 校驗(yàn)錯(cuò)、位填充錯(cuò)、傳輸順序錯(cuò)、應(yīng)用程序緩沖區(qū)BufferOverRun 和BufferUnderRun錯(cuò)、控制器內(nèi)部數(shù)據(jù)FIFO DataOverRun 和DataUnderRun 錯(cuò)、設(shè)備Babble、設(shè)備超時(shí)錯(cuò)等;

(5)根集線器配置部分功能,主要包括下行端口狀態(tài)轉(zhuǎn)換、設(shè)備連接/斷開檢測、端口過流檢測、遠(yuǎn)程喚醒、設(shè)備掛起、USB 總線復(fù)位等。主機(jī)控制器IP 設(shè)計(jì)使用的硬件描述語言是Verilog。仿真工具使用Cadence 公司的NCSIM。邏輯綜合使用Synopsys公司的Design Compiler。作者在RTL 設(shè)計(jì)完成以后在行為級作仿真。在確定行為正確以后,利用綜合工具作邏輯綜合,形成網(wǎng)表文件和綜合后的時(shí)延估計(jì)(Standard Delay Format,SDF)文件,然后利用這兩個(gè)文件作門級仿真。

為簡單起見,本文列出綜合后門級仿真一個(gè)典型Setup交易的波形圖,如圖4 所示。圖中USB 總線上進(jìn)行的交易為USB 總線復(fù)位結(jié)束以后,主機(jī)控制器檢測到根端口1 上接入了一個(gè)USB 設(shè)備,由根端口作完設(shè)備速度評估,判斷出接入端口1 的虛擬設(shè)備為全速設(shè)備,然后應(yīng)用程序根據(jù)這些信息以及現(xiàn)有系統(tǒng)中USB 設(shè)備的相關(guān)信息來設(shè)置當(dāng)前接入的設(shè)備地址,圖中所示波形展示了主機(jī)發(fā)出SetAddress 請求以后USB 總線上的數(shù)據(jù)線D+和D-的行為以及主機(jī)控制器IP 的端口數(shù)據(jù)線的行為。

結(jié)論

USB 主機(jī)控制器IP 設(shè)計(jì)是一個(gè)綜合考慮軟硬件系統(tǒng)各方面情況的復(fù)雜設(shè)計(jì),工作時(shí)沒有經(jīng)驗(yàn)可以參考,所以也遇到不少問題。在IP 設(shè)計(jì)中,基本是按照IP 必須遵從的兩個(gè)規(guī)范來劃分電路的功能子模塊,然后在子模塊中具體實(shí)現(xiàn)相關(guān)的功能,自頂向下設(shè)計(jì)。在行為級和綜合后的門級仿真時(shí),采用虛擬的軟硬件協(xié)同驗(yàn)證方法,模擬現(xiàn)實(shí)操作系統(tǒng)中針對當(dāng)前有待驗(yàn)證的電路將會發(fā)生的行為,進(jìn)行高強(qiáng)度的測試和驗(yàn)證,電路工作正常。這些結(jié)果說明軟硬件協(xié)同設(shè)計(jì)和驗(yàn)證在IP 設(shè)計(jì)過程當(dāng)中也是適用的,本設(shè)計(jì)也是這方面工作的一個(gè)探索。

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

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

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

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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