Maxim T1、E1和J1器件內部的彈性存儲器用作器件線路側和系統側之間的雙端口緩沖區。它允許雙方在不同的時鐘域甚至不同的頻率下工作。彈性存儲的性質使得很難理解設備在給定條件下的反應。本應用說明提供了許多不同的示例,應該消除有關彈性存儲如何在這些不同條件下運行的大多數問題。
介紹
Maxim T1、E1和J1器件內部的彈性存儲器用作器件線路側和系統側之間的雙端口緩沖區。它允許雙方在不同的時鐘域甚至不同的頻率下工作。彈性存儲的性質使得很難理解設備在給定條件下的反應。本應用說明提供了許多不同的示例,應該消除有關彈性存儲如何在這些不同條件下運行的大多數問題。
彈性存儲操作
彈性存儲是深度為 512 位的雙端口緩沖區。由于幀的位長度在 T1 和 E1 之間變化,因此使用的緩沖區位數取決于操作模式。有四種基本操作模式:
T1 模式:193 位幀
E1 模式:256 位幀
T1 到 E1 速率轉換模式:線路(網絡)端為 193 位幀,系統(背板)端為 256 位幀
交錯總線操作模式:線路(網絡)端為193位或256位幀,系統(背板)端為256位幀,具有高速間隙系統時鐘
為了闡明彈性存儲的操作,創建了以下一系列關系圖。每個示例都基于 E1 模式下具有 256 位幀的接收彈性存儲。寫入指針(由白點指示)由 RCLK 計時,并將數據寫入彈性存儲。由黑點指示的讀取指針由 RSYSCLK 計時,并從彈性存儲中讀取數據(如果在示例中使用傳輸彈性存儲,則寫入指針將由 TSYSCLK 計時,讀取指針將由 TCLK 計時)。圖 1 說明了寫入指針和讀取指針“理想情況下”以一幀為中心的情況。
圖1.彈性存儲讀取和寫入指針正好相隔一幀。
在圖 2 中,讀取指針(黑點)即將進入幀 B。當任一指針越過幀邊界時,將比較兩個指針之間的距離。任何低于設定閾值的距離都將導致幀滑動,并且剛剛越過幀邊界的指針將移動到下一幀的開頭。根據滑動的指針,將出現重復或刪除的幀。閾值取決于工作模式:E1模式下為16位,所有其他模式下為9位。在下面的示例中,寫入指針(白點)幾乎相距一幀,因此不會發生滑移,讀取指針將繼續進入幀 B。
圖2.讀取和寫入指針相距足夠遠,因此在比較后不會發生滑移。
在圖 3 中,讀取指針(黑點)的運行速度比寫入指針(白點)快,并且最終會趕上。當讀取指針越過邊界進入幀 A 時,它會檢測到寫入指針在幀 A 開始的 16 位范圍內。讀取指針不會進入幀 A,而是滑動并返回到幀 B 的開頭,位于位位置 256。由于讀取指針滑動,因此將重復從緩沖區讀取的最后一幀,并報告接收彈性存儲空事件。
圖3.在比較過程中,讀取指針與寫入指針太近,導致滑移。
當寫入指針的運行速度快于讀取指針時,情況也是如此。如果寫入指針檢測到讀取指針距離幀 B 的開頭在 16 位以內,則寫入指針將滑動并返回到幀 A 的位位置 0 的開頭。由于寫入指針滑動,因此將刪除寫入緩沖區的最后一幀,并報告接收彈性存儲已滿事件。導致滑移的寫入指針示例如圖 4 所示。
圖4.在比較過程中,寫入指針與讀取指針太近,導致滑移。
在上面的接收彈性存儲示例中,兩個指針應始終以恒定速率在緩沖區周圍移動。寫入指針由接收時鐘計時,并且基于恢復的時鐘或載波丟失時的主時鐘保持恒定。讀取指針由接收系統時鐘計時,并且應基于外部時鐘或背板時鐘保持恒定。因此,滑移爭用邏輯將始終能夠檢測到滑移事件。邏輯將重復或刪除數據幀,彈性存儲將立即恢復,僅出現單個幀錯誤。
審核編輯:郭婷
-
Maxim
+關注
關注
8文章
859瀏覽量
87250 -
存儲器
+關注
關注
38文章
7507瀏覽量
163963 -
存儲
+關注
關注
13文章
4323瀏覽量
85927 -
時鐘
+關注
關注
11文章
1735瀏覽量
131546 -
指針
+關注
關注
1文章
480瀏覽量
70580
發布評論請先 登錄
相關推薦
評論