www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > EDA > 電子設(shè)計自動化
[導(dǎo)讀]現(xiàn)代EDA(電子設(shè)計自動化)技術(shù)提供了一種很好的途徑,利用VHDL硬件描述語言和FPGA器件可以很方便地構(gòu)建鍵盤掃描模塊。經(jīng)過實際操作檢驗,該模塊可以很好地對每一次按鍵動作進(jìn)行掃描和響應(yīng),實現(xiàn)預(yù)先設(shè)計的功能。

摘要:在電子產(chǎn)品中,鍵盤是最基本的輸入設(shè)備,然而在應(yīng)用中都采用通用的鍵盤掃描器件是不現(xiàn)實的,需要單獨(dú)設(shè)計成專用的小鍵盤?,F(xiàn)代EDA(電子設(shè)計自動化)技術(shù)提供了一種很好的途徑,利用VHDL硬件描述語言和FPGA器件可以很方便地構(gòu)建鍵盤掃描模塊。經(jīng)過實際操作檢驗,該模塊可以很好地對每一次按鍵動作進(jìn)行掃描和響應(yīng),實現(xiàn)預(yù)先設(shè)計的功能。
關(guān)鍵詞:嵌入式系統(tǒng);鍵盤掃描;抖動;FPGA;EDA


1 概述
1.1 通用鍵盤和專用鍵盤
   
在現(xiàn)代個人計算機(jī)系統(tǒng)中,一般都采用通用的標(biāo)準(zhǔn)鍵盤(如:標(biāo)準(zhǔn)101/102鍵盤或Microsoft自然PS/2鍵盤)來實現(xiàn)人與計算機(jī)之間的接口交互,所需要的各種數(shù)據(jù)和指令等信息都通過鍵盤來輸入計算機(jī)。
    但是,在各種嵌入式系統(tǒng)(如手機(jī)、微波爐、電風(fēng)扇等)中,所需要的鍵盤按鍵個數(shù)非常有限,通常為幾個到十幾個不等(而標(biāo)準(zhǔn)鍵盤通常為一百多個按鍵),并且每個按鍵所代表的功能含義也各不相同。所以,針對每一種嵌入式系統(tǒng)都應(yīng)對鍵盤(包括鍵盤掃描模塊和相關(guān)控制信號等)進(jìn)行專門設(shè)計,結(jié)合工程實際情況充分利用該系統(tǒng)已有的各種資源,使所設(shè)計的鍵盤恰如其分地融合到嵌入式系統(tǒng)中,成為其不可分割的一部分。
1.2 編碼鍵盤和掃描鍵盤
   
在數(shù)字電路中,可以利用編碼器實現(xiàn)按鍵鍵值的直接編碼。將每個按鍵的輸出信號對應(yīng)連接到編碼器的每個輸入端,通過編碼邏輯就可以在編碼器的輸出端得到對應(yīng)每個按鍵的碼值,早期稱這種鍵盤為編碼鍵盤。但是,當(dāng)按鍵較多時數(shù)碼邏輯的成本較高,直接編碼的方法也不夠靈括,一旦編碼邏輯固定就難以更改。
    在通用鍵盤上或當(dāng)按鍵數(shù)量較多時,普遍采用掃描方式產(chǎn)生鍵值。將按鍵連接成矩陣,每個按鍵位于某行、某列的交點(diǎn)上,如圖1所示,先通過掃描方式確定按下鍵的行和列位,即位置碼或掃描碼。再查表將位置碼轉(zhuǎn)換為按鍵碼值或者直接使用掃描碼,有些參考書稱此為“非編碼鍵盤”。但這種名稱容易讓人誤解為沒有對應(yīng)的鍵值,因此又稱為掃描式鍵盤。

1.3 硬件掃描鍵盤與軟件掃描鍵盤
   
如果執(zhí)行掃描的過程由硬件邏輯實現(xiàn),則這種鍵盤稱為硬件掃描鍵盤或電子掃描式編碼鍵盤。在執(zhí)行鍵盤掃描時應(yīng)注意將鍵在閉合過程中往往會有一些難以避免的機(jī)械性抖動,使輸出信號也發(fā)生抖動,通常達(dá)10 ms~20 ms寬。若不避開抖動區(qū),則可能誤認(rèn)為多次按鍵。因此應(yīng)該設(shè)置硬件延時電路,延遲數(shù)十毫秒后才讀取鍵值,這種電路稱為去抖電路。還應(yīng)注意當(dāng)前一個鍵值還未送出又有按鍵按下時,后邊的鍵值將覆蓋前邊的鍵值,從而造成丟失。通常可以設(shè)置一個控制信號,使前一鍵值送出后才允許產(chǎn)生后一鍵值,或者設(shè)置一組寄存器保存前邊若干個鍵值,等待系統(tǒng)逐個按序處理。
    硬件掃描鍵盤的優(yōu)點(diǎn)是不需要主機(jī)擔(dān)負(fù)掃描任務(wù),僅當(dāng)產(chǎn)生鍵值后才向主機(jī)發(fā)出中斷請求,CPU以相應(yīng)中斷方式接收按鍵鍵值,或者CPU定時從某個地址獲取按鍵鍵值。這種方式大大減輕了CPU的運(yùn)行負(fù)荷,使其有更多的時間段去運(yùn)行其他應(yīng)用程序。
    當(dāng)然也可以執(zhí)行鍵盤掃描程序,由CPU通過軟件方法對鍵盤進(jìn)行掃描,鍵盤掃描程序的流程如圖2所示。這種鍵盤被稱為軟件掃描鍵盤。按鍵時,鍵盤向主機(jī)提出中斷請求,由軟件掃描鍵盤獲得按鍵鍵值,或者由CPU定期執(zhí)行鍵盤掃描程序,從而獲得按鍵鍵值,這種掃描方法被稱為逐行掃描法,當(dāng)有鍵按下時首先獲得此鍵的列值,然后逐行掃描就可以判斷按鍵所在的行值,由行、列值轉(zhuǎn)換到按鍵鍵值。當(dāng)然,可以在執(zhí)行鍵盤掃描的過程中加入一定的延時,以去除抖動所帶來的影響。

    如果系統(tǒng)對CPU的運(yùn)行速度要求較高,并且CPU的負(fù)荷較重,系統(tǒng)資源比較緊張,則可以在鍵盤中設(shè)置一個單片機(jī),由單片機(jī)執(zhí)行鍵盤掃描程序,然后向CPU申請中斷并送出掃描碼或者鍵值?,F(xiàn)代計算機(jī)的通用鍵盤大多采用這樣的鍵盤掃描方法。

2 基于FPGA的實現(xiàn)方法
2.1 實現(xiàn)方法分析
   
根據(jù)項目的實際需要,擬實現(xiàn)的鍵盤掃描模塊應(yīng)具有如下特點(diǎn):
    該模塊實時地將掃描所得的鍵值信息寫入存儲器指定地址,鍵值信息包括同一按鍵的重復(fù)次數(shù)和鍵值,系統(tǒng)軟件定時從該地址讀取鍵值信息以執(zhí)行相應(yīng)的操作。
    鍵盤去抖動的方法是多次掃描法,當(dāng)連續(xù)幾次掃描到同一鍵值時就認(rèn)為此鍵被按下,這樣就完成了去抖動操作。
    由于該項目不需要ASCⅡ字符編碼按鍵,故將按鍵值設(shè)計為1~20直接送出。
    為了能表示長時間按鍵的操作,當(dāng)確定某一按鍵按下時,以后每隔一定時間才掃描一次,若獲得同一鍵值,則將按鍵重復(fù)次數(shù)加一,同時將重復(fù)次數(shù)和鍵值組合成鍵值信息送出;延遲一定時間后再次掃描。
2.2 FPGA具體實現(xiàn)
   
該設(shè)計采用4個模塊來實現(xiàn)鍵盤掃描功能,分別為即時掃描模塊、掃描控制模塊、掃描脈沖模塊和鍵值傳送模塊,如圖3所示。

2.2.1 即時掃描模塊
   
該模塊完成鍵盤即時掃描功能,當(dāng)檢測到SCAN信號有一個窄脈沖到來時,模塊內(nèi)部將產(chǎn)生一組相應(yīng)的KB_OUT信號輸出到鍵盤矩陣,然后對KB_IN輸入信號進(jìn)行檢測,以判斷有無鍵被按下及哪個鍵被按下,并送出相應(yīng)的即時鍵值VALUE。
2.2.2 掃描控制模塊
   
該模塊的功能是控制是否允許進(jìn)行掃描及完成鍵盤去抖動等。在無鍵按下時.CTRL置高電平允許掃描;當(dāng)連續(xù)幾次掃描到同一個按鍵時,則認(rèn)為此鍵被按下(已經(jīng)完成去抖動操作)。然后CTRL置低電平,禁止掃描并同時開始延時,當(dāng)CNT達(dá)到某一數(shù)值時,重新進(jìn)行掃描并再次延時,同時將按鍵重復(fù)次數(shù)和鍵值VALUE組合成KEYVALUES并輸出。以此類推,直到無鍵按下或檢測到其他的鍵值。
2.2.3 掃描脈沖模塊
   
該模塊的主要功能為產(chǎn)生掃描指示窄脈沖和掃描延時計數(shù)。當(dāng)CTRL為高電平時,在每個CLK為50Hz的上升沿送出一個SCAN窄脈沖;當(dāng)CTRL為低電平時,延時計數(shù)器開始計數(shù),達(dá)到某一特定值時才送出一次掃描脈沖信號SCAN。
2.2.4 鍵值傳送模塊
   
該模塊負(fù)責(zé)把鍵值信息寫入存儲器,供應(yīng)用軟件定時查詢。當(dāng)輸入端KEYVALUES的值發(fā)生改變時,才會發(fā)起一次存儲器寫操作。


3 結(jié)束語
   
此模塊用VHDL硬件描述語言來實現(xiàn),經(jīng)過功能、時序仿真后利用QUARTUS Ⅱ軟件進(jìn)行編譯并下載到Altera的CYCLONE 1C20開發(fā)板上。經(jīng)過對鍵盤的實際操作檢驗,證明此模塊可以正常實現(xiàn)鍵盤掃描和去抖動等功能,能正確地識別每一個按鍵的動作。同時,若對該模塊稍加修改同樣可以移植到其他的系統(tǒng)中,這樣可以大大減輕CPU的運(yùn)行負(fù)荷,這對大多數(shù)對系統(tǒng)資源比較敏感的嵌入式系統(tǒng)來說具有很強(qiáng)的現(xiàn)實意義。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉