PDIUSBD12芯片在USB接口電路中的應(yīng)用
引言
USB是近年來應(yīng)用在PC領(lǐng)域的新型接口技術(shù),是一些PC大廠商,如 Microsoft、Intel等為了解決日益增加的PC外設(shè)與有限的主板插槽和端口之間的矛盾而制定的一種串行通信的標(biāo)準(zhǔn),自1995年在Comdex上亮相以來至今已廣泛地為各 PC廠家所支持。現(xiàn)在生產(chǎn)的PC幾乎都配備了USB接口,Microsoft 的Windows98、NT以及MacOS、Linux、FreeBSD等流行操作系統(tǒng)都增加了對(duì) USB的支持。
USB的主要優(yōu)點(diǎn):
① 使用方便。連接外設(shè)不必再打開機(jī)箱;允許外設(shè)熱插拔,而不必關(guān)閉主機(jī)電源。
② 速度快。USB接口的最高傳輸率可達(dá)12 Mb/s;提供低速方式,速率為1.5 Mb/s??鄢糜诳偩€狀態(tài)控制和錯(cuò)誤檢測(cè)等數(shù)據(jù)傳輸,最大理論速度也能達(dá)到1.2 Mb/s和9.6 Mb/s。
③ 連接靈活。一個(gè)USB口理論上可以連接127個(gè)USB設(shè)備。連接的方式也十分靈活,既可以使用串行連接,也可以使用集線器Hub,把多個(gè)設(shè)備連接在一起,再同PC機(jī)的USB口相接。
?、?nbsp; 獨(dú)立供電。USB接口提供了內(nèi)置電源。
現(xiàn)在的USB生產(chǎn)廠商很多,幾乎所有的硬件廠商都有USB 的產(chǎn)品。USB控制器一般有兩種類型:一種是MCU集成在芯片里面的,如 Intel的8X930AX、CYPRESS的EZ-USB、SIEMENS的C541U以及 MOTOLORA、National Semiconductors等公司的產(chǎn)品;另一種就是純粹的USB接口芯片,僅處理 USB通信,如PHILIPS的PDIUSBD11(I2C接口)、 PDIUSBP11A、PDIUSBD12(并行接口),National Semiconductor的USBN9602、USBN9603、USBN9604等。前一種由于開發(fā)時(shí)需要單獨(dú)的開發(fā)系統(tǒng),因此開發(fā)成本較高;而后一種只是一個(gè)芯片與MCU接口實(shí)現(xiàn)USB通信功能,因此成本較低,而且可靠性高。本文主要介紹PHILIPS公司的PDIUSBD12器件。
1 PDIUSBD12芯片特點(diǎn)和內(nèi)部結(jié)構(gòu)
PDIUSBD12是一個(gè)性能優(yōu)化的USB器件,通常用于基于微控制器的系統(tǒng)并與微控制器通過高速通用并行接口進(jìn)行通信,也支持本地DMA傳輸。該器件采用模塊化的方法實(shí)現(xiàn)一個(gè) USB接口,允許在眾多可用的微控制器中選擇最合適的作為系統(tǒng)微控制器,允許使用現(xiàn)存的體系結(jié)構(gòu)并使固件投資減到最小。這種靈活性減少了開發(fā)時(shí)間、風(fēng)險(xiǎn)和成本, 是開發(fā)低成本且高效的USB外圍設(shè)備解決方案的一種最快途徑。 PDIUSBD12完全符合USB1.1規(guī)范,也能適應(yīng)大多數(shù)設(shè)備類規(guī)范的設(shè)計(jì),如成像類、大容量存儲(chǔ)類、通信類、打印類和人工輸入設(shè)備等,因此,PDIUSBD12 非常適合做很多外圍設(shè)備,如打印機(jī)、掃描儀、外部大容量存儲(chǔ)器( Zip驅(qū)動(dòng)器)和數(shù)碼相機(jī)等?,F(xiàn)在用SCSI實(shí)現(xiàn)的很多設(shè)備如果用 USB來實(shí)現(xiàn)可以直接降低成本。
PDIUSBD12掛起時(shí)的低功耗以及LazyClock輸出符合ACPI 、OnNOW和USB電源管理設(shè)備的要求。低功耗工作允許實(shí)現(xiàn)總線供電的外圍設(shè)備。
PDIUSBD12還集成了像SoftConnect、GoodLink、可編程時(shí)鐘輸出、低頻晶振和終端電阻等特性。所有這些特性都能在系統(tǒng)實(shí)現(xiàn)時(shí)節(jié)省成本,同時(shí)在外圍設(shè)備上很容易實(shí)現(xiàn)更高級(jí)的 USB功能。
1.1 主要特性
◇ 符合USB 1.1協(xié)議規(guī)范;
◇ 集成了SIE、FIFO存儲(chǔ)器、收發(fā)器和電壓調(diào)整器的高性能USB接口芯片;
◇ 適應(yīng)大多數(shù)設(shè)備類規(guī)范的設(shè)計(jì);
◇ 與任何微控制器/微處理器有高速(2MB/s)的并行接口;
◇ 完全自動(dòng)DMA操作;
◇ 集成了320 B的多配置FIFO存儲(chǔ)器;
◇ 主端點(diǎn)有雙緩存配置,增加吞吐量,容易實(shí)現(xiàn)實(shí)時(shí)數(shù)據(jù)傳輸;
◇ 在塊傳輸模式下有1MB/s的數(shù)據(jù)傳輸率,在同步傳輸模式下有 1Mb/s的數(shù)據(jù)傳輸率;
◇ 具有總線供電能力,有非常好的EMI性能;
◇ 在掛起時(shí)有可控制的LazyClock輸出;
◇ 可通過軟件控制USB總線連接SoftConnect;
◇ 在USB傳輸時(shí)有閃亮的USB連接指示燈GoodLink;
◇ 時(shí)鐘頻率輸出可編程;
◇ 符合ACPI、OnNOW和USB電源管理要求;
◇ 具有內(nèi)部上電復(fù)位和低電壓復(fù)位電路;
◇ 有SO18和TSSOP28封裝;
◇ 能在-40~+85 ℃工業(yè)級(jí)工作;
◇ 片內(nèi)8kV靜電保護(hù);
◇ 雙電壓工作:(3.3±0.3)V或擴(kuò)大的5 V電壓范圍(3.6~5.5 V);
◇ 多中斷模式,方便塊傳輸和同步傳輸。
1.2 內(nèi)部結(jié)構(gòu)
PDIUSBD12的內(nèi)部框圖如 圖 1 所示。
圖1 PDIUSBD12內(nèi)部結(jié)構(gòu)框圖
① 模擬收發(fā)器。集成的收發(fā)器直接通過終端電阻與USB電纜接口。
?、?nbsp; 電壓調(diào)整器。片上集成的1個(gè)3.3 V電壓調(diào)整器為模擬收發(fā)器供電,也提供連接到外部1.5 kΩ上拉電阻的輸出電壓。作為選擇,PDIUSBD12提供集成1.5 kΩ上拉電阻的SoftConnect技術(shù)。
?、?PLL。片上集成1個(gè)6~48 MHz的倍頻PLL(鎖相環(huán)),允許使用6 MHz的晶振,EMI也由于使用低頻晶振而減小。PLL的工作不需要外部器件。
④ 位時(shí)鐘恢復(fù)。位時(shí)鐘恢復(fù)電路用4倍過采樣原理從輸入的USB 數(shù)據(jù)流中恢復(fù)時(shí)鐘,能跟蹤USB規(guī)范中指出的信號(hào)抖動(dòng)和頻率漂移。
?、?nbsp; PHILIPS串行接口引擎PSIE。PHILIPS的SIE完全實(shí)現(xiàn)USB協(xié)議層。考慮到速度,它是全硬件的, 不需要固件(微程序)介入。這個(gè)模塊的功能包括:同步模式識(shí)別、并 /串轉(zhuǎn)換、位填充/不填充、CRC校驗(yàn)、PID確認(rèn)、地址識(shí)別以及握手鑒定。
⑥ SoftConnect。高速設(shè)備與USB的連接是靠把D+通過1個(gè)1.5 kΩ的上拉電阻接到高電平來建立的。在PDIUSBD12中,這個(gè)上拉電阻是集成在芯片內(nèi)的,缺省是沒有連接到VDD,這個(gè)連接是靠外部 MCU發(fā)一個(gè)命令來建立的。這使得系統(tǒng)微處理器可以在決定建立 USB連接之前完成初始化。重新初始化USB總線連接也可以不用拔掉電纜來完成。
?、?nbsp; GoodLink。GoodLink是靠一個(gè)引腳接發(fā)光二極管實(shí)現(xiàn)的。在 USB設(shè)備枚舉時(shí)LED指示燈將立即閃亮;當(dāng)PDIUSBD12被成功枚舉并配置時(shí), LED指示燈將會(huì)始終亮;經(jīng)過PDIUSBD12的USB數(shù)據(jù)傳輸過程中, LED將一閃一閃,傳輸成功后LED熄滅;在掛起期間,LED熄滅。這種特性可以使我們知道 PDIUSBD12的狀態(tài),方便電路調(diào)試。
?、?nbsp; 存儲(chǔ)器管理單元MMU和集成RAM。MMU和集成RAM能緩沖USB(工作在 12Mb/s)數(shù)據(jù)傳輸和微控制器之間并行接口之間的速度差異,這允許微控制器以自己的速度讀寫USB包。
?、?nbsp; 并行和DMA接口。并行接口容易使用、速度快并且能直接與主微控制器接口。對(duì)于微控制器,PDIUSBD12可以看成是一個(gè)有8位數(shù)據(jù)總線和1位地址線的存儲(chǔ)設(shè)備。 PDIUSBD12支持多路復(fù)用和非多路復(fù)用的地址和數(shù)據(jù)總線。在主端點(diǎn)(端點(diǎn) 2)和局部共享存儲(chǔ)器之間也可使用DMA(直接存儲(chǔ)器存?。﹤鬏?。它支持單周期模式和塊傳送模式兩種DMA傳輸。
2 PDIUSBD12的引腳說明及典型連接
2.1 PDIUSBD12引腳說明
PDIUSBD12引腳如 圖 2 所示,引腳如 表 1 所列。
圖2 PDIUSBD12的引腳圖
表1 PDIUSBD12引腳說明
2.2 PDIUSBD12的典型連接
PDIUSBD1與80C51的連接電路如 圖 3 所示。在這個(gè)例子中, ALE始終接低電平,說明采用單獨(dú)地址和數(shù)據(jù)總線配置。A0 腳接80C51的任何I/O引腳,控制是命令還是數(shù)據(jù)輸入到PDIUSBD12 。80C51的P0口直接與PDIUSBD12的數(shù)據(jù)總線相連接,CLKOUT 時(shí)鐘輸出為80C51提供時(shí)鐘輸入。
圖3 PDIUSBD12與80C51的連接電路圖
3 軟件設(shè)計(jì)
3.1 單片機(jī)方面軟件設(shè)計(jì)
對(duì)于單片機(jī)控制程序,目前沒有任何廠商提供自動(dòng)生成固件(firmware)的工具,因此所有程序都要由自己手工編制。USB單片機(jī)控制程序通常由三部分組成:第一、初始化單片機(jī)和所有的外圍電路(包括PDIUSBD12);第二、主循環(huán)部分,其任務(wù)是可以中斷的;第三、中斷服務(wù)程序,其任務(wù)是對(duì)時(shí)間敏感的,必須馬上執(zhí)行。根據(jù)USB協(xié)議,任何傳輸都是由主機(jī)(host)開始的,這樣,單片機(jī)作它的前臺(tái)工作,等待中斷。主機(jī)首先要發(fā)令牌包給USB設(shè)備(這里是PDIUSBD12),PDIUSBD12接收到令牌包后就給單片機(jī)發(fā)中斷,單片機(jī)進(jìn)入中斷服務(wù)程序,首先讀PDIUSBD12的中斷寄存器,判斷 USB令牌包的類型,然后執(zhí)行相應(yīng)的操作。因此,USB單片機(jī)程序主要就是中斷服務(wù)程序的編寫。在USB單片機(jī)程序中要完成對(duì)各種令牌包的響應(yīng),其中比較難處理的是SETUP包,主要是端口0的編程。
單片機(jī)與PDIUSBD12的通信主要是靠單片機(jī)給PDIUSBD12發(fā)命令和數(shù)據(jù)來實(shí)現(xiàn)的。 PDIUSBD12的命令字分為三種:初始化命令字、數(shù)據(jù)流命令字和通用命令字。PDIUSBD12給出了各種命令的代碼和地址。單片機(jī)先給PDIUSBD12的命令地址發(fā)命令,根據(jù)不同命令的要求再發(fā)送或讀出不同的數(shù)據(jù)。因此,可以將每種命令做成函數(shù),用函數(shù)實(shí)現(xiàn)各個(gè)命令,以后直接調(diào)用函數(shù)即可。
在編寫USB的單片機(jī)程序時(shí),需要注意:
① 單片機(jī)的中斷應(yīng)設(shè)置為電平觸發(fā);中斷后一定要讀上次傳輸狀態(tài)寄存器(命令40-45H),以清除中斷寄存器中的中斷標(biāo)志。這樣,PDIUSBD12的中斷輸出才能變回高電平,這一點(diǎn)非常重要。
?、?在接收到Setup包后,一定要調(diào)用ACK setup命令重新使能端口0。
?、?在向IN端點(diǎn)寫完數(shù)據(jù)后,一定調(diào)用Validate Buffer(命令FAH),指明緩沖區(qū)中的數(shù)據(jù)有效,可以發(fā)送到主機(jī)。
?、?nbsp; 當(dāng)讀完數(shù)據(jù)后,一定調(diào)用Clear Buffer(命令F2H),以保證可以接收新的包。
?、?nbsp; 可以通過調(diào)用Read Chip ID(命令FDH)檢查PDIUSBD12是否工作。該命令要讀兩個(gè)字節(jié)數(shù)據(jù)。
USB初始化過程為:
?、?Set Address Enable;
?、?nbsp; Set Endpoint Enable(此時(shí)LED亮);
?、?Disconnect;
④ delay(1~2 s);
?、?Connect(即用43h參數(shù)調(diào)用Set Mode,此時(shí)LED滅);
?、?Read Interrupt Register。
完成初始化工作后,就可作其它的前臺(tái)工作了,并在前臺(tái)判斷是否有 Setup包(通過一個(gè)變量,當(dāng)中斷服務(wù)程序檢測(cè)到有Setup包時(shí),設(shè)置該變量),然后執(zhí)行響應(yīng)的控制傳輸。
在調(diào)試USB單片機(jī)程序時(shí),還要特別注意Windows對(duì)USB設(shè)備的枚舉順序:
?、?GetDeviceDescriptor。主機(jī)主要對(duì)Length域感興趣,發(fā)送內(nèi)容一定要正確,特別是第 2字節(jié)type一定為0x01,即Device;否則,主機(jī)將不響應(yīng),或者再重復(fù)2次后放棄。可檢查一下對(duì)EP0的RX、TX的設(shè)置次序。
?、?SetAddress。一般為02或03。
?、?連續(xù)3次GetDeviceDescriptor,讀取全部設(shè)備描述符,一般為 18 B,分為多次傳輸。如果不正確,主機(jī)將不響應(yīng)或重復(fù)2次后放棄。
?、?GetConfigDescriptor。注意第2字節(jié)一定為0x02,即config 。
⑤ GetStringDescriptor(可能沒有),根據(jù)在設(shè)備描述符中是否有 String索引而定。一般先讀取LanguageID,再讀取product string。
?、?nbsp; 讀取全部ConfigDescriptor,次數(shù)根據(jù)描述符的大小決定(端點(diǎn)個(gè)數(shù)不同,描述符大小不同),如果不正確,主機(jī)將不響應(yīng)或再重復(fù)2次后放棄。
?、?如果以上步驟都正確,主機(jī)將找到新設(shè)備,提示安裝驅(qū)動(dòng)程序;否則找到未知設(shè)備,不可用。安裝驅(qū)動(dòng)程序后,以后的每次PlugIn,枚舉次序與以上步驟略有不同,之后會(huì)有 SetConfiguration、GetConfiguration和GetInterface等調(diào)用。
3.2 主機(jī)方面軟件設(shè)計(jì)
Windows98 提供了多種USB設(shè)備的驅(qū)動(dòng)程序,但好像還沒有一種是專門針對(duì)數(shù)據(jù)采集系統(tǒng)的,所以必須針對(duì)特定的設(shè)備來編制驅(qū)動(dòng)程序。盡管系統(tǒng)已經(jīng)提供了很多標(biāo)準(zhǔn)接口函數(shù),但編制驅(qū)動(dòng)程序仍然是USB開發(fā)中最困難的一件事情,通常采用Windows DDK來實(shí)現(xiàn)。目前有許多第三方軟件廠商提供了各種各樣的生成工具,像 Compuware的driver works,Blue Waters的Driver Wizard等,它們能夠很容易地在幾分鐘之內(nèi)生成高質(zhì)量的USB 的驅(qū)動(dòng)程序。作為WIN98和WIN2K推薦的一項(xiàng)新技術(shù)來說,USB的驅(qū)動(dòng)程序和以往的直接跟硬件打交道的 WIN95的VXD方式的驅(qū)動(dòng)程序不同。它是WDM類型的。
在調(diào)試USB設(shè)備時(shí),可使用UsbView程序檢測(cè)設(shè)備是否能被Windows枚舉并配置,如果成功, 還可在該程序中查看設(shè)備描述符、配置描述符和端點(diǎn)描述符是否正確。之后可以使用Driver Wizard生成一個(gè)通用驅(qū)動(dòng)程序,在Windows提示安裝驅(qū)動(dòng)程 序時(shí),選擇Driver Wizard生成的驅(qū)動(dòng)程序。其實(shí)Driver Wizard生成的僅是一個(gè)Windows控制臺(tái)的應(yīng)用程序,它會(huì)調(diào)用安裝Driver Wizard時(shí)安裝在系統(tǒng)中的通用USB驅(qū)動(dòng)程序。使用該程序就可測(cè)試設(shè)備是否能夠正確傳輸數(shù)據(jù)以及傳輸速度。該程序也可作為最終產(chǎn)品USB傳輸部分的框架;如果不能滿足要求,也可用WDM重新編制驅(qū)動(dòng)程序,用調(diào)試好的USB設(shè)備來開發(fā)、調(diào)試主機(jī)軟件。
4 應(yīng)用實(shí)例
本文介紹一個(gè)高速數(shù)據(jù)采集系統(tǒng),以AD公司的ADμC812為系統(tǒng)控制器。該單片機(jī)本身就是高度集成的高精度12位數(shù)據(jù)采集系統(tǒng),在其片內(nèi)不僅組合了可重新編程非易失性閃速/電擦除程序存儲(chǔ)器的高性能8位(與8051兼容)MCU,還包含了高性能的自校準(zhǔn)多通道(8個(gè)輸入通道)12位ADC和兩個(gè)12位 DAC,且內(nèi)核與8051指令集兼容。PDIUSBD12作為 ADμC812的存儲(chǔ)器外設(shè),接口比較簡單。需要注意的地方是引腳必須接高電平,否則將不能接收任何命令和數(shù)據(jù);EOT_N必須通過電阻接到USB 的+5 V,以正確檢測(cè)到USB連接;INT_N引腳加1個(gè)上拉電阻,+5 V接到VDD引腳;在VOUT3.3引腳加 1μF(電解電容)和0.1μF兩個(gè)退耦電容。
結(jié)束語
PDIUSBD12是一個(gè)性能優(yōu)化的USB器件,它的SoftConnect 和GoodLink技術(shù)使開發(fā)和調(diào)試USB設(shè)備時(shí)非常方便,在性能、速度、方便性以及成本上都具有很大的優(yōu)勢(shì)。因此,使用PHILIPS公司的PDIUSBD12可以快速開發(fā)出高性能的 USB設(shè)備。
參考文獻(xiàn)
1 Philips Corp. PDIUSBD12 Users Manual
2 Universal Serial Bus Specification,Compaq,Intel,Micrisoft,NEC,Revision 1.1 eptember 23, 1998
3 劉丁,毛德柱,王云飛. USB在數(shù)據(jù)采集系統(tǒng)中的應(yīng)用. 電子技術(shù)應(yīng)用
4 晁建剛,陳善廣,薛亮. 基于USB接口技術(shù)的外設(shè)應(yīng)用設(shè)計(jì). 嵌入式系統(tǒng)論文集,2000.11