<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à) > 【從零開(kāi)始走進(jìn)FPGA】非同于MCU的獨立按鍵消抖動(dòng)

【從零開(kāi)始走進(jìn)FPGA】非同于MCU的獨立按鍵消抖動(dòng)

作者: 時(shí)間:2015-03-02 來(lái)源:網(wǎng)絡(luò ) 收藏
編者按: 進(jìn)入電子,無(wú)處不用到按鍵, FPGA中的按鍵消抖動(dòng)更是非同一般,并針對不同情況有相應的對策。

  3. 中的動(dòng)

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

  對于中的消抖動(dòng),很多教科書(shū)上都沒(méi)有講述。但Bingo覺(jué)得這個(gè)很有必要。對于信號穩定性以及準確性分析,按鍵信號必須有一個(gè)穩定的脈沖,不然對系統穩定性有很大的干擾。

  此處Bingo用兩種方法對動(dòng)分析。其中第一種是通過(guò)狀態(tài)機的使用直接移植以上的代碼,這個(gè)思想在FPGA狀態(tài)機中很重要。第二種,通過(guò)循環(huán)n次計數的方法來(lái)確認是否真的被按下,這種方法很實(shí)用在FPGA這種高速并行器件中。

  (1)利用狀態(tài)機移植動(dòng)

  此模塊由Bingo無(wú)數次修改測試最后成型的代碼,在功能上可適配n個(gè)按鍵,在思想上利用單片機采用了單片機消抖動(dòng)的思想。具體代碼實(shí)現過(guò)程請有需要的自行分析,本模塊移植方便,Verilog代碼如下所示:

  /*************************************************

  * Module Name : key_scan_jitter.v

  * Engineer : Crazy Bingo

  * Target Device : EP2C8Q208C8

  * Tool versions : Quartus II 11.0

  * Create Date : 2011-6-26

  * Revision : v1.0

  * Description :

  **************************************************/

  module key_scan_jitter

  #(

  parameter KEY_WIDTH = 2

  )

  (

  input clk,

  input rst_n,

  input [KEY_WIDTH-1:0] key_data,

  output key_flag,

  output reg [KEY_WIDTH-1:0] key_value

  );

  reg [19:0] cnt; //delay_5ms(249999)

  reg [2:0] state;

  //-----------------------------------

  always @(posedge clk or negedge rst_n)

  begin

  if(!rst_n)

  cnt <= 20'd0;

  else

  begin

  cnt <= cnt + 1'b1;

  if(cnt == 20'd249999)

  cnt <= 20'd0;

  end

  end

  //-----------------------------------

  reg key_flag_r;

  reg [KEY_WIDTH-1:0] key_data_r;

  always@(posedge clk or negedge rst_n)

  begin

  if(!rst_n)

  begin

  key_flag_r <= 1'b0;

  key_value <= {KEY_WIDTH{1'b0}};

  end

  else if(cnt == 20'd249999) //Delay_5ms

  begin

  case(state)

  0:

  begin

  if(key_data != {KEY_WIDTH{1'b1}})

  state <= 1;

  else

  state <= 0;

  end

  1:

  begin

  if(key_data != {KEY_WIDTH{1'b1}})

  state <= 2;

  else

  state <= 0;

  end

  2:

  begin

  key_flag_r <= 1'b1;

  key_value <= key_data; //lock the key_value

  state <= 3;

  end

  3:

  begin

  key_flag_r <= 1'b0; //read the key_value

  if(key_data == {KEY_WIDTH{1'b1}})

  state <= 4;

  else

  state <= 3;

  end

  4:

  begin

  if(key_data == {KEY_WIDTH{1'b1}})

  state <= 0;

  else

  state <= 4;

  end

  endcase

  end

  end

  //---------------------------------------

  //Capture the falling endge of the key_flag

  reg key_flag_r0,key_flag_r1;

  always@(posedge clk or negedge rst_n)

  begin

  if(!rst_n)

  begin

  key_flag_r0 <= 0;

  key_flag_r1 <= 0;

  end

  else

  begin

  key_flag_r0 <= key_flag_r;

  key_flag_r1 <= key_flag_r0;

  end

  end

  assign key_flag = key_flag_r1 & ~key_flag_r0;

  endmodule

  信號線(xiàn)說(shuō)明如下:

  clk

  系統最高時(shí)鐘

  rst_n

  系統復位信號

  Key_data

  按鍵信號(可根據需要配置為n位)

  Key_flag

  按鍵確認信號

  Key_vaule

  按鍵返回值

  雷同上述按鍵消抖動(dòng)的狀態(tài),此模塊可以模擬成一下5個(gè)狀態(tài),見(jiàn)state machine:


wps_clip_image-28120

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




關(guān)鍵詞: FPGA MCU 按鍵消抖

評論


相關(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>