原创 [博客大赛]74HC595-串行并出驱动器

2014-4-25 10:31 2851 15 18 分类: FPGA/CPLD 文集: FPGA编码
1.芯片原理图
74hc595原理图.jpg
2.时序图(Timing diagram)
74hc595时序图.jpg
3.根据时序图编写74hc595的verilog驱动程序
功能:根据输入的8bits数据data_in,通过sclk,sda,slatch来更新74hc595的数据输出。
思路:
(1)用一个状态机,1个状态用于检测data_in数据是否更新,第2个状态用于将data_in数据通过串行端口传送出去;
(2)sclk的时钟不能超过10MHz,因此需要用一个计数器(delay_cnt)来控制sclk的频率;
(3)用一个计数器(bit_cnt)来控制传送的位数(8bit)。
 
//filename : diver_74hc595.v
//Author : Crazy_bingo
//date : 2014.4.22
//function block:
// clk ->|-----|->sclk
// rst_n ->| |->sda
// data_in=>|-----|->slatch
module diver_74hc595(
input wire clk, //50MHz
input wire rst_n,
input wire[7:0] data_in,
 
output wire sclk, //lower than 10MHz
output wire sda,
output wire slatch
);
 
//update output when data_in is update
reg[7:0] data_r = 8'h00;
reg update_flag;
always @(posedge clk or negedge rst_n)
begin
 if(!rst_n)
  begin
  data_r <= 0;
  update_flag <= 1'b1; //when reset, update the dada_r
  end
 else
  begin
  data_r <= data_in;
  update_flag <= (data_in != data_r)? 1'b1 : 1'b0;
  end
end
 
//clk delay for enough setup time and fmax(10MHz)
localparam DELAY_CNT = 3'd7; //This parameter can be changed for different clk.
localparam WAIT_UPDATE = 1'b0;//state code
localparam SHIFT_DATA = 1'b1;//state code
reg [2:0] delay_cnt;
reg shift_state; //led scan state
always@(posedge clk or negedge rst_n)
begin
 if(!rst_n)
  delay_cnt <= 0;
 else if(shift_state == 1'b1)
  delay_cnt <= (delay_cnt == DELAY_CNT) ? 3'd0 : delay_cnt + 1'b1;
 else
  delay_cnt <= 0;
end
 
wire shift_flag = (delay_cnt == DELAY_CNT) ? 1'b1 : 1'b0;
wire shift_clk = (delay_cnt > DELAY_CNT/2) ? 1'b1 : 1'b0;
 
//shift data state-machine
//state code is in the front part
reg[3:0] bit_cnt;
always @(posedge clk or negedge rst_n)
begin
 if(!rst_n)
  begin
  shift_state <= WAIT_UPDATE;
  bit_cnt <= 0;
  end
 else
  begin
  case (shift_state)
  WAIT_UPDATE:
   begin
   bit_cnt <= 0;
   if(update_flag)
    shift_state <= SHIFT_DATA;
   else
    shift_state <= WAIT_UPDATE;
   end
  SHIFT_DATA :
   begin
    if(shift_flag)//every bit_cnt will be last for DELAY_CNT,
       begin //because shift_flag will be '1' for just one clk-cycle
     if(bit_cnt == 4'd8)
      begin
      bit_cnt <= 0;
      shift_state = WAIT_UPDATE; //shift to WAIT_UPDATE after 8 bit transfered
      end
     else
      begin
      bit_cnt <= bit_cnt + 1'b1;
      shift_state = SHIFT_DATA;
      end
     end
    else
     begin
     bit_cnt <= bit_cnt;
     shift_state <= shift_state;
     end
   end
  endcase
  end
end
 
assign sda = (shift_state == SHIFT_DATA && bit_cnt < 4'd8) ? data_in[3'd7-bit_cnt] : 1'b0;
assign sclk = (shift_state == SHIFT_DATA && bit_cnt < 4'd8) ? shift_clk : 1'b0;
assign slatch = (shift_state == SHIFT_DATA && bit_cnt == 4'd8) ? 1'b1 : 1'b0;
 
endmodule
 
PARTNER CONTENT

文章评论3条评论)

登录后参与讨论

用户403664 2014-4-24 09:49

欢迎回来1!

用户658643 2014-4-23 21:22

赞,学习学习。

用户658643 2014-4-23 21:21

赞,学习学习。
相关推荐阅读
用户468654 2014-04-27 19:30
MinGW编译cpp文件
1.下载MinGW:http://ishare.iask.sina.com.cn/f/23746562.html?retcode=0 2.安装MinGW; 3.添加环境变量中的Path值等...
用户468654 2014-04-26 23:21
“mspdb80.dll无法找到”之解决之道
我在电脑是安装了VS2010。在用命令行调用cl.exe来编译cpp文件时遇到如题的问题。最后查了网络资料。解决方法如下: 1>直接从C:\Program Files\Microsoft...
用户468654 2014-04-25 10:31
[博客大赛]按键消抖之终极解决方案
1.按键消抖的原理                  图1.按键抖动示意图 我们平常所用的按键为机械弹性开关,由于触点的弹性作用,按键在闭合时不会马上稳定的接通,而是有...
用户468654 2014-04-23 16:25
【转】FPGA学习的一些误区
作者:某人(摘自网络,不知道作者) 我常年担任多个有关FPGA学习研讨的QQ群管理员,长期以来很多新入群的菜鸟们总是在重复的问一些非常简单但是又让新手困惑不解的问题。作为管理员经常要给这些菜鸟们...
用户468654 2014-04-23 16:13
何為"阻抗匹配"?
  阻抗匹配(Impedance matching)是微波电子学里的一部分,主要用于传输线上,来达至所有高频的微波信号皆能传至负载点的目的,不会有信号反射回来源点,从而提升能源效益。   大体...
EE直播间
更多
我要评论
3
15
关闭 站长推荐上一条 /3 下一条