<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 牛人業(yè)話(huà) > 小梅哥和你一起深入學(xué)習FPGA之DAC驅動(dòng)

小梅哥和你一起深入學(xué)習FPGA之DAC驅動(dòng)

作者: 時(shí)間:2015-08-05 來(lái)源:網(wǎng)絡(luò ) 收藏

  線(xiàn)性序列機計數器Cnt1的控制代碼如下:

本文引用地址:http://dyxdggzs.com/article/278347.htm

  以下是代碼片段:

  always @(posedge Clk or negedge Rst_n)

  if(!Rst_n)

  Cnt1 <= 5'd0;

  else if(Cnt_State == DO_CNT)

  begin

  if(Cnt1 == 5'd25)

  Cnt1 <= 5'd0;

  else if(Cnt2 == Cnt2_Top)

  Cnt1 <= Cnt1 + 1'b1;

  else

  Cnt1 <= Cnt1;

  end

  else

  Cnt1 <= 5'd0;

  其中,涉及到了兩個(gè)狀態(tài),當Cnt_State = 0時(shí),表示沒(méi)有轉換請求,即系統處于空閑狀態(tài),不工作,當外部有轉換請求時(shí),則系統進(jìn)入轉換狀態(tài),每當計數使能信號到來(lái)時(shí),Cnt1自加一,當Cnt1=25后,表明一次轉換完成,將計數器清零,同時(shí)狀態(tài)跳回空閑態(tài),等待下一次使能信號的到來(lái)。具體的狀態(tài)轉移圖如下所示:

  

 

  圖2 系統狀態(tài)轉移圖

  該狀態(tài)機的代碼對應如下:

  以下是代碼片段:

  always @(posedge Clk or negedge Rst_n)

  if(!Rst_n)

  Cnt_State <= IDEL;

  else

  begin

  case(Cnt_State)

  IDEL:

  if(Do_DA)

  Cnt_State <= DO_CNT;

  else

  Cnt_State <= IDEL;

  DO_CNT:

  if(Cnt1 == 5'd25)

  Cnt_State <= IDEL;

  else

  Cnt_State <= DO_CNT;

  default:;

  endcase

  end

  因此,我們,只需要將Do_DA給出1個(gè)時(shí)鐘周期的高脈沖,即可啟動(dòng)一次轉換。同時(shí),在檢測到該脈沖時(shí),模塊內部會(huì )將數據端口Data上的數據讀入到內部數據寄存器中,代碼如下:

  以下是代碼片段:

  always@(posedge Clk or negedge Rst_n)

  if(!Rst_n)

  Data_r <= 10'd0;

  else if(Do_DA)

  Data_r <= Data;

  else

  Data_r <= Data_r;

  同時(shí),為了產(chǎn)生1MHz的時(shí)鐘,系統中使用了一個(gè)計數器Cnt2來(lái)專(zhuān)門(mén)產(chǎn)生該信號,該計數器對系統時(shí)鐘進(jìn)行計數,如當系統時(shí)鐘為50M(周期為20ns)時(shí),Cnt2計數到24,即計數了500ns,產(chǎn)生一個(gè)時(shí)鐘周期的標志信號,則Cnt1在檢測到這個(gè)標志信號后,便會(huì )自加1,因此,該標志信號出現兩次則表明計時(shí)1000ns,對應時(shí)鐘頻率為1Mhz,即芯片數字接口的時(shí)鐘頻率。該部分代碼如下:

  以下是代碼片段:

  always @ (posedge Clk or negedge Rst_n)

  if(!Rst_n)

  Cnt2 <= 5'd0;

  else if(Cnt_State == DO_CNT)

  begin

  if(Cnt2 == Cnt2_Top)

  Cnt2 <= 5'd0;

  else

  Cnt2 <= Cnt2 + 1'b1;

  end

  else

  Cnt2 <= 5'd0;

  為了兼容不同的系統時(shí)鐘,這里采用參數化定制,得出對應的計數最大值,具體代碼如下:

  以下是代碼片段:

  Localparam system_clk = 50_000_000; /*系統時(shí)鐘*/

  Localparam Cnt2_Top = system_clk / 1_000_000 / 2 - 1; /*500ns技術(shù)器計數最大值*/

  系統時(shí)鐘設置為50M,則計數最大值為50000000/1000000/2– 1 = 24,當系統時(shí)鐘改變后,只需要修改system_clk的值,即可保證Cnt2計數一次的時(shí)間為500ns。

  最后,附上主序列中的操作代碼:

  以下是代碼片段:

  always@(posedge Clk or negedge Rst_n)

  if(!Rst_n)

  begin

  _Dout <= 1;

  DAC_Clk <= 0;

  DAC_LOAD <= 1;

  DAC_LDAC <= 1;

  DA_Done <= 1;

  end

  else

  begin

  case(Cnt1)

  0:

  begin

  DAC_Dout <= 1;

  DAC_Clk <= 0;

  DAC_LOAD <= 1;

  DAC_LDAC <= 1;

  DA_Done <= 1;

  end

  1:begin DAC_Dout <= Data_r[10]; DAC_Clk <= 1;DA_Done <= 0;end

  2:DAC_Clk <= 0;

  3:begin DAC_Dout <= Data_r[9]; DAC_Clk <= 1;end

  4:DAC_Clk <= 0;

  5:begin DAC_Dout <= Data_r[8]; DAC_Clk <= 1;end

  6:DAC_Clk <= 0;

  7:begin DAC_Dout <= Data_r[7]; DAC_Clk <= 1;end

  8:DAC_Clk <= 0;

  9:begin DAC_Dout <= Data_r[6]; DAC_Clk <= 1;end

  10:DAC_Clk <= 0;

  11:begin DAC_Dout <= Data_r[5]; DAC_Clk <= 1;end

  12:DAC_Clk <= 0;

  13:begin DAC_Dout <= Data_r[4]; DAC_Clk <= 1;end

  14:DAC_Clk <= 0;

  15:begin DAC_Dout <= Data_r[3]; DAC_Clk <= 1;end

  16:DAC_Clk <= 0;

  17:begin DAC_Dout <= Data_r[2]; DAC_Clk <= 1;end

  18:DAC_Clk <= 0;

  19:begin DAC_Dout <= Data_r[1]; DAC_Clk <= 1;end

  20:DAC_Clk <= 0;

  21:begin DAC_Dout <= Data_r[0]; DAC_Clk <= 1;end

  22:DAC_Clk <= 0;

  23:DAC_LOAD <= 0;

  24:begin DAC_LOAD <= 1; DAC_LDAC <= 0; end

  25:begin DAC_LDAC <= 1; DA_Done <= 1; end

  default:;

  endcase

  end

  該設計的仿真結果如下如所示:

  

 

  由該仿真結果可知,時(shí)鐘頻率為1MHz,滿(mǎn)足芯片工作要求,其它時(shí)序均與手冊給出的時(shí)序保持一致。為了設計簡(jiǎn)潔,這里將LOAD和LDAC的低電平脈沖時(shí)間都設置為了500ns,而非最小時(shí)間250ns,這里主要是為了方便序列機的設計。當然,如此設計在一定程度上會(huì )影響DAC 的轉換速率,不過(guò)在大多數應用場(chǎng)合已經(jīng)足夠,如需更加高效的設計,只需要對代碼稍加修改即可。

  本驅動(dòng)的testbench編寫(xiě)較為簡(jiǎn)單,這里只附上對應代碼,不做詳細解釋?zhuān)?/p>

  以下是代碼片段:

  `timescale 1ns/1ns

  module TLC5620_Driver_tb;

  reg Clk;

  reg Rst_n;

  reg Do_DA; /*使能單次轉換*/

  reg [10:0]Data;/*{Addr1,Addr0,Range,Data_bit[7:0]}*/

  wire DAC_Dout; /*DAC數據線(xiàn)*/

  wire DAC_Clk; /*DAC時(shí)鐘線(xiàn),最高速度1M*/

  wire DAC_LDAC; /**/

  wire DAC_LOAD; /**/

  wire DA_Done; /*單次轉換完成標志信號*/

  TLC5620_Driver u1(

  .Clk(Clk),

  .Rst_n(Rst_n),

  .Do_DA(Do_DA),

  .Data(Data),

  .DAC_Dout(DAC_Dout),

  .DAC_Clk(DAC_Clk),

  .DAC_LDAC(DAC_LDAC),

  .DAC_LOAD(DAC_LOAD),

  .DA_Done(DA_Done)

  );

  initial begin

  Clk = 1;

  Rst_n = 0;

  Do_DA = 0;

  Data = 11'd0;

  #200;

  Rst_n = 1;

  #400;

  Data = 11'b110_1011_1001;

  Do_DA = 1;

  @(posedge DA_Done)

  Data = 11'b110_0000_1111;

  #20

  Do_DA = 1;

  #20;

  Do_DA = 0;

  @(posedge DA_Done)

  Data = 11'b110_1111_0000;

  #20

  Do_DA = 1;

  #20;

  Do_DA = 0;

  @(posedge DA_Done)

  #400;

  $stop;

  end

  always #10 Clk = ~Clk;

  endmodule

  因為時(shí)間關(guān)系,這里只開(kāi)發(fā)了該芯片的驅動(dòng),并用modelsim對該驅動(dòng)進(jìn)行了仿真,詳細的調試和應用,小梅哥將在下一個(gè)實(shí)驗中介紹。

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


路由器相關(guān)文章:路由器工作原理


路由器相關(guān)文章:路由器工作原理


塵埃粒子計數器相關(guān)文章:塵埃粒子計數器原理

上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: FPGA DAC

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>