<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > USB3.0/USB3.1/ThunderBolt高速串行接口速度由什么決定?

          USB3.0/USB3.1/ThunderBolt高速串行接口速度由什么決定?

          作者: 時間:2018-07-26 來源:網(wǎng)絡 收藏

          上世紀七八十年代就出來了各種數(shù)據(jù)傳輸?shù)膮f(xié)議,比如T1/E1載波系統(tǒng)(2.048Mbps)、X.25中繼系統(tǒng)、ISDN(綜合業(yè)務數(shù)字網(wǎng))等,那時的速度還比較慢的,到了九十年代,SDH(Synchronous Digital Hierarchy,同步數(shù)字體系)和SONET(Synchronous Optical Network同步光纖網(wǎng))標準出現(xiàn),其基本速度就是STM-1 155.520Mbps,STM-4為622.080Mbps,STM-16為2488.240Mbps,到更后來WDM(Wavelength Division Multiplexing, 波分復用)技術,再到最新的OTN(OpticalTransportNetwork,光傳送網(wǎng)),這里面最重要的個概念就是(Time Division Multiplexing, 時分復用)。

          本文引用地址:http://www.ex-cimer.com/article/201807/384127.htm

          時分多路復用(Time-Division Multiplexing,)是一種數(shù)字的或者模擬(較罕見)的多路復用技術。使用這種技術,兩個以上的信號或數(shù)據(jù)流可以同時在一條通信線路上傳輸,其表現(xiàn)為同一通信信道的子信道。但在物理上來看,信號還是輪流占用物理通道的。時間域被分成周期循環(huán)的一些小段,每段時間長度是固定的,每個時段用來傳輸一個子信道。例如子信道1的采樣,可能是字節(jié)或者是數(shù)據(jù)塊,使用時間段1,子信道2使用時間段2,等等。一個的幀包含了一個子信道的一個時間段,當最后一個子信道傳輸完畢,這樣的過程將會再重復來傳輸新的幀,也就是下個信號片段。

          數(shù)字傳輸就像打包裹,最基本單元是一個小包裹,四個小包裹打成一個中的,再四個中的打成一個大的,再四個大的打成一個更大,然后再特大的。比如SONET的傳輸速度就是STM-1/-4/-16等這樣疊加上去,以2的指數(shù)倍往上翻。其中TDM-16速度為2488.240MBps,就是我們通常說的2.5Gbps。

          上面說了堆協(xié)議,那總要具體的物理實現(xiàn),一般選用銅線或光纜進行遠距離傳輸。以光纜為例,數(shù)據(jù)先由電路中的并行數(shù)據(jù)變成串行傳送出去,然后再經(jīng)過光纖接口,變成光信號在光纖里傳輸,接收時先由光信號變成電信號,再由串行變成并行到內部使用。其中由并行到串行/串行到并行經(jīng)過的就稱為SERDES PHY,高速SERDES的技術實現(xiàn)難度較高,得由模擬電路實現(xiàn),在很多場合就是一塊單獨的SERDES PHY芯片,那就有專門的公司來做這個事情,比如在業(yè)界大名鼎鼎的TI德州儀器,其TI芯片就賣得很好。逐漸實現(xiàn)這樣的產(chǎn)業(yè)鏈:做數(shù)字電路的、模擬電路的、測試設備的、生產(chǎn)制造的(包括PCB和SERDES PHY、光口、光纖等),已經(jīng)定了個基本速率后,再往上的更新?lián)Q代往往是X2地疊加,在數(shù)字電路上最好實現(xiàn),在模擬電路上也有這樣的動力,整個技術就一直這樣往前走下去。

          回到標題高速由什么決定的來,PCI總線由Intel公司于91年提出,之后移交給第三方機構PCI SIG。PCI SIG由多家業(yè)內公司組成的聯(lián)盟,別的公司也可以申請加入成為會員,TI也是早期會員之一。就像聯(lián)合國一樣,Intel等公司像常任理事國一樣擁有更大的主導權;USB于94年由帶頭大哥Intel聯(lián)合微軟、HP、NEC等電腦公司組成USB-IF組織,96年推出USB1.0標準;(同期還有Apple推出的FireWare火線,也紅火了好多年)由此可見,Intel對PCI/PCIE和USB的建立和發(fā)展一直擁有極大的主導權。

          2001年PCIE開始制定,決定以串行方式代替并行的PCI總線時,那時產(chǎn)業(yè)內2.5G PHY已經(jīng)比較成熟了,PCI組織PCI-SIG決定直接借鑒此速度就很正常;等到PCIE2.0發(fā)布已經(jīng)是過2007年,就直接X2變成5G了; 于2008年發(fā)布,直接借鑒業(yè)界比較成熟的5G方案也就很正常了; 而PCIE3.0發(fā)布是2010年時(為什么PCIE3.0是8G而不是10G,這算是個折衷吧,速度越快對PCB走線設計和生產(chǎn)、線纜、測試儀器等要求越高,采用64b/66b或128b/130b編碼方案,8G*64/66=7.88G,解碼后的速度幾乎就是2.0的二倍,2.0采用傳統(tǒng)的8b/10b編碼,解碼后速度5G*8/10=4G)。

          等到USB3.1發(fā)布,也就是最近的事情(2014年),覺得10G PHY也比較成熟了,那也直接采用10G吧,USB3.1采用128b/132b編碼,效率與PCIE3.0是等效的,它直接向PCIE借鑒了很多內容。

          而ThunderBolt,定位在更高速速度傳輸,其1.0速度最開始設計時就是一 路10G PHY(大約2011年),而后2.0就成兩路10G PHY了,最近的3.0成兩路20G PHY,為什么不直接成40G PHY,工藝做不上去啊。

          很早前,業(yè)界有個傳說,銅界質PCB走線最高速度只能到16G,幾年前就已經(jīng)打破了,28G甚至32G以上跑銅界質的高速PHY已經(jīng)有DEMO演示了,ThunderBolt2.0推出兩路10G PHY,自然也是業(yè)界有這樣能力去推出成熟產(chǎn)品。不出意外的是,ThunderBolt定位在高端,從最先推出1.0接口的MAC電腦(2011年),到現(xiàn)在已經(jīng)四年過去了,相對來說還很不普及,只在高端電腦上才有配備,其外設產(chǎn)品,比如支持該接口的外接存儲和高清顯示器見到過報道,但市場上賣得真不太多,比起這幾年一下子普及開來的還是相差不少。與此類似待遇的是DisplayPort接口,顯示器接口從最早的VGA到DVI,到同時支持聲音圖像傳輸?shù)腍DMI、DisplayPort接口,HDMI逐漸變得常見,尤其是電視接口上,而DisplayPort仍然不太多見。而ThunderBolt在外觀上與Mini DP接口兼容,在功能上可認為是圖像傳輸接口DP和數(shù)據(jù)傳輸協(xié)議PCIE的合體。

          這不,Intel一琢磨,那ThunderBolt3.0改成USB3.1 Type-C接口兼容吧,這樣支持ThunderBolt3.0的外設既可以連接對應的ThunderBolt3.0 host,享受40G的高速,也可以接在USB3.1 Type-C上,盡管只能跑USB3.0 5G速率(注意,資料顯示所兼容的控制器是USB3.0,而不是最新的USB3.1; 也有人指出Intel推出的控制器是支持10G速度的。無論如何PHY通道是支持的,這主要取決于控制器部分),其實這樣對于外設廠商也是一大利好,用戶也可以放心地買,不用擔心接口不支持。

          最后做個總結:高速速度由什么決定?當時協(xié)議公布時前代技術的積累與影響和已成熟技術,二者占重要因素。比如2.5G速率和STM-1 155M的關系,比如不同年代PHY技術的成熟度,再者還有業(yè)界領先公司在制定標準時的號召力及技術前瞻性,如Intel在多種協(xié)議上的主導力。



          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();