標(biāo)題: 發(fā)一個任意數(shù)分頻的程序 [打印本頁]

作者: Mystery0724    時間: 2019-3-28 09:35
標(biāo)題: 發(fā)一個任意數(shù)分頻的程序
本帖最后由 Mystery0724 于 2019-3-28 09:39 編輯

  1. module divide(
  2.                                         clk,
  3.                                         rst_n,
  4.                                         clkout);

  5. input         clk,rst_n;
  6. output        clkout;   

  7. parameter        WIDTH        = 3;         
  8. parameter        N = 5;            

  9. reg         [WIDTH-1:0]        cnt_p,cnt_n;   //cnt_p為上升沿觸發(fā)時的計數(shù)器,cnt_n為下降沿觸發(fā)時的計數(shù)器
  10. reg        clk_p,clk_n;     //clk_p為上升沿觸發(fā)時分頻時鐘,clk_n為下降沿觸發(fā)時分頻時鐘

  11. //上升沿觸發(fā)時計數(shù)器的控制
  12. always @ (posedge clk or negedge rst_n )         
  13. begin
  14.         if(!rst_n)
  15.                 cnt_p<=0;
  16.         else if (cnt_p==(N-1))
  17.                 cnt_p<=0;
  18.         else cnt_p<=cnt_p+1;            
  19. end
  20.                
  21. always @ (posedge clk or negedge rst_n)
  22. begin
  23.         if(!rst_n)
  24.                 clk_p<=0;
  25.         else if (cnt_p<(N>>1))          //N>>1表示右移一位,相當(dāng)于除以2去掉余數(shù)
  26.                 clk_p<=0;
  27.         else
  28.                 clk_p<=1;               //得到的分頻時鐘正周期比負(fù)周期多一個clk時鐘
  29. end

  30.           //下降沿觸發(fā)時計數(shù)器的控制               
  31. always @ (negedge clk or negedge rst_n)
  32.         begin
  33.                 if(!rst_n)
  34.                         cnt_n<=0;
  35.                 else if (cnt_n==(N-1))
  36.                         cnt_n<=0;
  37.                 else cnt_n<=cnt_n+1;
  38.         end

  39.           //下降沿觸發(fā)的分頻時鐘輸出,和clk_p相差半個時鐘
  40. always @ (negedge clk)
  41.         begin
  42.                 if(!rst_n)
  43.                         clk_n<=0;
  44.                 else if (cnt_n<(N>>1))  
  45.                         clk_n<=0;
  46.                 else
  47.                         clk_n<=1;                //得到的分頻時鐘正周期比負(fù)周期多一個clk時鐘
  48.         end

  49.           assign clkout = (N==1)?clk:(N[0])?(clk_p&clk_n):clk_p;      //條件判斷表達(dá)式
  50.                                                                                                                                                                           //當(dāng)N=1時,直接輸出clk
  51.                                                                                                                                                                           //當(dāng)N為偶數(shù)也就是N的最低位為0,N(0)=0,輸出clk_p
  52.                                                                                                                                                                           //當(dāng)N為奇數(shù)也就是N最低位為1,N(0)=1,輸出clk_p&clk_n。正周期多所以是相與
  53. endmodule
復(fù)制代碼



作者: shuijingfeng    時間: 2019-7-25 15:06
記號一下




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1