在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁 > 嵌入式系統(tǒng) > 牛人業(yè)話 > 小梅哥和你一起深入學(xué)習(xí)FPGA之DAC驅(qū)動

            小梅哥和你一起深入學(xué)習(xí)FPGA之DAC驅(qū)動

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

              線性序列機(jī)計數(shù)器Cnt1的控制代碼如下:

            本文引用地址:http://www.biyoush.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;

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

              

             

              圖2 系統(tǒng)狀態(tài)轉(zhuǎn)移圖

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

              以下是代碼片段:

              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個時鐘周期的高脈沖,即可啟動一次轉(zhuǎn)換。同時,在檢測到該脈沖時,模塊內(nèi)部會將數(shù)據(jù)端口Data上的數(shù)據(jù)讀入到內(nèi)部數(shù)據(jù)寄存器中,代碼如下:

              以下是代碼片段:

              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;

              同時,為了產(chǎn)生1MHz的時鐘,系統(tǒng)中使用了一個計數(shù)器Cnt2來專門產(chǎn)生該信號,該計數(shù)器對系統(tǒng)時鐘進(jìn)行計數(shù),如當(dāng)系統(tǒng)時鐘為50M(周期為20ns)時,Cnt2計數(shù)到24,即計數(shù)了500ns,產(chǎn)生一個時鐘周期的標(biāo)志信號,則Cnt1在檢測到這個標(biāo)志信號后,便會自加1,因此,該標(biāo)志信號出現(xiàn)兩次則表明計時1000ns,對應(yīng)時鐘頻率為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;

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

              以下是代碼片段:

              Localparam system_clk = 50_000_000; /*系統(tǒng)時鐘*/

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

              系統(tǒng)時鐘設(shè)置為50M,則計數(shù)最大值為50000000/1000000/2– 1 = 24,當(dāng)系統(tǒng)時鐘改變后,只需要修改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è)計的仿真結(jié)果如下如所示:

              

             

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

              本驅(qū)動的testbench編寫較為簡單,這里只附上對應(yīng)代碼,不做詳細(xì)解釋:

              以下是代碼片段:

              `timescale 1ns/1ns

              module TLC5620_Driver_tb;

              reg Clk;

              reg Rst_n;

              reg Do_DA; /*使能單次轉(zhuǎn)換*/

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

              wire DAC_Dout; /*DAC數(shù)據(jù)線*/

              wire DAC_Clk; /*DAC時鐘線,最高速度1M*/

              wire DAC_LDAC; /**/

              wire DAC_LOAD; /**/

              wire DA_Done; /*單次轉(zhuǎn)換完成標(biāo)志信號*/

              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

              因?yàn)闀r間關(guān)系,這里只開發(fā)了該芯片的驅(qū)動,并用modelsim對該驅(qū)動進(jìn)行了仿真,詳細(xì)的調(diào)試和應(yīng)用,小梅哥將在下一個實(shí)驗(yàn)中介紹。

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


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


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


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

            上一頁 1 2 下一頁

            關(guān)鍵詞: FPGA DAC

            評論


            相關(guān)推薦

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

            關(guān)閉