《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > SPI-4.2總線應用和調試經驗談
SPI-4.2總線應用和調試經驗談
單片機與嵌入式系統
王 江 上海貝爾股份有限公司
摘要: SPI-4.2總線(System Packet Interface,系統間數據包接口)是一種速度高達10 Gb/s的芯片間互連總線,主要應用于ATM信元傳輸、POS(Packet Over SONET/SDH,基于SONET/SDH的包傳輸)和10 Gb/s以太網等高端場合。
Abstract:
Key words :

引言
    SPI-4.2總線(System Packet Interface,系統間數據包接口)是一種速度高達10 Gb/s的芯片間互連總線,主要應用于ATM信元傳輸、POS(Packet Over SONET/SDH,基于SONET/SDH的包傳輸)和10 Gb/s以太網等高端場合。特別在通信領域,很多高端處理器和網絡處理器,如Intel公司的IXP2800、Cavium公司的多內核處理器CN58xx系列、NetLogic公司的XLR732、Broadcom的BCM1480,幾乎都集成了SPI-4.2接口,以提高芯片的吞吐能力,適應通信產業朝著LTE(長期演進)發展的需求。還有眾多的物理層芯片,例如Cortina公司的CS1331,可以將SPI-4.2總線轉換成8個千兆以太網接口。SPI-4.2總線之所以被眾多的高端芯片所采用,與其高速、靈活、可靠的特性是密不可分的。

1 SPI-4.2總線基本原理
    SPI-4.2總線是一種芯片間的互連總線,連接芯片的鏈路層和物理層模塊。其工作時鐘是源同步雙邊沿觸發時鐘,至少為311 MHz。圖1是使用SPI-4.2總線連接兩個芯片的示意圖??梢?,SPI-4.2總線的信號在發送和接收方向完全對稱而又互相獨立,數據鏈路和狀態鏈路分開,并且其時鐘也是完全分開的。因此,該總線不僅適合于雙向通道,而且適合于只收不發或者只發不收的單向通道。

a.jpg


    SPI-4.2總線具有以下特點:
    ①點對點互連,收發數據鏈路寬度為16位。
    ②發送和接收模塊的信號各分為兩組,即數據信號和狀態信號,分別對應數據鏈路和狀態鏈路,每個鏈路具有自己的時鐘。數據鏈路發送和接收數據,狀態鏈路傳輸相應鏈路的狀態信息。
    ③數據鏈路包含DCLK、DAT[15:0]和CTL三種LVDS(低壓差分傳輸)信號。前面加“T”表示信號屬于發送模塊,加“R”表示信號屬于接收模塊。以發送模塊為例,TDCLK是雙邊沿觸發時鐘,TCTL是控制信號,TDAT[15:0]承載了數據和控制信息。當TCTL為高電平時,TDAT[15:0]傳送的是數據包;當TCTL為低電平時,TDAT[15:0]傳送的是控制包。數據采用DIP~4校驗交織碼。
    ④狀態鏈路包括SCLK時鐘信號和STAT[1:0]狀態信號,信號類型是LVTTL或LVDS。SPI~4.2發送時序如圖2所示。如果選擇LVTTL,則SC-LK時鐘頻率是數據鏈路時鐘速率的1/4。如果選擇LVDS,則SCLK時鐘頻率和數據鏈路時鐘頻率相同。下文中均以LVDS為例進行闡述。狀態鏈路主要用于流控。

b.jpg


    ⑤接收和發送模塊都含有一個FIFO隊列,用于緩存數據,隊列長度由芯片設計而定。隊列的狀態信息通過狀態鏈路周期性地發送,接收模塊和發送模塊的狀態信息是獨立的。狀態信息附加了DIP-2交織校驗碼,以提高傳輸可靠性。


    除了數據包中最后一段不滿16字節的數據(EOP)之外,SPI-4.2總線的數據實行突發傳輸,以16字節為單位(稱為一個數據塊),每次傳輸多個數據塊。因為數據寬度是16位,所以一次突發傳輸至少需要4個時鐘周期。數據的高地址位字節先發送(MSB),低地址位字節后發送,數據塊傳輸過程中不會被中斷。每次突發傳輸的間隔期間傳送控制包或者訓練序列。圖2中,TDAT表示數據塊,TCTRL表示控制塊??刂瓢L度為16位,包含了前次傳輸和下次傳輸的狀態信息:包開始標志、包結束標志、邏輯端口地址和DIP-4交織校驗碼等。數據鏈路遵循有限狀態機進行工作,狀態包括5種:控制包傳輸、數據包傳輸、空閑包傳輸、訓練序列傳輸以及訓練序列控制。
    因為狀態鏈路的寬度是2位,所以每次突發傳輸至少傳輸16位數據(4個時鐘周期)。反映FIFO隊列的狀態信息有3種:飽(Satisfied)、餓(Hungry)、極餓(Starving),分別對應二進制數字10、01和00。11表示鏈路處于失步狀態,正在同步過程中。當狀態是“飽”時,說明隊列幾乎滿了,只接收當前正在傳送的數據包,其他數據包只有等狀態更新后才能接收。當狀態是“餓”時,可以接收最大MaxBurst2個數據塊。當狀態是“極餓”時,說明隊列幾乎空了,可以接收最大MaxBurst1個數據塊。MaxBurst1和MaxBurst2是SPI-4.2總線初始化時設定的參數,MaxBurst1不得小于MaxBurst2。

2 SPI-4.2總線的初始化和同步
    SPI-4.2總線初始化時必須設定一些基本參數,如表1所列。

c.jpg


    SPI-4.2總線協議定義了一個叫“日歷”的數據結構CALENDAR[i](i=1,…,CALENDAR_LEN)。CALENDAR_LEN(日歷長度)參數規定了邏輯端口(或稱為虛擬通道)的數目,該數值不能小于實際的邏輯端口數目。例如,如果SPI-4.2總線用于10 Gb/s以太網口,那么日歷長度是1(即CALENDAR_LEN=1);如果SPI-4.2總線用于10個1 Gb/s以太網口,那么日歷長度是10(CALENDAR_LEN=10),CALENDAR[i]=1,2,…,10,代表了10個以太網端口。CALENDAR[i]中承載的數據被周而復始地依次傳輸,重復次數是CALENDAR_M次。圖3為日歷長度和重復次數都是4的數據傳輸示意圖。SPI-4.2總線被初始化時,必須確保接口兩端的CALENDAR_LEN和CALENDAR_M分別相等。從這個角度看,SPI-4.2是一種時分復用的總線:總帶寬是固定的,“日歷”數據結構決定了帶寬和邏輯端口的分配。
    當SPI-4.2正常工作時,數據和狀態鏈路會不定期地發送訓練序列。在數據鏈路,訓練序列至少應該在DATA_MAX_T個時鐘周期內發送一次。在狀態鏈路,訓練序列至少應該在FIFO_MAX_T個時鐘周期內發送一次。設置DATA_MAX_T或FIFO_MAX_T為0將取消各自鏈路的訓練序列,一般情況下不推薦這種設置。
    圖4以XLR732為參照描述了SPI-4.2總線的收發同步過程。啟動之后,在發送方向,發送模塊(TX)通過數據鏈路發送連續的訓練序列,對端的接收模塊成功收到訓練序列后,會設置本端的接收同步標志;然后通過狀態鏈路發送訓練序列給對端,一旦發送模塊成功接收到訓練序列后,就設置本端的發送同步標志。

d.jpg

 


    在接收方,接收模塊(RX)在數據鏈路成功接收到對端發送的訓練序列后,會設置本端的接收同步標志;然后通過狀態鏈路發送訓練序列,一旦發送模塊成功接收到訓練序列后,就設置本端的發送同步標志。
    在同步過程中,訓練序列由指定的連續的DIP-4碼字組成。發送模塊必須連續發送訓練序列,直到本端的狀態鏈路收到有效信息。同時,接收模塊忽視所有接收到的數據,直到觀察到訓練序列,獲得數據同步。一旦數據鏈路同步之后,FIFO隊列狀態信息就開始傳送。如果發送
方接收到有效的狀態信息,它就可以開始進行數據突發傳輸。
    如果在工作過程中,由于某些原因(例如一端器件掉電或重啟)導致總線失步,那么為了再次獲得同步,雙方需要按照上述過程發送連續的訓練序列,直到建立同步為止。

3 SPI-4.2總線接口的調試
    SPI-4.2總線接口的調試包括兩個重要步驟:鏈路的同步和數據的正常收發。
    在調試鏈路同步時,首先必須查看總線兩端的初始化參數配置。因為SPI-4.2總線協議是一個對等端數據傳輸協議,所以大部分參數需要雙方的匹配和協商,特別是接收方和發送方的CALENDAR_LEN和CALENDAR_M參數。
    如何查看同步呢?芯片通常會提供一個狀態寄存器來反映總線的同步。“接收同步標志”只能說明在數據鏈路上成功接收到對端的訓練序列,但不能保證接收的狀態鏈路是正常的,如果需要確認可查看對端的“發送同步標志”。在收發雙向通道應用中,只有兩端的“接收同步標志”和“發送同步標志”都置位了,總線才算同步。此時,可以確認總線兩端的物理連接是正確的,握手成功。
    如果不能同步,就必須檢查兩端的“接收同步標志”和“發送同步標志”,判斷是哪一端出了問題。檢查是否有DIP4和DIP2錯誤,如果有此類錯誤,說明鏈路上信號質量可能不佳,可以用示波器測量信號波形。如果信號質量確實不好,可以通過提高信號驅動能力或者調整硬件匹配阻抗來優化。如果兩端的接收和發送都沒有同步,就必須測量芯片的電壓、工作頻率、重啟等信號。
    如果兩端的“接收同步標志”和“發送同步標志”都已經置位,說明雙方的接收和發送都同步,可以正常收發數據了。在大流量數據傳輸過程中,最相關的是FIFO隊列的參數配置,配置不當會導致錯包或丟包。以NetLogic公司的XLR732網絡處理器為例,SPI-4.2總線的發送模塊的所有邏輯端口共享一個FIFO隊列,寬度為16字節,長度為128;接收模塊的所有邏輯端口共享一個FIFO隊列,寬度為16字節,長度為512。每個邏輯端口所占用的隊列地址和大小都可以通過寄存器配置。
    假如某個端口接收端隊列的長度是48,MaxBurst1是12,MaxBurst2是8。那么當該模塊接收數據時,如果由于某些原因(例如軟件來不及處理),接收隊列只剩下12個空位,也就是接收隊列已經有48-12=36個空位被占用時,它將通過狀態鏈路向對端發送“餓”的狀態信號(反壓信號)。對端收到該信號后實施流控策略,根據本端發送端的MaxBurst1設置值發送數據,該值表示接收到“餓”狀態信號后最多還可以發送的數據塊數目。所以接收端的MaxBurst1的值一定要大于對端發送端的MaxBurst1,并且要留出一定的余量,因為數據在鏈路上的傳輸也是需要時間的。同理,接收端的MaxBurst2要大于對端發送端的MaxBurst2。值得注意的是,流控是基于邏輯端口的,而不是整條鏈路。
    為保證不發生接收端FIFO隊列溢出等問題,盡量將接收端的MaxBurst1和MaxBurst2設置大一些,只要小于FIFO入口總數就可以,而發送端MaxBurst1和MaxBurst2的設置不要超過本端接收能力。
    如果出現EOP(結束包)和SOP(起始包)錯誤或缺失,或者其他錯包(例如包長變短、幀校驗錯誤等),但沒有DIP4錯誤,該怎么辦?這類問題一般出現在FIFO隊列設置上,尤其是接收端的FIFO隊列可能溢出,從而丟失了某些數據塊,可以通過以下3種方法來檢測和解決:
    ①通過查看接收端FIFO溢出標志來判斷FIFO隊列是否溢出;
    ②通過調整接收端的MaxBurst1和MaxBurst2來防止FIFO隊列溢出;
    ③如果方法②的調整足夠大,還有此問題,可以查看對端是否收到反壓信號,以及對端的狀態等。
    為了方便,通常將發送端的MaxBurst1和MaxBurst2設置為相同數值,將接收端的MaxBurst1和MaxBurst2也設置成相同數值。

結語
    隨著處理器的速度越來越快,處理器集成的內核越來越多,處理器與外圍器件之間,處理器之間,以及外圍器件之間的連接速度逐漸成為制約平臺性能的瓶頸。許多芯片同時集成了多個總線接口,例如XLR732同時擁有SPI-4.2、HT、以太網3種總線接口。SPI-4.2總線在與其
他總線的競爭中體現出了強大的生命力,希望本文所介紹的經驗對正在應用或計劃應用SPI-4.2總線的同行有所幫助。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          午夜精品久久久| 欧美激情视频在线免费观看 欧美视频免费一| aⅴ色国产欧美| 欧美国产精品va在线观看| 蜜臀av一级做a爰片久久| 欧美极品aⅴ影院| 国产在线不卡| 亚洲人成网站精品片在线观看| 亚洲一区国产视频| 亚洲欧美中文日韩v在线观看| 狠狠爱综合网| 激情欧美国产欧美| 亚洲一区二区三区成人在线视频精品| 欧美一区二区视频在线观看2020| 久久久不卡网国产精品一区| 国外成人在线视频网站| 欧美二区视频| 亚洲高清精品中出| 香蕉乱码成人久久天堂爱免费| 国产偷国产偷亚洲高清97cao| 亚洲国产91色在线| 亚洲国产一区二区视频| 一区二区三区鲁丝不卡| 亚洲精选久久| 韩国久久久久| 亚洲一区二区三区乱码aⅴ| 欧美成人69av| 日韩视频在线观看一区二区| 亚洲一区尤物| 国产精品一香蕉国产线看观看| 亚洲尤物视频在线| 欧美大片免费看| 欧美精品一区二区三区视频| 国产婷婷97碰碰久久人人蜜臀| 久久伊人亚洲| 亚洲高清在线播放| 99re66热这里只有精品4| 欧美色大人视频| 99亚洲一区二区| 欧美sm视频| 欲色影视综合吧| 国产精品护士白丝一区av| 久久不见久久见免费视频1| 国内一区二区三区在线视频| 欧美日韩一区视频| 欧美亚洲网站| 欧美日在线观看| 国产亚洲人成网站在线观看| 一区二区亚洲精品| 亚洲在线视频一区| 国产亚洲视频在线观看| 欧美性猛片xxxx免费看久爱| 欧美亚洲动漫精品| 久久躁日日躁aaaaxxxx| 在线观看欧美黄色| 伊人久久久大香线蕉综合直播| 亚洲精品在线免费观看视频| 宅男噜噜噜66国产日韩在线观看| 巨胸喷奶水www久久久免费动漫| 久久蜜桃精品| 欧美日韩国语| 国产一区观看| 国产精品海角社区在线观看| 精品51国产黑色丝袜高跟鞋| 国产精品影视天天线| 在线观看亚洲视频啊啊啊啊| 欧美人与性动交a欧美精品| 久久婷婷久久一区二区三区| 欧美大片va欧美在线播放| 欧美一级欧美一级在线播放| 国产欧美日韩激情| 国产欧美在线播放| 欧美国产综合| 免费日韩成人| 欧美午夜片欧美片在线观看| 精品91久久久久| aa国产精品| 欧美mv日韩mv国产网站| 久久日韩精品| 欧美一区二区久久久| 国产精品自拍视频| 欧美日韩一区二区三区视频| 欧美裸体一区二区三区| 久久中文在线| 国产精品毛片大码女人| 久久综合网络一区二区| 欧美亚洲视频一区二区| 欧美日韩一本到| 性欧美暴力猛交69hd| 国产精品夜夜嗨| 欧美日韩精品免费观看视频| 亚洲日本在线观看| 国产精品一卡| 亚洲一区二区三区视频| 欧美精品免费观看二区| 欧美国产丝袜视频| 久久精品99国产精品| 亚洲香蕉视频| 小黄鸭精品aⅴ导航网站入口| 国产日韩欧美在线| 亚洲视频 欧洲视频| 欧美另类在线播放| 亚洲精品国偷自产在线99热| 亚洲欧美一区二区原创| 国产精品久久久亚洲一区| 国产亚洲一区二区在线观看| 在线亚洲精品| 欧美日本成人| 国产精品激情偷乱一区二区∴| 一区二区三区福利| 韩国av一区二区| 亚洲综合色视频| 亚洲精品一二三区| 亚洲国产精品久久人人爱蜜臀| 欧美伦理一区二区| 欧美顶级艳妇交换群宴| 国产精一区二区三区| 国外成人免费视频| 猛干欧美女孩| 亚洲国产mv| 欧美一区二区三区四区视频| 99视频在线精品国自产拍免费观看| 樱桃成人精品视频在线播放| 欧美精品成人91久久久久久久| 亚洲韩国精品一区| 黑人巨大精品欧美一区二区| 国产午夜精品视频| 免费亚洲电影在线| 国产精品日韩在线观看| 亚洲国产精品日韩| 狠狠色狠狠色综合日日五| 欧美mv日韩mv国产网站| 久久黄金**| 国产精品久久久久久av下载红粉| 亚洲一区二区三区四区在线观看| 久久久久一区二区| 欧美成人精品激情在线观看| 蜜桃av综合| 午夜精品婷婷| 亚洲欧美日韩视频一区| 国内精品伊人久久久久av影院| 国产精品视频xxx| 久久成人18免费观看| 久久久久久久97| 国产精品xnxxcom| 久久av老司机精品网站导航| 欧美中文字幕在线观看| 国产一区二区三区自拍| 葵司免费一区二区三区四区五区| 亚洲国产一区二区a毛片| 亚洲视频一区二区| 欧美成人精品福利| 亚洲美女黄色片| 亚洲精品中文字幕在线观看| 国内精品久久久久影院色| 国产一区二区精品丝袜| 亚洲国产黄色片| 欧美一区二区三区喷汁尤物| 欧美在线免费观看视频| 国产精品久久久久久妇女6080| 欧美日韩亚洲一区二区| 国产精品多人| 国产亚洲欧洲997久久综合| 亚洲天堂成人| 激情六月婷婷综合| 亚洲国产三级网| 美乳少妇欧美精品| 国产精品对白刺激久久久| 欧美一区影院| 欧美午夜精品理论片a级大开眼界| 久久综合99re88久久爱| 一区二区三区欧美在线观看| 国产精品扒开腿爽爽爽视频| 国产精品一区久久久久| 久久久久9999亚洲精品| 亚洲永久免费视频| 91久久精品美女高潮| 国产一区二区三区四区老人| 日韩视频二区| 久久精品亚洲国产奇米99| 精品69视频一区二区三区| 激情亚洲成人| 亚洲国产成人porn| 国内精品视频在线播放| 亚洲日本乱码在线观看| 欧美人与性动交α欧美精品济南到| 在线电影欧美日韩一区二区私密| 欧美日韩综合在线免费观看| 国产精品初高中精品久久| 亚洲永久免费| 亚洲天堂网站在线观看视频| 亚洲黄页视频免费观看| 国产一区二区精品| 99精品视频免费观看| 亚洲午夜久久久久久尤物| 欧美日韩日本视频| 亚洲视频中文| 亚洲六月丁香色婷婷综合久久| 国内精品国语自产拍在线观看| 一区二区三区偷拍| 国户精品久久久久久久久久久不卡| 亚洲精品一区二| 亚洲高清123| 一区二区三区精品在线| 好吊日精品视频| 亚洲免费婷婷| 亚洲国内自拍| 亚洲一区二区视频在线观看| 欧美日韩精品国产| 国产精品白丝黑袜喷水久久久| 亚洲国产人成综合网站| 久久精品理论片| 蜜乳av另类精品一区二区| 午夜亚洲精品| 久久精品国产精品亚洲综合| 久久se精品一区精品二区| 国产午夜精品一区理论片飘花| 国内一区二区三区在线视频| 亚洲专区在线| 欧美三级网页| 一区二区免费在线观看| 国产精品久久久免费| 欧美日韩国产在线看| 国产日韩在线看片| 欧美不卡视频| 欧美日本高清一区| 黄色成人小视频| 亚洲小说欧美另类婷婷| 欧美日韩在线亚洲一区蜜芽| 欧美激情一区二区| 久久丁香综合五月国产三级网站| 久久久久久久高潮| 国产丝袜一区二区| 韩国av一区二区三区四区| 久久久久久久久久码影片| 欧美国产日本高清在线| 久久免费国产精品1| 久久综合五月天婷婷伊人| 国产一区二区按摩在线观看| 国产精品久久999| 激情欧美日韩一区| 亚洲精品色婷婷福利天堂| 亚洲欧美在线一区| 国产精品一二三四| 日韩一级黄色av| 最新中文字幕一区二区三区| 一本色道久久综合精品竹菊| 欧美成人dvd在线视频| 欧美a级片网站| 亚洲第一天堂av| 国产精品一卡| 欧美日韩ab| 国产精品国产a| 欧美专区亚洲专区| 久久青草欧美一区二区三区| 国产精品一区二区三区四区五区| 99re这里只有精品6| 亚洲精品在线免费观看视频| 国产精品进线69影院| 黄色欧美成人| 欧美激情一区二区三区在线视频观看| 亚洲动漫精品| 99精品热视频只有精品10| 农村妇女精品| 国内精品嫩模av私拍在线观看| 91久久香蕉国产日韩欧美9色| 国产欧美一区视频| 亚洲成人中文| 另类酷文…触手系列精品集v1小说| 亚洲人体偷拍| 欧美国产视频在线观看| 亚洲黄网站在线观看| 亚洲激情综合| 亚洲人永久免费| 国产夜色精品一区二区av| 亚洲视频免费在线观看| 久久精品国产在热久久| 欧美系列电影免费观看| 一区二区在线视频播放| 久久精品一本久久99精品| 国产日韩一级二级三级| 亚洲看片免费| 激情成人av| 欧美亚洲免费在线| 亚洲黄色有码视频| 国产精品一区一区三区| 欧美片第一页| 欧美日韩国产一中文字不卡| 国产精品一区久久久久| 亚洲国产一区视频| 欧美一区二区三区四区在线观看| 欧美一区二区三区免费观看| 麻豆精品一区二区综合av| 国产日韩欧美成人| 欧美三级不卡| 国产欧美一区二区三区视频| 一区二区三区三区在线| 一区二区三区日韩精品| 国产精品久久久久久久久搜平片| 一区二区三区在线视频播放| 欧美日本韩国一区二区三区| 欧美诱惑福利视频| 影音欧美亚洲| 亚洲午夜精品一区二区三区他趣| 一区二区三区高清| 中文一区字幕| 亚洲一区3d动漫同人无遮挡| 欧美一区二区三区视频免费播放| 免费91麻豆精品国产自产在线观看| 西西裸体人体做爰大胆久久久| 国产精品久久久久久久久免费樱桃| 亚洲精品视频在线看| 亚洲欧美日韩另类精品一区二区三区| 欧美日韩一区二区在线观看视频| 欧美性色aⅴ视频一区日韩精品| 黑人一区二区三区四区五区| 久久久水蜜桃av免费网站| 国产精品国产三级国产| 国内精品免费午夜毛片| 精品99一区二区三区| 国内外成人在线| 亚洲一区免费| 国内成人精品一区| 国产女主播视频一区二区| 国产一区三区三区| 国产一区二区激情| 91久久中文字幕| 国产精品丝袜xxxxxxx|