smart kids

FPGA 下面dac调试

0
阅读(4962)

最近自己做了一套板子,弄了个DAC,一时不知道怎么去调试的好,今天闲来没事,调试了一下,代码一起哈成,无修改。代码也比较简陋,做了一个DAC 的典雅线性变化。这里就直接观察LED 灯的变化,跟PWM 实现的 LED 亮度变化差不多吧!

具体电路见这里:

时序:

这里的时序我分为 CS 拉低,WR拉低和赋值。WR拉高,CS拉高  4个阶段,

代码:

module dac
 (
  sys_clk,reset_b,
  wr,cs,data
 );
 input sys_clk,reset_b;
 output [7:0] data;
 output wr,cs;
 
 reg wr,cs;
 reg adc_clk;
 reg [7:0] data,data_buf;
 reg [2:0] next;
 
 parameter  state1 =3'd0;
 parameter  state2 =3'd1;
 parameter  state3 =3'd2;
 parameter  state4 =3'd3;
 reg[15:0] count;
 always @ (posedge sys_clk)
 begin
  if(!reset_b)
  begin
   count<=16'd0;
   adc_clk<=1'b1;
  end
  else
  if(count==16'd100)
  begin
   count<=16'd0;
   adc_clk<=~adc_clk;
  end
  else count<=count+1'b1;
 end
//=========data buf add=================
 reg[20:0] count_adc;
 always @ (posedge sys_clk)
 begin
  if(!reset_b)
  begin
   count_adc<=21'd0;
   data_buf<=8'b0;
  end
  else
  if(count_adc==21'd50000000)
  begin
   count_adc<=21'd0;
   data_buf<=data_buf+1'b1;
  end
  else count_adc<=count_adc+1'b1;
 end

 

 
 always @ (posedge adc_clk)
 begin
  if(!reset_b)
  begin
   next<=state1;
   cs<=1'b1;
   wr<=1'b1;
  end
  else
  case (next)
  state1 :
   begin
    cs<=1'b0;
    next<=state2;
   end
  state2 :
   begin
    wr<=1'b0;
    data<=data_buf;
    next<=state3;
   end
  state3 :
   begin
    wr<=1'b1;
    next<=state4;
   end
  state4 :
   begin
    cs<=1'b1;
    next<=state1;
   end
  endcase
  
 end
 
 
endmodule