一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

通過(guò)狀態(tài)機(jī)的使用直接移植MCU代碼的兩種方法

lhl545545 ? 來(lái)源:電子工程技術(shù) ? 作者:電子工程技術(shù) ? 2020-06-11 16:10 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

簡(jiǎn)單的說(shuō),進(jìn)入了電子,不管是學(xué)純模擬,還是學(xué)單片機(jī),DSP、ARM處理器,或者是我們的FPGA,一般沒(méi)有不用到按鍵的地方。按鍵:人機(jī)交互控制,主要用于對(duì)系統(tǒng)的控制,信號(hào)的釋放等。因此在這里,F(xiàn)PGA上應(yīng)用的按鍵消抖動(dòng),也不得不講!

一、為什么要消抖動(dòng)

在按鍵被按下的短暫一瞬間,由于硬件上的抖動(dòng),往往會(huì)產(chǎn)生幾毫秒的抖動(dòng),在這時(shí)候若采集信號(hào),勢(shì)必導(dǎo)致誤操作,甚至系統(tǒng)崩潰;同樣,在釋放按鍵的那一刻,硬件上會(huì)相應(yīng)的產(chǎn)生抖動(dòng),會(huì)產(chǎn)生同樣的后果。因此,在模擬或者數(shù)字電路中,我們要避免在最不穩(wěn)定的時(shí)候采集信號(hào),進(jìn)行操作。

對(duì)此一般產(chǎn)用消抖動(dòng)的原理。一般可分為以下幾種:

(1)延時(shí)

(2)N次低電平計(jì)數(shù)

(3)低通濾波

在數(shù)字電路中,一般產(chǎn)用(1)(2)種方法。后文中將詳細(xì)介紹。

二、各種消抖動(dòng)

1. 模擬電路按鍵消抖動(dòng)

對(duì)于模擬電路中,一般消抖動(dòng)用的是電容消抖動(dòng)或者施密特觸發(fā)等電路,再次不做具體介紹。

通過(guò)狀態(tài)機(jī)的使用直接移植MCU代碼的兩種方法

2. 單片機(jī)中按鍵消抖動(dòng)

對(duì)于單片機(jī)中的按鍵消抖動(dòng),本節(jié)Bingo根據(jù)自己當(dāng)年寫(xiě)過(guò)的單片機(jī)其中的一個(gè)代碼來(lái)講解,代碼如下所示:

unsigned char key_sCAN(void)

{

if(key == 0) //檢測(cè)到被按下

{

delay(5); //延時(shí)5ms,消抖

if(key != 0)

retrurn 0; //是抖動(dòng),返回退出

while(!key1); // 確認(rèn)被按下,等下釋放

delay(5); //延時(shí)5ms,消抖

while(!key1); //確認(rèn)被釋放

return 1; //返回按下信號(hào)

}

return 0; //沒(méi)信號(hào)

}

針對(duì)以上代碼,消抖動(dòng)的順序如下所示:

(1)檢測(cè)到信號(hào)

(2)延時(shí)5ms,消抖動(dòng)

(3)繼續(xù)檢測(cè)信號(hào),確認(rèn)是否被按下

a) 是,則開(kāi)始等待釋放

b) 否,則返回0,退出

(4)延時(shí)5ms,消抖動(dòng)

(5)確認(rèn),返回按下信號(hào),退出

當(dāng)然在單片機(jī)中也可以循環(huán)計(jì)數(shù)來(lái)確認(rèn)是否被按下。Bingo認(rèn)為如此,太耗MCU資源,因此再次不做講述。

3. FPGA中的按鍵消抖動(dòng)

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

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

(1)利用狀態(tài)機(jī)移植MCU按鍵消抖動(dòng)

此模塊由Bingo無(wú)數(shù)次修改測(cè)試最后成型的代碼,在功能上可適配n個(gè)按鍵,在思想上利用單片機(jī)采用了單片機(jī)消抖動(dòng)的思想。具體代碼實(shí)現(xiàn)過(guò)程請(qǐng)有需要的自行分析,本模塊移植方便,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)
責(zé)任編輯:pj

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 單片機(jī)
    +關(guān)注

    關(guān)注

    6067

    文章

    44992

    瀏覽量

    650564
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17984

    瀏覽量

    367061
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4900

    瀏覽量

    70756
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    請(qǐng)問(wèn)如何在FX10上使用GPIF III狀態(tài)機(jī) *.h 文件?

    LVCMOS 2 位 SlaveFIFO GPIF III 狀態(tài)機(jī)的演示中有一個(gè) cy_gpif_header_lvcmos.h 文件。 我想知道如何使用.h文件,只需放入.h文件放入 FX10 項(xiàng)目? 您有它的用戶指南文檔嗎?
    發(fā)表于 07-16 08:17

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)之八:PCIe初始化狀態(tài)機(jī)設(shè)計(jì)

    獲取配置空間的Header Type字段,其中當(dāng)該字段第8位值為1時(shí),表示設(shè)備為多功能設(shè)備,而NoP邏輯加速引擎當(dāng)前并不支持多功能設(shè)備,因此狀態(tài)機(jī)跳轉(zhuǎn)到ERROR狀態(tài),并設(shè)置錯(cuò)誤代碼寄存器表示檢測(cè)
    發(fā)表于 07-05 22:00

    機(jī)智云配網(wǎng)教程第三期:?jiǎn)纹?b class='flag-5'>機(jī)代碼移植實(shí)戰(zhàn)

    前言本篇文章將分享單片機(jī)移植的經(jīng)驗(yàn)??梢韵螺d并按步驟移植,也可以直接使用已移植好的工程文件。文中將介紹我在
    的頭像 發(fā)表于 07-01 17:32 ?172次閱讀
    機(jī)智云配網(wǎng)教程第三期:?jiǎn)纹?b class='flag-5'>機(jī)</b><b class='flag-5'>代碼</b><b class='flag-5'>移植</b>實(shí)戰(zhàn)

    六相永磁同步電機(jī)串聯(lián)系統(tǒng)控制的兩種方法分析研究

    /simulink環(huán)境下,分別用這兩種方法對(duì)臺(tái)電機(jī)串聯(lián)系統(tǒng)的運(yùn)行特性進(jìn)行仿真研究。當(dāng)其中一臺(tái)電機(jī)轉(zhuǎn)速、負(fù)載變化時(shí),分析兩種方法下另外一臺(tái)電機(jī)獨(dú)立運(yùn)行的情況,臉證分析這兩種方法的可行性
    發(fā)表于 06-10 13:09

    STM32與機(jī)智云連接實(shí)現(xiàn)步驟與技巧(下篇):機(jī)智云代碼移植與優(yōu)化

    機(jī)智云SDK,集成API,實(shí)現(xiàn)數(shù)據(jù)傳輸和設(shè)備狀態(tài)同步,并分享移植過(guò)程中的常見(jiàn)問(wèn)題及解決方法,幫助開(kāi)發(fā)者順利實(shí)現(xiàn)云端連接。機(jī)智云相關(guān)代碼開(kāi)始移植
    的頭像 發(fā)表于 05-23 18:10 ?261次閱讀
    STM32與機(jī)智云連接實(shí)現(xiàn)步驟與技巧(下篇):機(jī)智云<b class='flag-5'>代碼</b><b class='flag-5'>移植</b>與優(yōu)化

    有可能在 FX3 GPIF2 中創(chuàng)建個(gè)獨(dú)立的狀態(tài)機(jī)嗎?

    我想,如果我想通過(guò) FX3 GPIF2 創(chuàng)建個(gè)獨(dú)立的傳輸流接口,我需要在 GPIF2 設(shè)計(jì)器中創(chuàng)建個(gè)獨(dú)立的狀態(tài)機(jī),我是否有可能在 GPIF2 設(shè)計(jì)器中創(chuàng)建
    發(fā)表于 05-20 06:14

    求助,關(guān)于srammaster.cydsn中狀態(tài)機(jī)的問(wèn)題求解

    晚上好。 我目前正在學(xué)習(xí) GPIF II。 查看..EZ-USB FX3 SDK1.3firmwaregpif_examplescyfxsrammastersrammaster.cydsn中的狀態(tài)機(jī),有狀態(tài)START和START1。 這意味著什么?
    發(fā)表于 05-12 06:20

    Simulink中的狀態(tài)機(jī)建模方法 Simulink數(shù)據(jù)可視化與分析功能

    1. Simulink中的狀態(tài)機(jī)建模方法 1.1 理解狀態(tài)機(jī)的基本概念 在開(kāi)始建模之前,了解狀態(tài)機(jī)的基本概念是必要的。狀態(tài)機(jī)由以下幾個(gè)部分組
    的頭像 發(fā)表于 12-12 09:27 ?3009次閱讀

    放大電路的基本分析方法有哪兩種

    放大電路是電子學(xué)中的基礎(chǔ)組成部分,用于增強(qiáng)信號(hào)的幅度而不改變其基本特性。在電子工程中,放大電路的設(shè)計(jì)和分析是至關(guān)重要的。放大電路的基本分析方法主要有兩種:直流分析和交流分析。 直流分析 直流分析
    的頭像 發(fā)表于 09-23 10:40 ?1206次閱讀

    直接電流測(cè)量與電磁感應(yīng)電流測(cè)量的區(qū)別

    在電子工程和電氣領(lǐng)域,測(cè)量電流是一項(xiàng)基本且關(guān)鍵的任務(wù)。電流測(cè)量可以通過(guò)兩種主要方法實(shí)現(xiàn):直接電流測(cè)量和電磁感應(yīng)電流測(cè)量。這兩種方法在原理、應(yīng)
    的頭像 發(fā)表于 09-02 11:26 ?1256次閱讀
    <b class='flag-5'>直接</b>電流測(cè)量與電磁感應(yīng)電流測(cè)量的區(qū)別

    linux驅(qū)動(dòng)程序的編譯方法是什么

    Linux驅(qū)動(dòng)程序的編譯方法主要包括兩種: 與內(nèi)核一起編譯 和 編譯成獨(dú)立的內(nèi)核模塊 。以下是對(duì)這兩種方法的介紹: 一、與內(nèi)核一起編譯 與內(nèi)核一起編譯意味著將驅(qū)動(dòng)程序的源代碼
    的頭像 發(fā)表于 08-30 14:46 ?1259次閱讀

    linux驅(qū)動(dòng)程序的編譯方法有哪兩種

    Linux驅(qū)動(dòng)程序的編譯方法主要可以歸納為兩種: 手動(dòng)編譯 和 使用內(nèi)核構(gòu)建系統(tǒng)(Makefile)自動(dòng)編譯 。 1. 手動(dòng)編譯 手動(dòng)編譯驅(qū)動(dòng)程序通常涉及直接使用GCC(GNU Compiler
    的頭像 發(fā)表于 08-30 14:39 ?1536次閱讀

    LKT(LCS)代碼移植芯片優(yōu)勢(shì)

    所謂代碼移植就是客戶可以把自定義的程序一部分關(guān)鍵代碼函數(shù)移植到加密芯片中運(yùn)行。用戶采用標(biāo)準(zhǔn)C語(yǔ)言編寫(xiě)代碼,
    的頭像 發(fā)表于 08-22 10:03 ?1178次閱讀

    晶閘管的阻斷狀態(tài)兩種是什么

    晶閘管(Thyristor)是一種半導(dǎo)體器件,具有單向?qū)щ娦裕瑥V泛應(yīng)用于電力電子領(lǐng)域。晶閘管的阻斷狀態(tài)兩種:正向阻斷狀態(tài)和反向阻斷狀態(tài)。以下是對(duì)這
    的頭像 發(fā)表于 08-14 16:49 ?1423次閱讀

    觸發(fā)器和狀態(tài)機(jī)的關(guān)系是什么

    觸發(fā)器和狀態(tài)機(jī)在數(shù)字電路設(shè)計(jì)中有著緊密的關(guān)系,它們共同構(gòu)成了時(shí)序邏輯電路的基礎(chǔ),用于實(shí)現(xiàn)數(shù)據(jù)的存儲(chǔ)、處理和傳輸。
    的頭像 發(fā)表于 08-12 11:24 ?946次閱讀