下面我們進入正題,今天我們講時序 一、從靜態時序分析說起 我理解的靜態時序分析,就是我們在不加激勵的情況下,通過對電路進行時序的延遲計算,預計電路的工作流程,對電路提出我們需要的一些約束條件,比如我們需要從A寄存器到B寄存器的延遲不能大于10ns,如果我們不添加時序約束,綜合工具可能會有好幾條路徑,按照它自己的要求來布局布線,那么從A寄存器到B寄存器的時間就有可能是20ns或者15ns之類的路徑,而我們需要的是不能大于10ns,因此,我們需要添加時序約束,再根據特定的時序模型,使我們的系統達到設計要求。 這里的時間延遲可能包括我們的PCB板的走線延遲,也包括FPGA內部的走線延遲,時鐘延遲等等,這里我們添加的時序約束,就相當于我們在沒有下板之前,通過計算,來模擬仿真下板后的延遲情況,并通過時序報告查看有哪些違規路徑,以及建立保持時間不平衡的情況,通過時序優化使其達到一個穩定狀態的過程。 小墨在做SDRAM時序約束的時候深有體會,即使我們老老實實的按照時序計算公式將延時計算出來添加到工程中去,時序報告也顯示時序收斂并且也幾乎達到了建立保持時間的平衡狀態,前后仿真也沒什么問題,以為一切就緒了,但是下板后就是跑不起來,最后我還是改動了一下約束參數,有時候甚至改動幅度與計算幅度相比較大,當然還是在保證時序收斂的情況下,下板之后竟然跑起來了,可能是我第一次接觸時序這個高大上的概念,經驗不足吧,有的時候真是碰運氣....當然等會我將源碼共享的時候,大家還需要自己進行時序約束,因為我們的FPGA芯片型號,PCB布局,SDRAM型號都不太一樣,那么跑起來是件很困難的事情,所以大家還需要自己親自學一下這部分的知識,自己去摸索。 我們直接來看這個圖, 要看懂這個圖,當然還需要有一個模型 時序圖上的第一個時鐘,即我們的源時鐘,或者說是我們的晶振時鐘,從晶振到達源寄存器,這段路程肯定是有延遲的,我們把這段延遲叫做Tc2s,也即我們的clk1. 時序圖上的第二個時鐘,是我們的源時鐘到達目的寄存器的時鐘,即我們的鎖存寄存器的時鐘,它到目的寄存器的延遲,我們稱為Tc2d,也即我們的clk2 clk1 到達源寄存器的時候,將輸入的數據鎖存器到源寄存器,目的寄存器沒有鎖存值,等到第二個時鐘周期,clk2 到達目的寄存器的時候,將源寄存器的輸出數據鎖存,數據必須在clk2 到達之前保持穩定,從數據到達目的寄存器到clk2到達這段時間,稱為建立時間,當然,數據被鎖存之后,還需要保持穩定一段時間,這段時間稱為保持時間。 從數據被源寄存器鎖存開始,到數據出現在目的寄存器的這段時間,我們稱為數據的傳輸時間Tco 我們做這樣一個考慮,如果Tco很長,也就是說,數據從被源寄存器捕獲,到出現在目的寄存器的延時時間較長,甚至長到clk2到達目的寄存器的時候還沒有到達,那么,我們就說這段路徑,建立時間違規,數據不能被正確捕獲,這時候,我們就可以給其添加約束,讓數據在多少納秒之內到達,保證數據被捕獲,然后綜合工具就會根據我們的要求,尋找最佳路徑,從而保證建立時間足夠長。 同理,假設Tco很短,短到clk2到來的時候,本來應該被捕獲的數據,還沒有保持一定的穩定時間,就被下一個要捕獲的數據給覆蓋了,或者說我們捕獲到的是下一個要捕獲的數據,從而造成保持時間違規 所以,Tco的時間既不能太長,也不能太短,必須在一個合理的范圍內,盡量讓目的寄存器的捕獲時鐘在數據的有效窗口內,所以,建立保持時間必須滿足下列公式,公式的由來完全來自于時序圖 其中,Tc2d - Tc2s叫做時鐘偏斜,這兩個公式,是我們下面分析SDRAM時序的兩個重要公式 再來看一下這兩個公式,既然我們要做時序分析,得要知道我們要分析的是哪一部分吧,Tclk我們無法改變,就是系統時鐘嘛,時鐘偏斜我們也改變不了,因為對于一個特定的FPGA器件,時鐘偏斜相對固定,所以我們可以改變的就是Tco,怎么改變呢,就是添加我們的時序約束,讓綜合工具按照我們的要求尋找符合我們約束的路徑,從而滿足建立保持時間的要求。 二、輸入輸出模型以及I/O約束 1、先來看輸出模型 當然這個輸出模型并不是很符合我們的FPGA 和SDRAM的輸出模型,是我從網上找來的一張圖片,不過沒關系,做一下修改就好了。 我們的源時鐘需要進入FPGA的PLL中,然后輸出給我們的FPGA做內部時鐘,在輸出到外部做SDRAM的工作時鐘,所以上圖中,晶振到外部器件的時鐘路徑,應該是PLL的輸出到SDRAM的輸出路徑 還有,我們之前做的靜態時序分析,是基于在FPGA內部的,所以數據的延遲時間只有Tco一個參數,然而,我們的這個輸出模型,是源寄存器在FPGA內部,而目的寄存器在我們的SDRAM內部,所以,我們的數據輸出路徑的延遲,還需要加上一部分,即我們的外部PCB走線延遲 這樣,我們的輸入延遲 = 數據在FPGA內部傳輸延遲 Tco + 外部PCB走線延遲 帶入我們的靜態時序分析的建立時間公式得 Tco Th 即 Tco > Th - 外部PCB走線延時 + 最大時鐘網絡延時 其中,最小輸出延時 = Th - 外部PCB走線延時 + 最大時鐘網絡延時 即 Tco > 最小輸出延時 2、再來看輸入模型 輸入模型無非就是跟輸出模型相反罷了,原來FPGA作為輸出,現在作為輸入,還是要考慮我們之前靜態時序分析的時候推出的那兩個公式 即 Tclk + 時鐘偏斜 > Tco + 外部PCB走線延時 + Tsu 那么Tco + 外部PCB走線延時 + 時鐘網絡延時 Th 即最小輸入延時 > Th 3、下面我們做一個總結 最大輸出延時 = 外部器件的Tsu + 外部PCB最大延遲 + 最大時鐘網絡延時 最小輸出延時 = 外部器件的Th - 外部最小PCB走線延時 + 最大時鐘網絡延時 最大輸入延時 = 外部器件最大Tco + 外部PCB最大走線延時 + 最大時鐘網絡延時 最小輸入延時 = 外部器件最小Tco + 外部PCB最小走線延時 + 最小時鐘網絡延時 下面再來解釋一下最大最小問題,看到這大家肯有點看不懂了,剛才還覺得可以,加了一些最大最小就看不懂了,其實我們要做的輸出,不僅僅是有一個引腳輸出,拿我們的SDRAM來說,有12根地址線,還有16根數據線還有其他的控制信號線要輸出,那么,我們應該選其中最長的,或者最短的來考慮,只要最長的或者最短的滿足要求了,其他的自然也就滿足要求了,即我們用最壞的打算來考慮我們的約束路徑。 還有最大最小時鐘網絡延時,由于這里我們只有一跟時鐘線,就無所謂最大最小了,這么說就是為了規范 最大最小外部器件的Tco,數據經過SDRAM的時候,并不是時間都是一樣的,總有些快慢問題,這里我們也取極限,就是數據經過SDRAM的最大時間和最小時間,這個時間在datasheet里面是有參數的 細心的朋友可能會發現 最小輸出延時計算的時候,為什么是減去 最小PCB走線延時呢,為什么不是最大?為什么不是加上最大時鐘網絡延時呢?為什么不是最小?其實,時序分析工具分析的時候是按照一定的公式計算數據到達時間和數據需要時間的,這個公式見下圖 在計算保持時間余量,數據需要時間的時候,公式是減去 output minimum delay of pin 為什么是減去呢,按理說應該是加上我們的輸出最小延時才對,小墨當時也不理解,所以就當是記住吧,也就是說 這里的 output minimum delay of pin = - 輸出最小延時 這樣理解的話,那么輸出最小延時越大,那么output minimum delay of pin 就越小了,也就是為什么是減去最小PCB延時的原因吧 后面我們到時序分析工具里面看時序報告圖的時候就會發現,如果我們約束的最小輸出延時是負數的話,里面顯示的卻是正數,所以,我們就暫時記住好了,因為真的是不好理解。 三、參數計算 根據我們剛才推斷出來的那幾個公式,我們就可以進行參數計算了,先來看看我們需要什么參數 輸出模型的時候,我們需要的是SDRAM的建立時間,保持時間,外部PCB走線延時,輸入模型的時候,我們需要的是外部器件的最大最小Tco SDRAM的建立保持時間可以從datasheet里面找到 根據器件型號,我們選擇建立時間為 1.5 ns ,保持時間為 0.8ns,外部PCB走線延時這個不怎么好算,只能估計吧,因為板子不是我畫的,長度也不知道,根據經驗,我們知道,信號在PCB上的延時大概為0.18ns /1000mil,那我就估計為最大0.3ns,最小0.1好了 然后是時鐘網絡延時,也就是源時鐘到達源寄存器 - 到達目的寄存器的值,由于我們的時鐘是總PLL發出的,時鐘從FPGA管腳輸出后再送給SDRAM,因此這個值一定是負值,而且也是時鐘在PCB上的走線延時,這個值我們估算為-0.1ns好了,因為真的沒法算我覺得。 然后是數據經過外部器件的最大最小延時,這個值我們在SDRAM的理論篇里面說了,就是Tac參數和Toh參數,不懂得朋友可以到前面去補補課,這個值我們在datasheet里面也找得到 所以我們取最大Tco 為5.4ns 最小Tco為2.7ns 經過計算得我們的約束參數 最大輸出延時 =外部器件的Tsu+外部PCB最大延遲+最大時鐘網絡延時 =1.5+0.3-0.1=1.7ns 最小輸出延時 = 外部器件的Th - 外部最小PCB走線延時 + 最大時鐘網絡延時 = -(0.8 - 0.1 - 0.1 ) = - 0.6ns 最大輸入延時 = 外部器件最大Tco + 外部PCB最大走線延時 + 最大時鐘網絡延時 = 5.4 + 0.3 - 0.1=5.6ns 最小輸入延時 = 外部器件最小Tco + 外部PCB最小走線延時 + 最小時鐘網絡延時 = 2.7 + 0.1 -0.1 = 2.7ns 四、全局時鐘約束 由于我們的時鐘是由晶振源傳到PLL,然后再由PLL輸出給SDRAM和FPGA內部寄存器的,因此我們需要對輸入的時鐘進行約束,約束其為50M的時鐘,并對應好我們的端口時鐘clk,即約束我們的輸入時鐘為50M,并給這個時鐘取一個在時序分析時鐘的名字,即sys_clk,關于timequest的使用,大家還需自行學習,這里僅僅只是說約束方法 而對于PLL輸出時鐘的約束,我們僅需在.sdc文件相應的的位置,手動輸入約束即可,僅需要一條語句 ,這條命令輸進去以后,時序分析工具會自動的為我們約束好PLL的輸出時鐘 我們可以通過查看時序報告,可以看到,我們的時鐘都跑到了我們約束的條件,如果我們不加這條語句的的話,那么PLL的輸出時鐘是達不到這個要求的,那樣的話,我們的時鐘都不穩定,更別提系統穩定性了 五、關于虛擬時鐘 上圖中,細心的朋友可能會看到,第一行有一個SDRAM_CLK,這個時鐘是怎么來的呢?這個時鐘,其實就是我們給外部的芯片模擬了一個時鐘,因為外部器件的時鐘是我們PLL生成,送到外部管腳去的,并不是我們FPGA的內部時鐘,既然不是內部時鐘,那么我們就無法對其進行約束,我們只能定義這么一個虛擬的時鐘,來盡可能模擬SDRAM的工作時鐘。 例如,輸入的時候,源寄存器在SDRAM中,目的寄存器在FPGA中,數據的傳輸是在SDRAM工作時鐘下進行的,但是時序分析工具不知道這個時鐘,所以我們定義一個虛擬時鐘,連接好它的路徑,即從哪輸出,輸到哪,這里的話就是從PLL的clk2輸出,到SDRAM的時鐘輸入引腳了。因為這里是時序約束模型為源同步時序模型,即時鐘都是由FPGA產生,在不是源同步時序模型的情況下,就不需要指明虛擬時鐘的源和目的,只需要指明周期即可。 既然是模擬,那我們也應該考慮到這個時鐘從PLL輸出,到FPGA引腳的這段時間的延時,我們對其進行最大,最小延時約束 同理,我們約束最小值為0ns,這里就不做演示了,方法是一樣的 六、I/O時序約束 由于篇幅所限,這里就不能一點點的做了,只舉個例子吧,做最大輸入延時的約束,我們點擊 constraints ———> set input delay 時鐘名字我們選的就是我們生成的虛擬時鐘,為什么呢?因為我們做的是IO約束,即FPGA和SDRAM互相交換數據,既然交換數據肯定是建立在時鐘的基礎上的,這個時鐘,就是虛擬時鐘。這個地方比較難懂了,我理解的也不是太好。畢竟我們是要看得是時序報告,時序報告就是建立在虛擬時鐘的基礎上的一個模擬過程。先理解到這里吧,也不知道該怎么解釋了,還請看到的大神給指點一二吧~ 下面我們做最大輸入延時的約束,設置我們最大的輸入延時為5.4ns 設置輸入路徑,因為只有SDRAM_data路徑是雙向的,做輸入的時候僅考慮這個路徑即可 然后我們再做一個輸出最大延時的約束,輸出最大延時為1.7ns ,輸出路徑包括除了時鐘和時鐘有效信號sdram_cke信號外的所有的SDRAM引腳,當然也包括sdram_data信號,為什么不包括cke信號呢?因為cke信號自始至終沒有多少次的變化,也就是說對時序要求不嚴格,對于這種信號,類似還有片選信號,數碼管片選,位選等,我們只需對其進行false路徑約束即可,即對時序沒有嚴格要求的路徑 剩下的路徑我就不再做了,都是一樣的,將所有路徑約束好之后,我們需要開始調sdram工作時鐘的相位偏移了 由于篇幅所限,剩下的內容我放到下篇中講,謝謝大家~ |