新聞中心

        EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 非同于MCU的獨(dú)立按鍵消抖動(dòng)

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

        作者: 時(shí)間:2012-03-08 來源:網(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ù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 涟水县| 平邑县| 遵化市| 青阳县| 城市| 内乡县| 金塔县| 揭阳市| 大同市| 临泉县| 正安县| 清镇市| 城固县| 得荣县| 波密县| 洪雅县| 台中市| 泉州市| 石阡县| 郴州市| 泸州市| 南阳市| 铜鼓县| 温州市| 三江| 达州市| 葫芦岛市| 庄浪县| 石台县| 铜川市| 北宁市| 象州县| 永康市| 崇阳县| 南安市| 淮滨县| 聊城市| 海口市| 宣威市| 沙坪坝区| 石河子市|