在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,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首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 非同于MCU的獨(dú)立按鍵消抖動(dòng)

            非同于MCU的獨(dú)立按鍵消抖動(dòng)

            作者: 時(shí)間:2012-03-08 來(lái)源:網(wǎng)絡(luò) 收藏

            module key_scan

            #(

            parameter KEY_WIDTH = 2

            )

            (

            input clk, //50MHz

            input rst_n,

            input [KEY_WIDTH-1:0] key_data,

            output key_flag,

            output reg [KEY_WIDTH-1:0] key_value

            );

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

            //escape the jitters

            reg [19:0] key_cnt; //scan counter

            reg [KEY_WIDTH-1:0] key_data_r;

            always @(posedge clk or negedge rst_n)

            begin

            if(!rst_n)

            begin

            key_data_r = {KEY_WIDTH{1'b1}};

            key_cnt = 0;

            end

            else

            begin

            key_data_r = key_data; //lock the key value

            if((key_data == key_data_r) (key_data != {KEY_WIDTH{1'b1}})) //20ms escape jitter

            begin

            if(key_cnt 20'hfffff)

            key_cnt = key_cnt + 1'b1;

            end

            else key_cnt = 0;

            end

            end

            wire cnt_flag = (key_cnt == 20'hffffe) ? 1'b1 : 1'b0;//!!

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

            //sure the key is pressed

            reg key_flag_r;

            always@(posedge clk or negedge rst_n)

            begin

            if(!rst_n)

            begin

            key_flag_r = 0;

            key_value = 0;

            end

            else if(cnt_flag)

            begin

            key_flag_r = 1;

            key_value = key_data; //locked the data

            end

            else //let go your hand

            key_flag_r = 0; //lock the key_value

            end

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

            //Capture the rising 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


            上一頁(yè) 1 2 3 下一頁(yè)

            評(píng)論


            相關(guān)推薦

            技術(shù)專(zhuān)區(qū)

            關(guān)閉