【摘录】MTK按键扫描原理及相关代码
一.MTK按鍵掃描原理:
不同的MTK平臺(tái)內(nèi)部提供的按鍵數(shù)目各有不同,但是掃描原理大致一樣,這里以MTK6253為例來(lái)講解記錄。
MTK提供6*7共42個(gè)矩陣鍵盤(pán),加上Power鍵總共43個(gè)按鍵,其中BB芯片引出6根行線ROW,7根列線COL,如下圖。
??
?
下面來(lái)說(shuō)明一下掃描原理:
在初始化或是沒(méi)有按鍵的情況下,ROW設(shè)置為輸出,COL設(shè)置為輸入。
BB芯片的內(nèi)部設(shè)有一個(gè)按鍵中斷,在沒(méi)有任何按鍵的情況下,所有CLO線為高電平,ROW線為低電平,一旦有按鍵按下,比如key10(ROW1,COL2)有按下,由于COL2線與ROW1線直接相連,COL2線即被拉低,只要COL線有被拉低的,內(nèi)部按鍵中斷便會(huì)響應(yīng),內(nèi)部按鍵中斷產(chǎn)生后,BB就知道有按鍵產(chǎn)生,這時(shí)就進(jìn)行按鍵掃描,判斷出事哪個(gè)按鍵按下,然后進(jìn)行相應(yīng)的處理。
中斷產(chǎn)生后,BB先發(fā)出消息將所有COL線置高,所有ROW線置低,掃描COL線,比如key10(ROW1,COL2)有按下,會(huì)掃描到COL2被拉低;再將將所有ROW線置高,所有COL線置低,掃描ROW線,比如key10(ROW1,COL2)有按下,會(huì)掃描到ROW1被拉低;那么COL2和ROW1組合起來(lái)就知道哪個(gè)按鍵按下了。
??
?? 但是實(shí)際上按鍵中斷產(chǎn)生后,掃描過(guò)程已經(jīng)在BB內(nèi)部迅速完成,然后把相應(yīng)的按鍵位置用寄存器保存起來(lái)。
每個(gè)寄存器16位,每一位代表一個(gè)按鍵,那么總共53個(gè)按鍵,需要4個(gè)寄存器去保存。按鍵的對(duì)應(yīng)位置如下圖:
寄存器的每個(gè)位對(duì)應(yīng)一個(gè)按鍵,默認(rèn)為1,當(dāng)有按鍵按下,那么相應(yīng)位置0。然后系統(tǒng)去讀這四個(gè)寄存器,就能知道是哪一個(gè)按鍵按下。
讀取代碼如下:
???kbd_map_temp_reg?=?(?((kal_uint32)(DRV_Reg(KP_MID_KEY)?<<?16))|((kal_uint32)(DRV_Reg(KP_LOW_KEY)))?);??????#if?defined(DRV_KBD_32KEYS_ABOVE)
??????kbd_map_temp_reg1?=?(kal_uint32)(DRV_Reg(KP_HI_KEY));
??????#elif?defined(DRV_KBD_48KEYS_ABOVE)
??????kbd_map_temp_reg1?=?(?((kal_uint32)(DRV_Reg(KP_HI_KEY)?<<?16))|((kal_uint32)(DRV_Reg(KP_MID1_KEY)))?);
??????#elif?defined(DRV_KBD_64KEYS_ABOVE)
??????kbd_map_temp_reg1?=?(?((kal_uint32)(DRV_Reg(KP_MID2_KEY)?<<?16))|((kal_uint32)(DRV_Reg(KP_MID1_KEY)))?);
??????kbd_map_temp_reg2?=?(kal_uint32)(DRV_Reg(KP_HI_KEY));
??????#endif
二.代碼部分:
按鍵掃描代碼在kbdmain.c文件中的kbd_task_main函數(shù)。上層MMI處理在keybrd.c文件里。
首先,在Kbd_Init初始化時(shí)注冊(cè)按鍵中斷
DRV_Register_HISR(DRV_KP_HISR_ID, Kbd_HisrEntry);
其次,一旦有按鍵產(chǎn)生,那么在中斷處理函數(shù)里面發(fā)送一個(gè)按鍵事件,在kbd_task_main函數(shù)里會(huì)有一個(gè)死循環(huán)一直不停的掃描這個(gè)按鍵時(shí)間,若沒(méi)有按鍵事件發(fā)生,那么就退出此次循環(huán)(continue),一旦檢測(cè)到有按鍵事件發(fā)生,便開(kāi)始讀取寄存器中的值并進(jìn)行相關(guān)處理。
void?Kbd_HisrEntry(void){??
#ifdef?KEY_DEBUG
???dbg_print("Kbd_HisrEntry\r\n");
#endif
#if?defined(__EXTEND_QWERTY_KEYPAD__)
//use?gpt?polling?instead?of?key?IRQ?event?trigger
???IRQMask(IRQ_KPAD_CODE);
#endif?//#if?defined(__EXTEND_QWERTY_KEYPAD__)
???KBD_DBG(__LINE__,?KBD_GetTimeStamp(),?ust_get_current_time(),0);
???/*lint?-e(534)*/kal_set_eg_events(KBD.event,1,KAL_OR);?//設(shè)置按鍵事件?????????
}
在kbd_task_main函數(shù)中檢查按鍵事件
?if?(!(event_group?&?1))????????continue;
最后,將按鍵時(shí)間發(fā)送到MMI層進(jìn)行處理。
KBD_PUSH_ONEKEY_TO_KBDBUFFER(kbd_onekey_press,kbd_press_key[count]);另外附加補(bǔ)充一下:
如果是全鍵盤(pán)的話,NEOTEL53_09B_GPRS.mak中的KEYPAD_TYPE=QWERTY_KEYPAD。如果有擴(kuò)展按鍵的話(即用地或GPIO口模擬ROW線來(lái)擴(kuò)展按鍵)=KEYPAD_TYPE=EXTEND_QWERTY_KEYPAD
轉(zhuǎn)載于:https://www.cnblogs.com/IamEasy_Man/archive/2010/12/16/1908204.html
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的【摘录】MTK按键扫描原理及相关代码的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Python 项目实践三(Web应用程序
- 下一篇: 特征选择算法(机器学习)