跨時鐘域電路設計——多bit信號FIFO

多個bit信號的跨時鐘域僅僅通過簡單的同步器同步時不安全的。

如下圖:

雖然信號都同步到目的時鐘域,可完成的功能卻與設計的初衷不相符。

解決方案之一為對信號進行格雷碼編碼,但此方案只適用于連續變化的信號。另一種方案為增加新的控制信號en,確保傳輸信號穩定時采樣。比如在傳輸信號穩定輸出1、2個clk后再進行采樣。

一、異步FIFO

上面說到的為多bit指示信號傳輸,而數據流的傳輸與指示信號不同在于:數據流大多具有連續性,及背靠背傳輸;數據流要求信號具有較快的傳輸速度。主要的方案是利用FIFO進行傳輸。

異步FIFO結構如下:

?

1、FIFO的參數

  • 寬度:一次讀寫操作的數據位
  • 深度:可以存儲的N位數據的數目(寬度為N)
  • 滿標志:FIFO已滿或將要滿時,由FIFO的狀態電路送出的信號,阻止FIFO寫操作
  • 空標志:FIFO已空或將要空時,由FIFO的狀態電路送出的信號,阻止FIFO讀操作
  • 讀時鐘:讀操作所遵循的時鐘
  • 寫時鐘:寫操作所遵循的時鐘

2、設計空滿標志位電路

正確產生空滿信號是任何FIFO設計的關鍵。其設計原則是:能寫滿而不溢出,能讀空而不多讀

  • 在寫時鐘域下,判斷讀寫指針的關系,生成滿標志
  • 在讀時鐘域下,判斷讀寫指針的關系,生成空標志

對于空滿判斷,可看下圖

在判斷空和滿的情況下,都會有讀寫指針相等的情況,可采用以下方法進行區分:

在地址中額外添加一個位,當寫指針增加并越過最后一個地址位時,就將這個額外的位(MSB)加一,其他位回0。讀指針也進行同樣的操作。額外的位作為折回標志位。如果兩個指針的MSB不同,其余位相等,說明讀指針比寫指針少折回了一次,這種情況下,FIFO為滿。而讀寫指針所有位都相等,說明折回次數相等,此時FIFO為空。

解決空滿判斷后,則是讀寫指針同步的問題。二進制的讀寫指針通常位寬超過了1bit,而多比特信號是不可以直接使用兩級同步器的。這時,考慮到FIFO地址是連續變化的,我們使用格雷碼來進行傳輸。格雷碼相鄰兩個數值只有一位發生變化,0和最大數之間也只有一位不同。

而轉換為格雷碼進行傳輸后,如何進行空滿判斷?如下圖:

至于為什么選擇格雷碼進行傳輸,我們來看格雷碼傳輸失效的情況:

格雷碼傳輸失效,只有一位同步出錯,此時地址沒有跳變。如果是寫地址同步失效,用這個錯誤的寫地址在讀時鐘域進行空判斷時不會出錯,最多是讓空標志在FIFO不是真正空的時候產生,而不會產生空讀的情況。格雷碼保證的是同步后的讀寫地址即使在出錯的情況下依然能夠保證FIFO功能的正確性。

?

3、設計FIFO的深度

先從一個例題入手,

假設FIFO的寫時鐘為100MHZ,讀時鐘為80MHZ。在FIFO輸入側,每100個時鐘,寫入80個數據;FIFO讀入測,每個時鐘讀取一個數據。設計合理的FIFO深度,使FIFO不會溢出。

我們需要考慮數據輕載和重載的情況,對緩存能力要求最高的情況為背靠背傳輸,則FIFO深度為160-(160/100)*80=32

我們將問題一般化:

  1. 寫時鐘頻率WCLK
  2. 讀時鐘頻率RCLK
  3. 寫入測每B個時鐘周期有A個數據寫入
  4. 讀取測每Y個時鐘周期有X個數據讀出

則FIFO的深度為Depth=burst\_length-\frac{burst\_length}{wclk}*(rclk*\frac{X}{Y}),其中burst_length與寫入測情況有關。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/253869.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/253869.shtml
英文地址,請注明出處:http://en.pswp.cn/news/253869.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

嵌入式linux系統中設備驅動程序

嵌入式linux系統中設備驅動程序是內核的一部分,完成對設備初始、讀寫操作和控制等功能。驅動程序隱藏了硬件設備的具體細節,對不同的設備提供一致的接口,這些接口通過file_Operation結構來定義,設計驅動程序的大部分工作就是根據硬…

WPF 打印實例

原文:WPF 打印實例在WPF 中可以通過PrintDialog 類方便的實現應用程序打印功能&#xff0c;本文將使用一個簡單實例進行演示。首先在VS中編輯一個圖形&#xff08;如下圖所示&#xff09;。 將需要打印的內容放入同一個<Canvas>中&#xff0c;并起名為“printArea”&…

mongodb 物理刪除數據

剛開始用mongodb的時候&#xff0c;感覺很好用&#xff0c;速度很快&#xff0c;不過后面就遇到一個問題&#xff0c;數據物理內存一直增加&#xff0c;刪除表也不管用。 然后網上找了各種辦法&#xff0c;最后發現一個辦法管用&#xff0c;就是物理刪除存儲數據。 操作如下&am…

計數排序、桶排序和基數排序

計數排序 當輸入的元素是 n 個 0 到 k 之間的整數時&#xff0c;它的運行時間是 Θ(n k)。計數排序不是比較排序&#xff0c;排序的速度快于任何比較排序算法。 由于用來計數的數組C的長度取決于待排序數組中數據的范圍&#xff08;等于待排序數組的最大值與最小值的差加上1&a…

靜態時序分析——基礎概念

一、簡述 靜態時序分析是檢查系統時序是否滿足要求的主要手段。以往時序的驗證依賴于仿真&#xff0c;采用仿真的方法&#xff0c;覆蓋率跟所施加的激勵有關&#xff0c;有些時序違例會被忽略。此外&#xff0c;仿真方法效率非常的低&#xff0c;會大大延長產品的開發周期。靜…

linux framebuffer 例子

昨天做的一個極簡單的framebuffer的例子&#xff0c;用來學習怎樣操作fb設備。 這段代碼是在picogl的vesafb backend部分的基礎上簡出來的&#xff0c;所以變量名還保留著。 流程如下&#xff1a; &#xff11; 打開framebuffer設備&#xff1b; &#xff12; 通過ioctl取得f…

加載數據時,頁面顯示正在加載的動畫,支持移動端

最近在使用ionic3做一個移動端APP&#xff0c;在用戶網絡環境差的時候&#xff0c;查詢數據會比較慢&#xff0c;這個時候需要模擬其他成熟的APP給頁面上加入一個加載的動畫。由于一開始我不知道ionic3本身已經提供了一套組件&#xff0c;所以自己先做了一套樣式。提供給不用框…

靜態時序分析——單周期

一、建立時間的檢查 建立時間的檢查是指檢查電路里每一個觸發器的數據和時鐘的關系是否滿足建立時間的要求。 我們以上圖為例進行建立時間檢查。由圖可知&#xff0c;我們主要針對第二個觸發器UFF1進行檢查。我們可以梳理時序關系如下&#xff1a; 通過這個圖&#xff0c;我們…

自己搭建的CISCO實驗環境

交換機&#xff1a;設備型號&#xff1a; CISCO 3750 24-TS 3臺CISCO 3750 48-PS 1臺路由器&#xff1a;設備型號&#xff1a;1.CISCO 2821 3臺2.CISCO 3745 3臺 物理拓撲圖如下&#xff1a; 轉載于:https://blog.51cto.com/zxs3026/2156424

關于大數定律的討論(轉)

科普一下所謂“大數定律的四種證法” 作者 : 王若度最近網上總是調侃數學、統計博士知道所謂“大數定律的四種證法”&#xff0c;本身是模仿《孔乙己》的橋段&#xff0c;用以調侃數學、統計博士學一些沒什么用的東西。其實我是從來沒聽說過大數定律的四種證法這回事的&#x…

DM365 u-boot 啟動分析

第一階段&#xff1a;匯編語言啟動 先看u-boot/board/davinci/dm365_ipnc/下的文件。 u-boot.lds OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm") OUTPUT_ARCH(arm) ENTRY(_start) SECTIONS { . 0x0000000…

[Luogu1821][USACO07FEB]銀牛派對Silver Cow Party

由題意可知&#xff0c;我們需要求的是很多個點到同一個店的最短距離&#xff0c;然后再求同一個點到很多個點的最短距離。 對于后者我們很好解決&#xff0c;就是很經典的單源最短路徑&#xff0c;跑一邊dijkstra或者SPFA即可。 然而對于前者&#xff0c;我們應該怎么解決呢&a…

CMOS組合邏輯

1. 靜態互補CMOS 實際上就是靜態CMOS反相器擴展為具有多個輸入。更反相器一樣具有良好的穩定性&#xff0c;性能和功耗。 靜態的概念&#xff1a;每一時刻每個門的輸出通過低阻抗路徑連到VDD或VSS上。任何時候輸出即為布爾函數值。動態電路通常依賴把信號暫存在高阻抗節點的電…

繪制泰森多邊形

使用到的數據文件&#xff0c;內容如圖&#xff1a; 代碼&#xff1a; clc; clear; close all; % 導入需要的坐標數據成矩陣 a load(test.txt); x a(:,1); y a(:,2); x x;%獲取坐標的橫坐標 y y;%獲取坐標的縱坐標 %根據點 繪制泰森多邊形 voronoi(x,y); %設定x軸的邊界 x…

(八)限定某個目錄禁止解析php、限制user_agent和PHP相關配置

2019獨角獸企業重金招聘Python工程師標準>>> 限定某個目錄禁止解析php 對于使用php語言編寫的網站&#xff0c;有一些目錄是有需求上傳文件的。如果網站代碼有漏洞&#xff0c;讓黑客上傳了一個用PHP寫的木馬&#xff0c;由于網站可以執行PHP程序&#xff0c;最終會…

靜態時序分析——多周期、半周期和偽路徑

一、多周期 multicycle paths 在一些情況下&#xff0c;如下圖所示&#xff0c;兩個寄存器之間的組合電路傳輸的邏輯延時超過一個時鐘周期。在這樣的情況下&#xff0c;這個組合路徑被定義為多周期路徑&#xff08;multicycle path&#xff09;。盡管后一個寄存器會在每一個的…

微信頭像單張圖片上傳

后臺配置 public function upload_img($img){import(ORG.Tencent.Weixin);$wx new Weixin(get_app_config());$media_data$wx->getMedia($img);$path./Uploads/.uniqid()..jpg;if(!file_put_contents($path,$media_data)){$this->error(圖片上傳失敗);}return $path;}前…

u-boot nand flash read/write cmd

支援的命令函數說明1. nand info/nand device功能&#xff1a;顯示當前nand flash晶片資訊。函數調用關係如下(按先後順序)&#xff1a;static void nand_print(struct nand_chip *nand) ;2. nand erase 功能&#xff1a;擦除指定塊上的數據。 函數調用關係如下(按先後順序)&am…

APP測試瞎話

APP測試 一、功能性 1、APP的安裝、卸載 2、APP中業務功能 二、性能測試 1、高、中、低端機上運行效果 2、APP安裝過程、卸載過程的耗時 3、APP運行時&#xff0c;手機的CPU、內存、耗電量、流量、FPS&#xff08;畫面每…

網絡七層協議之物理層

我們以一個非常簡單的例子開始&#xff1a; 兩服務器通訊問題 如上圖&#xff0c;有兩臺服務器&#xff0c;分別是 Server 1 和 Server 2 。 我們先做一個假設&#xff1a;計算機網絡現在還沒有被發明出來&#xff0c; 作為計算機科學家的你&#xff0c;想在這兩臺服務器間傳遞…