1. 程式人生 > >FPGA中亞穩態——讓你無處可逃

FPGA中亞穩態——讓你無處可逃

1. 應用背景

1.1         亞穩態發生原因

      在FPGA系統中,如果資料傳輸中不滿足觸發器的Tsu和Th不滿足,或者復位過程中復位訊號的釋放相對於有效時鐘沿的恢復時間(recovery time)不滿足,就可能產生亞穩態,此時觸發器輸出端Q在有效時鐘沿之後比較長的一段時間處於不確定的狀態,在這段時間裡Q端在0和1之間處於振盪狀態,而不是等於資料輸入端D的值。這段時間稱為決斷時間(resolution time)。經過resolution time之後Q端將穩定到0或1上,但是穩定到0或者1,是隨機的,與輸入沒有必然的關係。

1.2         亞穩態發生場合

      只要系統中有非同步元件,亞穩態就是無法避免的,亞穩態主要發生在非同步訊號檢測、跨時鐘域訊號傳輸以及復位電路等常用設計中。

1.3         亞穩態危害

      由於產生亞穩態後,暫存器Q端輸出在穩定下來之前可能是毛刺、振盪、固定的某一電壓值。在訊號傳輸中產生亞穩態就會導致與其相連其他數字部件將其作出不同的判斷,有的判斷到“1”有的判斷到“0”,有的也進入了亞穩態,數字部件就會邏輯混亂。在復位電路中產生亞穩態可能會導致復位失敗。怎麼降低亞穩態發生的概率成了FPGA設計需要重視的一個注意事項。

 

2. 理論分析

2.1         訊號傳輸中的亞穩態

     在同步系統中,輸入訊號總是系統時鐘同步,能夠達到暫存器的時序要求,所以亞穩態不會發生。亞穩態問題通常發生在一些跨時鐘域訊號傳輸以及非同步訊號採集上。

它們發生的原因如下:

(1)在跨時鐘域訊號傳輸時,由於源暫存器時鐘和目的暫存器時鐘相移未知,所以源暫存器資料發出資料,資料可能在任何時間到達非同步時鐘域的目的暫存器,所以無法保證滿足目的暫存器Tsu和Th的要求;

(2)在非同步訊號採集中,由於非同步訊號可以在任意時間點到達目的暫存器,所以也無法保證滿足目的暫存器Tsu和Th的要求;

當資料在目的暫存器Tsu-Th時間視窗發生變化,也即當資料的建立時間或者保持時間不滿足時,就可能發生亞穩態現象。如圖3.1所示。

 

 圖3.1  亞穩態產生示意圖

     由圖可知,當產生亞穩態後Tco時間後會有Tmet(決斷時間)的振盪時間段,當振盪結束回到穩定狀態時為“0”或者“1”,這個是隨機的。因此,會對後續電路判斷造成影響。

2.2         復位電路的亞穩態

2.2.1    非同步復位電路

在復位電路設計中,復位訊號基本都是非同步的,常用非同步復位電路Verilog描述如下:

always @(posedge clk or negedge rst_n)

begin

       if(!rst_n) a <= 1’b0;

       else         a <= b;

end

綜合出來復位電路模型如圖3.2所示:

 

 

圖3.2  非同步復位電路模型

      如圖3.3所示,為復位電路復位時序圖。如果非同步復位訊號的撤銷時間在Trecovery(恢復時間)和Tremoval(移除時間)之內,那勢必造成亞穩態的產生,輸出在時鐘邊沿的Tco後會產生振盪,振盪時間為Tmet(決斷時間),最終穩定到“0”或者“1”,就會可能造成復位失敗。

 

圖3.3  非同步復位時序

2.2.2    同步復位電路的亞穩態

     在復位電路中,由於復位訊號是非同步的,因此,有些設計採用同步復位電路進行復位,並且絕大多數資料對於同步復位電路都認為不會發生亞穩態,其實不然,同步電路也會發生亞穩態,只是機率小於非同步復位電路。

如下面verilog程式碼對同步復位電路的描述。

always @(posedge clk)

begin

       if(!rst_n) a <= 1’b0;

       else         a <= b;

end

綜合出硬體電路如圖3.4所示。

 

圖3.4  同步復位電路

      在此,我們不討論同步復位的消耗資源問題,只討論同步復位的亞穩態產生情況。

      當輸入端Din為高電平,而且復位訊號的撤銷時間在clk的Tsu和Th內時候,亞穩態就隨之產生了。如圖3.5時序所示,當復位撤銷時間在clk的Tsu和Th內,輸入資料為“1”,通過和輸入資料相與後的資料也在clk的Tsu和Th內,因此,勢必會造成類似非同步訊號採集的亞穩態情況。

 

圖3.5  同步復位電路時序圖

2.3         亞穩態產生概率以及串擾概率

      在實際的FPGA電路設計中,常常人們想的是怎麼減少亞穩態對系統的影響,很少有人考慮怎麼才能減少亞穩態發生機率,以及亞穩態串擾的概率問題。

2.3.1    亞穩態發生概率

      由上面分析得知,系統亞穩態發生的都是由於clk的Tsu和Th不滿足,又或者是復位訊號的移除和恢復時間不滿足。常用FPGA器件的Tsu+Th約等於1ns,復位移除和恢復時間相加約等於1ns。

      當非同步訊號不是一組資料,或者訊號量較少,那就需要對非同步訊號進行同步處理,例如對一個非同步脈衝訊號進行採集,只要脈衝訊號變化發生在時鐘Tsu和Th視窗內,那就很可能會產生亞穩態,亞穩態產生的概率大概為:

                                              概率 = (建立時間 + 保持時間)/ 採集時鐘週期                                                                            (公式3-1)

      由公式3-1可以看出,隨著clk頻率的增加,亞穩態發生的機率是增加的。

      例如,為系統採用100M時鐘對一個外部訊號進行採集,採集時鐘週期為10ns,那採集產生亞穩態的概率為:1ns/10ns = 10%

      同理採用300M時鐘對一個外部訊號進行採集,那產生亞穩態的概率為:1ns/3.3ns = 30%

      如果採用三相相位差為120°的時鐘對一個外部訊號進行採集,那產生亞穩態的概率接近90%

     所以在非同步訊號採集過程中,要想減少亞穩態發生的概率:

  (1) 降低系統工作時鐘,增大系統週期,亞穩態概率就會減小;

  (2) 採用工藝更好的FPGA,也就是Tsu和Th時間較小的FPGA器件;

2.3.2    亞穩態的串擾概率

     使用非同步訊號進行使用的時候,好的設計都會對非同步訊號進行同步處理,同步一般採用多級D觸發器級聯處理,如圖3.6所示,採用三級D觸發器對非同步訊號進行同步處理。

 

圖3.6  三級暫存器同步

      這種模型大部分資料都說的是第一級暫存器產生亞穩態後,第二級暫存器穩定輸出概率為90%,第三極暫存器穩定輸出的概率為99%,如果亞穩態跟隨電路一直傳遞下去,那就會另自我修護能力較弱的系統直接崩潰。接下來我們分析這種串擾的概率問題。

     如圖3.7所示為一個正常第一級暫存器發生了亞穩態,第二級、第三極暫存器消除亞穩態時序模型。

 

 

圖3.7 三級暫存器消除亞穩態

     由上圖可以看出,當第一個暫存器發生亞穩態後,經過Tmet的振盪穩定後,第二級暫存器能採集到一個穩定的值。但是為什麼第二級暫存器還是可能會產生亞穩態呢?

     由於振盪時間Tmet是受到很多因素影響的,所以Tmet時間又長有短,所以當Tmet時間長到大於一個採集週期後,那第二級暫存器就會採集到亞穩態。如圖3.8所示。

 

 

圖3.8  二級暫存器亞穩態

      由上圖可知,第二級也是一個亞穩態,所以在這種情況下,亞穩態產生了串擾,從第一級暫存器傳到了第二級暫存器,同樣也可能從第二級暫存器串擾到第三級暫存器。這樣會讓設計邏輯判斷出錯,產生亞穩態傳輸,可能導致系統宕機奔潰。

2.3.3    亞穩態振盪時間Tmet

      亞穩態震盪時間Tmet關係到後級暫存器的採集穩定問題,Tmet影響因素包括:器件的生產工藝、溫度、環境以及暫存器採集到亞穩態離穩定態的時刻等。甚至某些特定條件,如干擾、輻射等都會造成Tmet增長。

3. 應用分析

有亞穩態產生,我們就要對亞穩態進行消除,常用對亞穩態消除有三種方式:

(1)       對非同步訊號進行同步處理;

(2)       採用FIFO對跨時鐘域資料通訊進行緩衝設計;

(3)       對復位電路採用非同步復位、同步釋放方式處理。

3.1.1    對非同步訊號進行同步提取邊沿

在非同步通訊或者跨時鐘域通訊過程中,最常用的就是對非同步訊號進行同步提取邊沿處理。對一個非同步訊號進行提取上升沿通常採用程式清單 4.1所示。

程式清單 4.1 雙極暫存器提取邊沿

input      sig_nsyn;

wire        sig_nsyn_p;

reg[1:0]   sig_nsyn_r;

always @(posedge clk or negedge rst_n)

begin

       if(!rst_n) sig_nsyn_r <= 2’d0;

       else         sig_nsyn_r <= { sig_nsyn_r [0], sig_nsyn };

end

 

assign     sig_nsyn_p = sig_nsyn_r[0] & ~sig_nsyn_r[1];

       這種邊沿提取方式對於一個穩定的系統是不合適的,例如:當第一級暫存器採集到亞穩態,那勢必造成sig_nsyn_p輸出亞穩態,這樣就會對採用sig_nsyn_p的訊號進行判斷的電路造成影響,甚至判斷出錯誤的值。

根據3.3.1小節的亞穩態產生概率,如果在100M時種下那第一級暫存器產生亞穩態的概率約為10%,隨著系統採集頻率升高,那產生亞穩態的概率也會隨之上升。因此,在進行非同步訊號跨頻提取邊沿時候,一般採用多進行一級暫存器消除亞穩態,可能在系統穩定性要求高的情況下,採用更多級暫存器來消除亞穩態,如程式清單 4.2所示,即為採用4級暫存器消除亞穩態,相應的邊沿訊號產生的時間就晚了兩個時鐘週期。

程式清單 4.2 多級暫存器提取邊沿訊號

input      sig_nsyn;

wire        sig_nsyn_p;

reg[3:0]   sig_nsyn_r;

always @(posedge clk or negedge rst_n)

begin

       if(!rst_n) sig_nsyn_r <= 2’d0;

       else         sig_nsyn_r <= { sig_nsyn_r [2::0], sig_nsyn };

end

 

assign     sig_nsyn_p = sig_nsyn_r[2] & ~sig_nsyn_r[3];

3.1.2    FIFO進行非同步跨頻資料處理

當資料流從一個時鐘域到另一個時鐘域的時候,絕大多數情況下都採用FIFO來作為中間緩衝,採用雙時鐘對資料緩衝,就可以避免亞穩態的發生。

3.1.3    非同步復位,同步釋放

對於復位情況下的亞穩態,常常是由於恢復時間和移除時鐘不滿足造成的,因此,最常用的處理方式是採用非同步復位、同步釋放。常用電路模型如所示。採用第二級暫存器輸出作為全域性復位訊號輸出。

程式清單 4.3  非同步復位處理

wire        sys_rst_n;

reg [1:0]  rst_r;

always @(posedge clk or negedge rst_n)

begin

       if(!rst_n) rst_r <= 2’d0;

       else         rst_r <= {rst_r[0], 1’b1};

end

assign     sys_rst_n = rst_r[1];

通過上面三種方式處理非同步訊號、非同步資料、以及非同步復位可有效的提高系統的穩定性。減少亞穩態的產生。

1.1         亞穩態發生原因

      在FPGA系統中,如果資料傳輸中不滿足觸發器的Tsu和Th不滿足,或者復位過程中復位訊號的釋放相對於有效時鐘沿的恢復時間(recovery time)不滿足,就可能產生亞穩態,此時觸發器輸出端Q在有效時鐘沿之後比較長的一段時間處於不確定的狀態,在這段時間裡Q端在0和1之間處於振盪狀態,而不是等於資料輸入端D的值。這段時間稱為決斷時間(resolution time)。經過resolution time之後Q端將穩定到0或1上,但是穩定到0或者1,是隨機的,與輸入沒有必然的關係。

1.2         亞穩態發生場合

      只要系統中有非同步元件,亞穩態就是無法避免的,亞穩態主要發生在非同步訊號檢測、跨時鐘域訊號傳輸以及復位電路等常用設計中。

1.3         亞穩態危害

      由於產生亞穩態後,暫存器Q端輸出在穩定下來之前可能是毛刺、振盪、固定的某一電壓值。在訊號傳輸中產生亞穩態就會導致與其相連其他數字部件將其作出不同的判斷,有的判斷到“1”有的判斷到“0”,有的也進入了亞穩態,數字部件就會邏輯混亂。在復位電路中產生亞穩態可能會導致復位失敗。怎麼降低亞穩態發生的概率成了FPGA設計需要重視的一個注意事項。

 

2. 理論分析

2.1         訊號傳輸中的亞穩態

     在同步系統中,輸入訊號總是系統時鐘同步,能夠達到暫存器的時序要求,所以亞穩態不會發生。亞穩態問題通常發生在一些跨時鐘域訊號傳輸以及非同步訊號採集上。

它們發生的原因如下:

(1)在跨時鐘域訊號傳輸時,由於源暫存器時鐘和目的暫存器時鐘相移未知,所以源暫存器資料發出資料,資料可能在任何時間到達非同步時鐘域的目的暫存器,所以無法保證滿足目的暫存器Tsu和Th的要求;

(2)在非同步訊號採集中,由於非同步訊號可以在任意時間點到達目的暫存器,所以也無法保證滿足目的暫存器Tsu和Th的要求;

當資料在目的暫存器Tsu-Th時間視窗發生變化,也即當資料的建立時間或者保持時間不滿足時,就可能發生亞穩態現象。如圖3.1所示。

 

 圖3.1  亞穩態產生示意圖

     由圖可知,當產生亞穩態後Tco時間後會有Tmet(決斷時間)的振盪時間段,當振盪結束回到穩定狀態時為“0”或者“1”,這個是隨機的。因此,會對後續電路判斷造成影響。

2.2         復位電路的亞穩態

2.2.1    非同步復位電路

在復位電路設計中,復位訊號基本都是非同步的,常用非同步復位電路Verilog描述如下:

always @(posedge clk or negedge rst_n)

begin

       if(!rst_n) a <= 1’b0;

       else         a <= b;

end

綜合出來復位電路模型如圖3.2所示:

 

 

圖3.2  非同步復位電路模型

      如圖3.3所示,為復位電路復位時序圖。如果非同步復位訊號的撤銷時間在Trecovery(恢復時間)和Tremoval(移除時間)之內,那勢必造成亞穩態的產生,輸出在時鐘邊沿的Tco後會產生振盪,振盪時間為Tmet(決斷時間),最終穩定到“0”或者“1”,就會可能造成復位失敗。

 

圖3.3  非同步復位時序

2.2.2    同步復位電路的亞穩態

     在復位電路中,由於復位訊號是非同步的,因此,有些設計採用同步復位電路進行復位,並且絕大多數資料對於同步復位電路都認為不會發生亞穩態,其實不然,同步電路也會發生亞穩態,只是機率小於非同步復位電路。

如下面verilog程式碼對同步復位電路的描述。

always @(posedge clk)

begin

       if(!rst_n) a <= 1’b0;

       else         a <= b;

end

綜合出硬體電路如圖3.4所示。

 

圖3.4  同步復位電路

      在此,我們不討論同步復位的消耗資源問題,只討論同步復位的亞穩態產生情況。

      當輸入端Din為高電平,而且復位訊號的撤銷時間在clk的Tsu和Th內時候,亞穩態就隨之產生了。如圖3.5時序所示,當復位撤銷時間在clk的Tsu和Th內,輸入資料為“1”,通過和輸入資料相與後的資料也在clk的Tsu和Th內,因此,勢必會造成類似非同步訊號採集的亞穩態情況。

 

圖3.5  同步復位電路時序圖

2.3         亞穩態產生概率以及串擾概率

      在實際的FPGA電路設計中,常常人們想的是怎麼減少亞穩態對系統的影響,很少有人考慮怎麼才能減少亞穩態發生機率,以及亞穩態串擾的概率問題。

2.3.1    亞穩態發生概率

      由上面分析得知,系統亞穩態發生的都是由於clk的Tsu和Th不滿足,又或者是復位訊號的移除和恢復時間不滿足。常用FPGA器件的Tsu+Th約等於1ns,復位移除和恢復時間相加約等於1ns。

      當非同步訊號不是一組資料,或者訊號量較少,那就需要對非同步訊號進行同步處理,例如對一個非同步脈衝訊號進行採集,只要脈衝訊號變化發生在時鐘Tsu和Th視窗內,那就很可能會產生亞穩態,亞穩態產生的概率大概為:

                                              概率 = (建立時間 + 保持時間)/ 採集時鐘週期                                                                            (公式3-1)

      由公式3-1可以看出,隨著clk頻率的增加,亞穩態發生的機率是增加的。

      例如,為系統採用100M時鐘對一個外部訊號進行採集,採集時鐘週期為10ns,那採集產生亞穩態的概率為:1ns/10ns = 10%

      同理採用300M時鐘對一個外部訊號進行採集,那產生亞穩態的概率為:1ns/3.3ns = 30%

      如果採用三相相位差為120°的時鐘對一個外部訊號進行採集,那產生亞穩態的概率接近90%

     所以在非同步訊號採集過程中,要想減少亞穩態發生的概率:

  (1) 降低系統工作時鐘,增大系統週期,亞穩態概率就會減小;

  (2) 採用工藝更好的FPGA,也就是Tsu和Th時間較小的FPGA器件;

2.3.2    亞穩態的串擾概率

     使用非同步訊號進行使用的時候,好的設計都會對非同步訊號進行同步處理,同步一般採用多級D觸發器級聯處理,如圖3.6所示,採用三級D觸發器對非同步訊號進行同步處理。

 

圖3.6  三級暫存器同步

      這種模型大部分資料都說的是第一級暫存器產生亞穩態後,第二級暫存器穩定輸出概率為90%,第三極暫存器穩定輸出的概率為99%,如果亞穩態跟隨電路一直傳遞下去,那就會另自我修護能力較弱的系統直接崩潰。接下來我們分析這種串擾的概率問題。

     如圖3.7所示為一個正常第一級暫存器發生了亞穩態,第二級、第三極暫存器消除亞穩態時序模型。

 

 

圖3.7 三級暫存器消除亞穩態

     由上圖可以看出,當第一個暫存器發生亞穩態後,經過Tmet的振盪穩定後,第二級暫存器能採集到一個穩定的值。但是為什麼第二級暫存器還是可能會產生亞穩態呢?

     由於振盪時間Tmet是受到很多因素影響的,所以Tmet時間又長有短,所以當Tmet時間長到大於一個採集週期後,那第二級暫存器就會採集到亞穩態。如圖3.8所示。

 

 

圖3.8  二級暫存器亞穩態

      由上圖可知,第二級也是一個亞穩態,所以在這種情況下,亞穩態產生了串擾,從第一級暫存器傳到了第二級暫存器,同樣也可能從第二級暫存器串擾到第三級暫存器。這樣會讓設計邏輯判斷出錯,產生亞穩態傳輸,可能導致系統宕機奔潰。

2.3.3    亞穩態振盪時間Tmet

      亞穩態震盪時間Tmet關係到後級暫存器的採集穩定問題,Tmet影響因素包括:器件的生產工藝、溫度、環境以及暫存器採集到亞穩態離穩定態的時刻等。甚至某些特定條件,如干擾、輻射等都會造成Tmet增長。

3. 應用分析

有亞穩態產生,我們就要對亞穩態進行消除,常用對亞穩態消除有三種方式:

(1)       對非同步訊號進行同步處理;

(2)       採用FIFO對跨時鐘域資料通訊進行緩衝設計;

(3)       對復位電路採用非同步復位、同步釋放方式處理。

3.1.1    對非同步訊號進行同步提取邊沿

在非同步通訊或者跨時鐘域通訊過程中,最常用的就是對非同步訊號進行同步提取邊沿處理。對一個非同步訊號進行提取上升沿通常採用程式清單 4.1所示。

程式清單 4.1 雙極暫存器提取邊沿

input      sig_nsyn;

wire        sig_nsyn_p;

reg[1:0]   sig_nsyn_r;

always @(posedge clk or negedge rst_n)

begin

       if(!rst_n) sig_nsyn_r <= 2’d0;

       else         sig_nsyn_r <= { sig_nsyn_r [0], sig_nsyn };

end

 

assign     sig_nsyn_p = sig_nsyn_r[0] & ~sig_nsyn_r[1];

       這種邊沿提取方式對於一個穩定的系統是不合適的,例如:當第一級暫存器採集到亞穩態,那勢必造成sig_nsyn_p輸出亞穩態,這樣就會對採用sig_nsyn_p的訊號進行判斷的電路造成影響,甚至判斷出錯誤的值。

根據3.3.1小節的亞穩態產生概率,如果在100M時種下那第一級暫存器產生亞穩態的概率約為10%,隨著系統採集頻率升高,那產生亞穩態的概率也會隨之上升。因此,在進行非同步訊號跨頻提取邊沿時候,一般採用多進行一級暫存器消除亞穩態,可能在系統穩定性要求高的情況下,採用更多級暫存器來消除亞穩態,如程式清單 4.2所示,即為採用4級暫存器消除亞穩態,相應的邊沿訊號產生的時間就晚了兩個時鐘週期。

程式清單 4.2 多級暫存器提取邊沿訊號

input      sig_nsyn;

wire        sig_nsyn_p;

reg[3:0]   sig_nsyn_r;

always @(posedge clk or negedge rst_n)

begin

       if(!rst_n) sig_nsyn_r <= 2’d0;

       else         sig_nsyn_r <= { sig_nsyn_r [2::0], sig_nsyn };

end

 

assign     sig_nsyn_p = sig_nsyn_r[2] & ~sig_nsyn_r[3];

3.1.2    FIFO進行非同步跨頻資料處理

當資料流從一個時鐘域到另一個時鐘域的時候,絕大多數情況下都採用FIFO來作為中間緩衝,採用雙時鐘對資料緩衝,就可以避免亞穩態的發生。

3.1.3    非同步復位,同步釋放

對於復位情況下的亞穩態,常常是由於恢復時間和移除時鐘不滿足造成的,因此,最常用的處理方式是採用非同步復位、同步釋放。常用電路模型如所示。採用第二級暫存器輸出作為全域性復位訊號輸出。

程式清單 4.3  非同步復位處理

wire        sys_rst_n;

reg [1:0]  rst_r;

always @(posedge clk or negedge rst_n)

begin

       if(!rst_n) rst_r <= 2’d0;

       else         rst_r <= {rst_r[0], 1’b1};

end

assign     sys_rst_n = rst_r[1];

通過上面三種方式處理非同步訊號、非同步資料、以及非同步復位可有效的提高系統的穩定性。減少亞穩態的產生。