<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > USBN9604及其在USB接口設計中的應用

USBN9604及其在USB接口設計中的應用

作者: 時(shí)間:2012-03-13 來(lái)源:網(wǎng)絡(luò ) 收藏
引言

USB通用串行總線(xiàn)是近年興起的一種通信方式。USB協(xié)議1.1版規定了低速(1.5Mb/s)和全速(12Mb/s)兩種速率,目前大部分USB器件支持該協(xié)議。2000年USB2.0白皮書(shū)出臺后,其速度最高可達480Mb/s。該總線(xiàn)是由Compaq、Intel、Microsoft、NEC四公司共同提出,并得到了眾多廠(chǎng)商的支持。具有安裝方便、高速、靈活、低成本、易擴展,支持熱插拔等優(yōu)點(diǎn),已經(jīng)逐漸成為現代數據傳輸的發(fā)展趨勢。

2

是NatiONalSemiconductor公司設計生產(chǎn)的一款較新型的專(zhuān)用USB通信控制芯片,是US-BN9602的改進(jìn)產(chǎn)品,同時(shí)在時(shí)鐘產(chǎn)生電路的復位機制上又較USBN9603有所改進(jìn)。支持全速傳輸,可滿(mǎn)足USBl.0和1.1協(xié)議。它具有8位并行接口,可支持DMA、MICROWIRE/PLUS。圖1是US-BN9604的結構框圖。其主要特點(diǎn)如下:

  • 工作頻率為48MHz,但外部只需接24MHz晶振,因為芯片內部有倍頻電路,因而可得到48MHz時(shí)鐘。
  • 可由編程時(shí)鐘發(fā)生器編程產(chǎn)生不同的頻率時(shí)鐘,以作為外部器件(如CPU)的時(shí)鐘信號。
  • 帶有串行引擎接口(SⅢ),可實(shí)現USB物理層和信號層協(xié)議的轉換,主要有CRC校驗/產(chǎn)生、PID校驗/產(chǎn)生、位填充/解除填充、地址識別、握手評估/產(chǎn)生、并串轉換等。
  • 帶有7個(gè)端點(diǎn)的USB功能控制器,每個(gè)端點(diǎn)對應一個(gè)FIFO。其中端點(diǎn)0是雙向控制端點(diǎn)(FIFO 8字節深),另有3個(gè)發(fā)送端點(diǎn):EPl(16)、EP3(16)和EP5(64)以及3個(gè)接收端點(diǎn)EP2(16)、EP4(16)和EP6(64)。

    USBN9604內部有64個(gè)映射到內存的寄存器,主要有主控制寄存器(MCNTRL)、時(shí)鐘配置寄存器(CCONF)、主事件寄存器(MAEV)、轉換事件寄存器ALteV)、接收發(fā)送事件寄存器(RXEV、TXEV)以及各端點(diǎn)的控制寄存器和收發(fā)數據及狀態(tài)寄存器等。固件的大部分功能就是完成對此寄存器組的讀寫(xiě),實(shí)現對接口的配置、接口狀態(tài)的轉換以及數據在外設和計算機之間的傳輸等。


    3 的硬件實(shí)現

    51單片機與USBN9604的并行連接有兩種方式,即非復用方式和復用方式。它們可通過(guò)設置引腳MODE0、MODEl來(lái)選擇。在非復用方式時(shí),可用控制引腳CS、RD、WR、地址引腳A0和雙向數據線(xiàn)D[7:0]實(shí)現相應的地址讀寫(xiě)。而在復用方式時(shí),則使用控制引腳CS、RD、WR、地址鎖存信號ALE和雙向數據線(xiàn)D[7:01實(shí)現其地址讀寫(xiě)。本設計采用復用方式進(jìn)行數據交換。

    圖2所示是89C51單片機和USBN9604的接口電路,該電路由一片89C51單片機、USBN9604、時(shí)鐘振蕩電路以及相應的外圍電路組成。其中USBN9604通過(guò)外部中斷INT0與89C51單片機進(jìn)行通信。

    4 的軟件實(shí)現

    設備固件是設備運行的核心,可采用C語(yǔ)言設計。其主要功能是控制USBN9604接受并處理USB驅動(dòng)程序的請求(如各種標準請求)、接收/_k傳數據。當主程序完成CPU和USBN9604的初始化后,可用while循環(huán)等待外部中斷。中斷處理程序可在給出中斷人口后跳出中斷。所有的USB事物處理都在函數USB-ISR中完成。圖3所示是USB-ISR程序框圖。在USB-ISR中,通過(guò)程序可讀取USBN9604中的主事件寄存器(MAEV),并判斷中斷原因,包括收發(fā)事件的發(fā)生、總線(xiàn)狀態(tài)的改變以及握手信號的產(chǎn)生等,同時(shí)可根據不同原因進(jìn)入相應函數。另外也可通過(guò)函數具體實(shí)現各種USB標準的請求、端點(diǎn)0的接收和發(fā)送以及其它端點(diǎn)的收發(fā)和總線(xiàn)狀態(tài)的改變等。


    上一頁(yè) 1 2 下一頁(yè)

    關(guān)鍵詞: USBN9604 USB接口

    評論


    相關(guān)推薦

    技術(shù)專(zhuān)區

    關(guān)閉
    国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
    <dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>