0 引言
器是設計中使用頻率非常高的基本單元之一。盡管目前在大部分設計中還廣泛使用集成鎖相環(如altera的PLL,Xilinx的DLL)來進行的分頻、倍頻以及相移設計,但是,對於時鍾要求不太嚴格的設計,通過自主設計進行時鍾分頻的實現方法仍然非常流行。首先這種方法可以節省鎖相環資源,再者,這種方式隻消耗不多的邏輯單元就可以達到對時鍾操作的目的。
1 整數分頻器的設計
1.1 偶數倍分頻
偶數分頻器的實現非常簡單,通過計數器計數就完全可以實現。如進行N倍偶數分頻,就可以通過由待分頻的時鍾觸發計數器計數,當計數器從0計數到N/2-1時,輸出時鍾進行翻轉,並給計數器一個複位信號,以使下一個時鍾從零開始計數。以此循環,就可以實現任意的偶數分頻。圖1所示是占空比為1:1的36分頻的仿真波形圖。

1.2 奇數倍分頻
奇數倍分頻有兩種實現方法,其中之一完全可以通過計數器來實現,如進行三分頻,就可通過待分頻時鍾上升沿觸發計數器來進行模三計數,當計數器計數到鄰近值時進行兩次翻轉。比如可以在計數器計數到1時,輸出時鍾進行翻轉,計數到2時再次進 行翻轉。這樣,就在計數值鄰近的1和2進行了兩次翻轉。如此便實現了三分頻,其占空比為1/3或2/3。
占空比1/15的15分頻設計的主要代碼如下:
如果要實現占空比為50%的三分頻時鍾,則可通過待分頻時鍾下降沿觸發計數,並以和上升沿同樣的方法計數進行三分頻,然後對下降沿產生的三分頻時鍾和上升沿產生的時鍾進行相或運算。即可得到占空比為50%的三分頻時鍾這是奇數分頻的第三種方法。這種方法可以實現任意的奇數分頻。如將其歸類為一般的方法:對於實現占空比為50%的N倍奇數分頻,首先要進行上升沿觸發以進行模N計數,計數選定到某一個值再進行輸出時鍾翻轉,然後過(N-1)/2再次進行翻轉,就可得到一個占空比非50%的奇數n分頻時鍾。再同時進行下降沿觸發的模N計數,當其到達與上升沿觸發輸出時鍾翻轉選定值相同時,再進行輸出時鍾翻轉,同樣,經過(N-1)/2時,輸出時鍾再次翻轉以生成占空比非50%的奇數n分頻時鍾。將這兩個占空比非50%的n分頻時鍾相或運算,就可以得到占空比為50%的奇數n分頻時鍾。

圖2所示是占空比為1:1的3分頻電路原理圖。圖3為其仿真波形。


2 半整數分頻器設計
進行n+0.5分頻一般需要對輸入時鍾先進行操作。其基本設計思想是:首先進行模n的計數,在計數到n-1時,將輸出時鍾賦為'1',而當回到計數0時,又賦為0,這樣,當計數值為n-1時,輸出時鍾才為1,因此,隻要保持計數值n-1為半個輸入時鍾周期,即可實現n+0.5分頻時鍾。因此,保持n-1為半個時鍾周期即是該設計的關鍵。從中可以發現,因為計數器是通過時鍾上升沿計數,故可在計數為n-1時對計數觸發時鍾進行翻轉,那麼,時鍾的下降沿就變成了上升沿。即在計數值為n-1期間的時鍾下降沿變成了上升沿,也就是說,計數值n-1隻保持了半個時鍾周期。由於時鍾翻轉下降沿變成上升沿,因此,計數值變為0。所以,每產生一個n+0.5分頻時鍾的周期,觸發時鍾都要翻轉一次。圖4給出了通用的半整數分頻器的電路原理圖。

圖5所示是一個分頻係數為2.5的分頻器電路,該電路是用FPGA來設計半整數分頻器的。它由模3計數器、異或門和D觸發器組成。圖6是其仿真波形圖。

3 任意整數帶小數分頻
任意整數帶小數分頻的基本原理是采用脈衝吞吐計數器和鎖相環技術先設計兩個不同分頻比的整數分頻器,然後通過控製單位時間內兩種分頻比出現的不同次數來獲得所需要的小數分頻值。若設計一個分頻係數為10.1的分頻器,即可以將分頻器設計成9次10分頻和1次11分頻,這樣,總的分頻值為:
F=(9×10+1×11)/(9+1)=10.1
從這種實現方法的特點可以看出,由於分頻器的分頻值不斷改變,分頻後得到的信號抖動一般較大。當分頻係數為N-0.5(N為整數)時,可控製扣除脈衝的時間,以使輸出成為一個穩定的脈衝頻率,而不是一次N分頻,一次N-1分頻。一般而言,這種分頻由於分頻輸出的時鍾脈衝抖動很大,故在設計中的使用已經非常少。但是,這也是可以實現的。
4 結束語
利用本文介紹的方法可在對時鍾要求比較嚴格的FPGA係統中,用FPGA內嵌的鎖相環資源來實現分頻。該設計方法簡單方便、節約資源、可移置性強、便於係統升級,因此,在時鍾要求不太嚴格的係統中應用非常廣泛,同時在以後的FPGA設計發展中也有很大的應用空間。