新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 牛人業(yè)話 > 零基礎(chǔ)學(xué)FPGA (二十四)必會! 從靜態(tài)時(shí)序分析到SDRAM時(shí)序收斂(上篇)

零基礎(chǔ)學(xué)FPGA (二十四)必會! 從靜態(tài)時(shí)序分析到SDRAM時(shí)序收斂(上篇)

—— 零基礎(chǔ)學(xué)FPGA (二十三)必會! 從靜態(tài)時(shí)序分析到SDRAM時(shí)序收斂(上篇)
作者: 時(shí)間:2015-08-18 來源:網(wǎng)絡(luò) 收藏

  下面我們進(jìn)入正題,今天我們講時(shí)序

本文引用地址:http://2s4d.com/article/278905.htm

  一、從靜態(tài)時(shí)序分析說起

  我理解的靜態(tài)時(shí)序分析,就是我們在不加激勵(lì)的情況下,通過對電路進(jìn)行時(shí)序的延遲計(jì)算,預(yù)計(jì)電路的工作流程,對電路提出我們需要的一些約束條件,比如我們需要從A寄存器到B寄存器的延遲不能大于10ns,如果我們不添加時(shí)序約束,綜合工具可能會有好幾條路徑,按照它自己的要求來布局布線,那么從A寄存器到B寄存器的時(shí)間就有可能是20ns或者15ns之類的路徑,而我們需要的是不能大于10ns,因此,我們需要添加時(shí)序約束,再根據(jù)特定的時(shí)序模型,使我們的系統(tǒng)達(dá)到設(shè)計(jì)要求。

  這里的時(shí)間延遲可能包括我們的PCB板的走線延遲,也包括內(nèi)部的走線延遲,時(shí)鐘延遲等等,這里我們添加的時(shí)序約束,就相當(dāng)于我們在沒有下板之前,通過計(jì)算,來模擬仿真下板后的延遲情況,并通過時(shí)序報(bào)告查看有哪些違規(guī)路徑,以及建立保持時(shí)間不平衡的情況,通過時(shí)序優(yōu)化使其達(dá)到一個(gè)穩(wěn)定狀態(tài)的過程。

  小墨在做時(shí)序約束的時(shí)候深有體會,即使我們老老實(shí)實(shí)的按照時(shí)序計(jì)算公式將延時(shí)計(jì)算出來添加到工程中去,時(shí)序報(bào)告也顯示時(shí)序收斂并且也幾乎達(dá)到了建立保持時(shí)間的平衡狀態(tài),前后仿真也沒什么問題,以為一切就緒了,但是下板后就是跑不起來,最后我還是改動(dòng)了一下約束參數(shù),有時(shí)候甚至改動(dòng)幅度與計(jì)算幅度相比較大,當(dāng)然還是在保證時(shí)序收斂的情況下,下板之后竟然跑起來了,可能是我第一次接觸時(shí)序這個(gè)高大上的概念,經(jīng)驗(yàn)不足吧,有的時(shí)候真是碰運(yùn)氣....當(dāng)然等會我將源碼共享的時(shí)候,大家還需要自己進(jìn)行時(shí)序約束,因?yàn)槲覀兊?a class="contentlabel" href="http://2s4d.com/news/listbylabel/label/FPGA">FPGA芯片型號,PCB布局,型號都不太一樣,那么跑起來是件很困難的事情,所以大家還需要自己親自學(xué)一下這部分的知識,自己去摸索。

  我們直接來看這個(gè)圖,

  

?

  要看懂這個(gè)圖,當(dāng)然還需要有一個(gè)模型

  

?

  時(shí)序圖上的第一個(gè)時(shí)鐘,即我們的源時(shí)鐘,或者說是我們的晶振時(shí)鐘,從晶振到達(dá)源寄存器,這段路程肯定是有延遲的,我們把這段延遲叫做Tc2s,也即我們的clk1.

  時(shí)序圖上的第二個(gè)時(shí)鐘,是我們的源時(shí)鐘到達(dá)目的寄存器的時(shí)鐘,即我們的鎖存寄存器的時(shí)鐘,它到目的寄存器的延遲,我們稱為Tc2d,也即我們的clk2

  clk1 到達(dá)源寄存器的時(shí)候,將輸入的數(shù)據(jù)鎖存器到源寄存器,目的寄存器沒有鎖存值,等到第二個(gè)時(shí)鐘周期,clk2 到達(dá)目的寄存器的時(shí)候,將源寄存器的輸出數(shù)據(jù)鎖存,數(shù)據(jù)必須在clk2 到達(dá)之前保持穩(wěn)定,從數(shù)據(jù)到達(dá)目的寄存器到clk2到達(dá)這段時(shí)間,稱為建立時(shí)間,當(dāng)然,數(shù)據(jù)被鎖存之后,還需要保持穩(wěn)定一段時(shí)間,這段時(shí)間稱為保持時(shí)間。

  從數(shù)據(jù)被源寄存器鎖存開始,到數(shù)據(jù)出現(xiàn)在目的寄存器的這段時(shí)間,我們稱為數(shù)據(jù)的傳輸時(shí)間Tco

  我們做這樣一個(gè)考慮,如果Tco很長,也就是說,數(shù)據(jù)從被源寄存器捕獲,到出現(xiàn)在目的寄存器的延時(shí)時(shí)間較長,甚至長到clk2到達(dá)目的寄存器的時(shí)候還沒有到達(dá),那么,我們就說這段路徑,建立時(shí)間違規(guī),數(shù)據(jù)不能被正確捕獲,這時(shí)候,我們就可以給其添加約束,讓數(shù)據(jù)在多少納秒之內(nèi)到達(dá),保證數(shù)據(jù)被捕獲,然后綜合工具就會根據(jù)我們的要求,尋找最佳路徑,從而保證建立時(shí)間足夠長。

  同理,假設(shè)Tco很短,短到clk2到來的時(shí)候,本來應(yīng)該被捕獲的數(shù)據(jù),還沒有保持一定的穩(wěn)定時(shí)間,就被下一個(gè)要捕獲的數(shù)據(jù)給覆蓋了,或者說我們捕獲到的是下一個(gè)要捕獲的數(shù)據(jù),從而造成保持時(shí)間違規(guī)

  所以,Tco的時(shí)間既不能太長,也不能太短,必須在一個(gè)合理的范圍內(nèi),盡量讓目的寄存器的捕獲時(shí)鐘在數(shù)據(jù)的有效窗口內(nèi),所以,建立保持時(shí)間必須滿足下列公式,公式的由來完全來自于時(shí)序圖

  

?

  其中,Tc2d - Tc2s叫做時(shí)鐘偏斜,這兩個(gè)公式,是我們下面分析時(shí)序的兩個(gè)重要公式

  再來看一下這兩個(gè)公式,既然我們要做時(shí)序分析,得要知道我們要分析的是哪一部分吧,Tclk我們無法改變,就是系統(tǒng)時(shí)鐘嘛,時(shí)鐘偏斜我們也改變不了,因?yàn)閷τ谝粋€(gè)特定的器件,時(shí)鐘偏斜相對固定,所以我們可以改變的就是Tco,怎么改變呢,就是添加我們的時(shí)序約束,讓綜合工具按照我們的要求尋找符合我們約束的路徑,從而滿足建立保持時(shí)間的要求。

  二、輸入輸出模型以及I/O約束

  1、先來看輸出模型

  

?

  當(dāng)然這個(gè)輸出模型并不是很符合我們的FPGA 和SDRAM的輸出模型,是我從網(wǎng)上找來的一張圖片,不過沒關(guān)系,做一下修改就好了。

  我們的源時(shí)鐘需要進(jìn)入FPGA的PLL中,然后輸出給我們的FPGA做內(nèi)部時(shí)鐘,在輸出到外部做SDRAM的工作時(shí)鐘,所以上圖中,晶振到外部器件的時(shí)鐘路徑,應(yīng)該是PLL的輸出到SDRAM的輸出路徑

  還有,我們之前做的靜態(tài)時(shí)序分析,是基于在FPGA內(nèi)部的,所以數(shù)據(jù)的延遲時(shí)間只有Tco一個(gè)參數(shù),然而,我們的這個(gè)輸出模型,是源寄存器在FPGA內(nèi)部,而目的寄存器在我們的SDRAM內(nèi)部,所以,我們的數(shù)據(jù)輸出路徑的延遲,還需要加上一部分,即我們的外部PCB走線延遲

  這樣,我們的輸入延遲 = 數(shù)據(jù)在FPGA內(nèi)部傳輸延遲 Tco + 外部PCB走線延遲

  帶入我們的靜態(tài)時(shí)序分析的建立時(shí)間公式得

  Tco < Tclk - Tsu - 外部PCB延遲 + 時(shí)鐘偏斜

  由于是輸出模型,所以,Tco即我們的約束部分,Tsu即SDRAM的建立時(shí)間,又因?yàn)?,altera官方提供的資料,不用時(shí)鐘偏斜這一概念,用的是時(shí)鐘網(wǎng)絡(luò)延時(shí),

  即時(shí)鐘網(wǎng)絡(luò)延時(shí) = - 時(shí)鐘偏斜,即 Tc2s - Tc2d

  所以,我們得出輸出模型的一個(gè)最終公式

  Tco < Tclk - Tsu - 外部PCB延遲 - 最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  其中 Tsu + 外部PCB延遲 + 最大時(shí)鐘網(wǎng)絡(luò)延時(shí) 稱為最大輸出延時(shí)

  也即 Tco < Tclk - 最大輸出延時(shí)

  我們到時(shí)候給時(shí)序分析工具添加的,就是這個(gè)最大輸出延時(shí),有人會問,為什么我們添加的不是 Tclk - 最大輸出延時(shí),這個(gè)問題我之前也想過,我理解的就是,最大輸出延時(shí)是真實(shí)存在的,當(dāng)我們下板之后,這些延時(shí)會直接影響系統(tǒng)的,而Tclk確實(shí)固定的,因此,我們只需要算出最大輸出延時(shí),其實(shí)Tco就已經(jīng)確定了,綜合工具會根據(jù)這個(gè)確定值尋找路徑

  同理,我們根據(jù)靜態(tài)時(shí)序分析的公式算出最小輸出延時(shí)

  即Tco + 外部PCB走線延遲 + 時(shí)鐘偏斜 > Th

  即 Tco > Th - 外部PCB走線延時(shí) + 最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  其中,最小輸出延時(shí) = Th - 外部PCB走線延時(shí) + 最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  即 Tco > 最小輸出延時(shí)

  2、再來看輸入模型

  

?

  輸入模型無非就是跟輸出模型相反罷了,原來FPGA作為輸出,現(xiàn)在作為輸入,還是要考慮我們之前靜態(tài)時(shí)序分析的時(shí)候推出的那兩個(gè)公式

  即 Tclk + 時(shí)鐘偏斜 > Tco + 外部PCB走線延時(shí) + Tsu

  那么Tco + 外部PCB走線延時(shí) + 時(shí)鐘網(wǎng)絡(luò)延時(shí) < Tclk - Tsu,

  小于號左邊就是我們的最大輸入延時(shí) ,這里的Tco就不再是FPGA內(nèi)部的了,而是數(shù)據(jù)經(jīng)過SDRAM的延時(shí)了。Tclk就是FPGA的內(nèi)部時(shí)鐘了,Tsu當(dāng)然也是FPGA的建立時(shí)間。到了這個(gè)地方我就有點(diǎn)不懂了,既然是輸入延時(shí),為什么不把FPGA的建立時(shí)間考慮在內(nèi)呢?要知道我們在推輸出延時(shí)的時(shí)候也是把SDRAM的建立時(shí)間考慮在內(nèi)了啊,為什么這里就不把FPGA的建立時(shí)間考慮在內(nèi)呢?

  我是這么理解的,會不會是因?yàn)槲覀冎恍枰銛?shù)據(jù)到FPGA引腳的延時(shí)就可以了,剩下的路徑,包括數(shù)據(jù)從FPGA引腳到數(shù)據(jù)被鎖存這段時(shí)間,也就是已經(jīng)包括了FPGA的建立時(shí)間在內(nèi)了的緣故,這段時(shí)間是綜合工具根據(jù)我們的輸入延時(shí)來分配路線的。

  這個(gè)問題,希望看到的大神給個(gè)意見吧

  當(dāng)然了,最小輸入延時(shí)也是根據(jù)那個(gè)公式求得

  即Tco + 外部PCB走線延時(shí) +時(shí)鐘網(wǎng)絡(luò)延時(shí) > Th

  即最小輸入延時(shí) > Th

  3、下面我們做一個(gè)總結(jié)

  最大輸出延時(shí) = 外部器件的Tsu + 外部PCB最大延遲 + 最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  最小輸出延時(shí) = 外部器件的Th - 外部最小PCB走線延時(shí) + 最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  最大輸入延時(shí) = 外部器件最大Tco + 外部PCB最大走線延時(shí) + 最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  最小輸入延時(shí) = 外部器件最小Tco + 外部PCB最小走線延時(shí) + 最小時(shí)鐘網(wǎng)絡(luò)延時(shí)

  下面再來解釋一下最大最小問題,看到這大家肯有點(diǎn)看不懂了,剛才還覺得可以,加了一些最大最小就看不懂了,其實(shí)我們要做的輸出,不僅僅是有一個(gè)引腳輸出,拿我們的SDRAM來說,有12根地址線,還有16根數(shù)據(jù)線還有其他的控制信號線要輸出,那么,我們應(yīng)該選其中最長的,或者最短的來考慮,只要最長的或者最短的滿足要求了,其他的自然也就滿足要求了,即我們用最壞的打算來考慮我們的約束路徑。

  還有最大最小時(shí)鐘網(wǎng)絡(luò)延時(shí),由于這里我們只有一跟時(shí)鐘線,就無所謂最大最小了,這么說就是為了規(guī)范

  最大最小外部器件的Tco,數(shù)據(jù)經(jīng)過SDRAM的時(shí)候,并不是時(shí)間都是一樣的,總有些快慢問題,這里我們也取極限,就是數(shù)據(jù)經(jīng)過SDRAM的最大時(shí)間和最小時(shí)間,這個(gè)時(shí)間在datasheet里面是有參數(shù)的

  細(xì)心的朋友可能會發(fā)現(xiàn) 最小輸出延時(shí)計(jì)算的時(shí)候,為什么是減去 最小PCB走線延時(shí)呢,為什么不是最大?為什么不是加上最大時(shí)鐘網(wǎng)絡(luò)延時(shí)呢?為什么不是最小?其實(shí),時(shí)序分析工具分析的時(shí)候是按照一定的公式計(jì)算數(shù)據(jù)到達(dá)時(shí)間和數(shù)據(jù)需要時(shí)間的,這個(gè)公式見下圖

  

?

  在計(jì)算保持時(shí)間余量,數(shù)據(jù)需要時(shí)間的時(shí)候,公式是減去 output minimum delay of pin

  為什么是減去呢,按理說應(yīng)該是加上我們的輸出最小延時(shí)才對,小墨當(dāng)時(shí)也不理解,所以就當(dāng)是記住吧,也就是說

  這里的 output minimum delay of pin = - 輸出最小延時(shí)

  這樣理解的話,那么輸出最小延時(shí)越大,那么output minimum delay of pin 就越小了,也就是為什么是減去最小PCB延時(shí)的原因吧

  后面我們到時(shí)序分析工具里面看時(shí)序報(bào)告圖的時(shí)候就會發(fā)現(xiàn),如果我們約束的最小輸出延時(shí)是負(fù)數(shù)的話,里面顯示的卻是正數(shù),所以,我們就暫時(shí)記住好了,因?yàn)檎娴氖遣缓美斫狻?/p>

  三、參數(shù)計(jì)算

  根據(jù)我們剛才推斷出來的那幾個(gè)公式,我們就可以進(jìn)行參數(shù)計(jì)算了,先來看看我們需要什么參數(shù)

  輸出模型的時(shí)候,我們需要的是SDRAM的建立時(shí)間,保持時(shí)間,外部PCB走線延時(shí),輸入模型的時(shí)候,我們需要的是外部器件的最大最小Tco

  SDRAM的建立保持時(shí)間可以從datasheet里面找到

  

?

  根據(jù)器件型號,我們選擇建立時(shí)間為 1.5 ns ,保持時(shí)間為 0.8ns,外部PCB走線延時(shí)這個(gè)不怎么好算,只能估計(jì)吧,因?yàn)榘遄硬皇俏耶嫷模L度也不知道,根據(jù)經(jīng)驗(yàn),我們知道,信號在PCB上的延時(shí)大概為0.18ns /1000mil,那我就估計(jì)為最大0.3ns,最小0.1好了

  然后是時(shí)鐘網(wǎng)絡(luò)延時(shí),也就是源時(shí)鐘到達(dá)源寄存器 - 到達(dá)目的寄存器的值,由于我們的時(shí)鐘是總PLL發(fā)出的,時(shí)鐘從FPGA管腳輸出后再送給SDRAM,因此這個(gè)值一定是負(fù)值,而且也是時(shí)鐘在PCB上的走線延時(shí),這個(gè)值我們估算為-0.1ns好了,因?yàn)檎娴臎]法算我覺得。

  然后是數(shù)據(jù)經(jīng)過外部器件的最大最小延時(shí),這個(gè)值我們在SDRAM的理論篇里面說了,就是Tac參數(shù)和Toh參數(shù),不懂得朋友可以到前面去補(bǔ)補(bǔ)課,這個(gè)值我們在datasheet里面也找得到

  

?

  所以我們?nèi)∽畲骉co 為5.4ns 最小Tco為2.7ns

  經(jīng)過計(jì)算得我們的約束參數(shù)

  最大輸出延時(shí) =外部器件的Tsu+外部PCB最大延遲+最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  =1.5+0.3-0.1=1.7ns

  最小輸出延時(shí) = 外部器件的Th - 外部最小PCB走線延時(shí) + 最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  = -(0.8 - 0.1 - 0.1 ) = - 0.6ns

  最大輸入延時(shí) = 外部器件最大Tco + 外部PCB最大走線延時(shí) + 最大時(shí)鐘網(wǎng)絡(luò)延時(shí)

  = 5.4 + 0.3 - 0.1=5.6ns

  最小輸入延時(shí) = 外部器件最小Tco + 外部PCB最小走線延時(shí) + 最小時(shí)鐘網(wǎng)絡(luò)延時(shí)

  = 2.7 + 0.1 -0.1 = 2.7ns

  四、全局時(shí)鐘約束

  由于我們的時(shí)鐘是由晶振源傳到PLL,然后再由PLL輸出給SDRAM和FPGA內(nèi)部寄存器的,因此我們需要對輸入的時(shí)鐘進(jìn)行約束,約束其為50M的時(shí)鐘,并對應(yīng)好我們的端口時(shí)鐘clk,即約束我們的輸入時(shí)鐘為50M,并給這個(gè)時(shí)鐘取一個(gè)在時(shí)序分析時(shí)鐘的名字,即sys_clk,關(guān)于timequest的使用,大家還需自行學(xué)習(xí),這里僅僅只是說約束方法

  

?

  而對于PLL輸出時(shí)鐘的約束,我們僅需在.sdc文件相應(yīng)的的位置,手動(dòng)輸入約束即可,僅需要一條語句 ,這條命令輸進(jìn)去以后,時(shí)序分析工具會自動(dòng)的為我們約束好PLL的輸出時(shí)鐘

  

?

  我們可以通過查看時(shí)序報(bào)告,可以看到,我們的時(shí)鐘都跑到了我們約束的條件,如果我們不加這條語句的的話,那么PLL的輸出時(shí)鐘是達(dá)不到這個(gè)要求的,那樣的話,我們的時(shí)鐘都不穩(wěn)定,更別提系統(tǒng)穩(wěn)定性了

  

?

  五、關(guān)于虛擬時(shí)鐘

  上圖中,細(xì)心的朋友可能會看到,第一行有一個(gè)SDRAM_CLK,這個(gè)時(shí)鐘是怎么來的呢?這個(gè)時(shí)鐘,其實(shí)就是我們給外部的芯片模擬了一個(gè)時(shí)鐘,因?yàn)橥獠科骷臅r(shí)鐘是我們PLL生成,送到外部管腳去的,并不是我們FPGA的內(nèi)部時(shí)鐘,既然不是內(nèi)部時(shí)鐘,那么我們就無法對其進(jìn)行約束,我們只能定義這么一個(gè)虛擬的時(shí)鐘,來盡可能模擬SDRAM的工作時(shí)鐘。 例如,輸入的時(shí)候,源寄存器在SDRAM中,目的寄存器在FPGA中,數(shù)據(jù)的傳輸是在SDRAM工作時(shí)鐘下進(jìn)行的,但是時(shí)序分析工具不知道這個(gè)時(shí)鐘,所以我們定義一個(gè)虛擬時(shí)鐘,連接好它的路徑,即從哪輸出,輸?shù)侥模@里的話就是從PLL的clk2輸出,到SDRAM的時(shí)鐘輸入引腳了。因?yàn)檫@里是時(shí)序約束模型為源同步時(shí)序模型,即時(shí)鐘都是由FPGA產(chǎn)生,在不是源同步時(shí)序模型的情況下,就不需要指明虛擬時(shí)鐘的源和目的,只需要指明周期即可。

  

?

  既然是模擬,那我們也應(yīng)該考慮到這個(gè)時(shí)鐘從PLL輸出,到FPGA引腳的這段時(shí)間的延時(shí),我們對其進(jìn)行最大,最小延時(shí)約束

  

?

  同理,我們約束最小值為0ns,這里就不做演示了,方法是一樣的

  六、I/O時(shí)序約束

  由于篇幅所限,這里就不能一點(diǎn)點(diǎn)的做了,只舉個(gè)例子吧,做最大輸入延時(shí)的約束,我們點(diǎn)擊 constraints ———> set input delay

  時(shí)鐘名字我們選的就是我們生成的虛擬時(shí)鐘,為什么呢?因?yàn)槲覀冏龅氖荌O約束,即FPGA和SDRAM互相交換數(shù)據(jù),既然交換數(shù)據(jù)肯定是建立在時(shí)鐘的基礎(chǔ)上的,這個(gè)時(shí)鐘,就是虛擬時(shí)鐘。這個(gè)地方比較難懂了,我理解的也不是太好。畢竟我們是要看得是時(shí)序報(bào)告,時(shí)序報(bào)告就是建立在虛擬時(shí)鐘的基礎(chǔ)上的一個(gè)模擬過程。先理解到這里吧,也不知道該怎么解釋了,還請看到的大神給指點(diǎn)一二吧~

  下面我們做最大輸入延時(shí)的約束,設(shè)置我們最大的輸入延時(shí)為5.4ns

  

?

  設(shè)置輸入路徑,因?yàn)橹挥蠸DRAM_data路徑是雙向的,做輸入的時(shí)候僅考慮這個(gè)路徑即可

  

?

  然后我們再做一個(gè)輸出最大延時(shí)的約束,輸出最大延時(shí)為1.7ns ,輸出路徑包括除了時(shí)鐘和時(shí)鐘有效信號sdram_cke信號外的所有的SDRAM引腳,當(dāng)然也包括sdram_data信號,為什么不包括cke信號呢?因?yàn)閏ke信號自始至終沒有多少次的變化,也就是說對時(shí)序要求不嚴(yán)格,對于這種信號,類似還有片選信號,數(shù)碼管片選,位選等,我們只需對其進(jìn)行false路徑約束即可,即對時(shí)序沒有嚴(yán)格要求的路徑

  

?

  

?

  剩下的路徑我就不再做了,都是一樣的,將所有路徑約束好之后,我們需要開始調(diào)sdram工作時(shí)鐘的相位偏移了

  由于篇幅所限,剩下的內(nèi)容我放到下篇中講,謝謝大家~

fpga相關(guān)文章:fpga是什么


晶振相關(guān)文章:晶振原理


關(guān)鍵詞: FPGA SDRAM

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉