Chinaunix首页 | 论坛 | 博客
  • 博客访问: 132117
  • 博文数量: 24
  • 博客积分: 1961
  • 博客等级: 上尉
  • 技术积分: 310
  • 用 户 组: 普通用户
  • 注册时间: 2010-10-15 20:43
文章分类

全部博文(24)

文章存档

2012年(7)

2011年(11)

2010年(6)

分类:

2010-11-05 22:28:07

module rot(led,rot_a,rot_b,rotary_press,clk,rst
    );
   
output   [7:0]led;
input    rot_a;
input    rot_b;
input    rotary_press;
input    clk;
input    rst;

//internal signals
wire         rot_a_pulse;
wire         rot_b_pulse;
wire         rotary_push_down;
reg     [1:0]rot_a_buffer;
reg     [1:0]rot_b_buffer;
reg     [1:0]rotary_press_buffer;
reg          rot_clk;
reg     [6:0]cnt1;
reg     [5:0]cnt2;
reg          rot_left;
reg          rot_right;
reg     [7:0]led_pattern;
//--module code-----
//------------------

//---generate rot_clk
clk)
  if(rst)
    begin
      cnt1<=7'd0;
    end
  else
    begin
      cnt1<=cnt1+1;
    end
   
clk)
  if(rst)
    begin
      rot_clk<=1'b0;
      cnt2<=6'd0;
    end   
  else
    begin
      if(cnt1==7'b111_1111)
        begin
          rot_clk<=1'b1;
          cnt2<=6'd1;
        end
      else
        begin
          rot_clk<=1'b0;
          cnt2<=cnt2+1;
        end
    end
   
//----  
rot_clk)
  if(rst)
    begin
      rot_a_buffer<=2'b00;
    end
  else
    begin
      rot_a_buffer[0]<=rot_a;
      rot_a_buffer[1]<=rot_a_buffer[0];
    end  
   
rot_clk)
  if(rst)
    begin
            rot_b_buffer<=2'b00;
    end
  else
    begin
      rot_b_buffer[0]<=rot_b;
      rot_b_buffer[1]<=rot_b_buffer[0];
    end 
 
rot_clk)
 if(rst)
    begin
            rotary_press_buffer<=2'b00;
    end
 else
    begin
      rotary_press_buffer[0]<=rotary_press;
      rotary_press_buffer[1]<=rotary_press_buffer[0];
    end 
 
assign  rot_a_pulse=~rot_a_buffer[0]&&rot_a_buffer[1];
assign  rot_b_pulse=~rot_b_buffer[0]&&rot_b_buffer[1];
assign  rotary_push_down=~rotary_press_buffer[0]&&rotary_press_buffer[1];

rot_clk)
  if(rst)
    begin
      rot_left<=1'b0;
      rot_right<=1'b0;
    end
  else
    begin
      if((rot_a_buffer[1]==1'b0)&&(rot_b_pulse==1'b1))
        begin
          rot_left<=1'b1;
        end
      else
        begin
          rot_left<=1'b0;
        end
      if((rot_b_buffer[1]==1'b0)&&(rot_a_pulse==1'b1))
        begin
          rot_right<=1'b1;
        end
      else
        begin
          rot_right<=1'b0;
        end
    end
endmodule
旋转按钮驱动程序,是基于Spartan3E板子实现的......  需要注意的是,去抖电路的实现,这里应用了分段式分频写法,是综合速度更快。
阅读(1010) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~