【摘录】MTK按键扫描原理及相关代码
一.MTK按鍵掃描原理:
不同的MTK平臺內部提供的按鍵數目各有不同,但是掃描原理大致一樣,這里以MTK6253為例來講解記錄。
MTK提供6*7共42個矩陣鍵盤,加上Power鍵總共43個按鍵,其中BB芯片引出6根行線ROW,7根列線COL,如下圖。
??
?
下面來說明一下掃描原理:
在初始化或是沒有按鍵的情況下,ROW設置為輸出,COL設置為輸入。
BB芯片的內部設有一個按鍵中斷,在沒有任何按鍵的情況下,所有CLO線為高電平,ROW線為低電平,一旦有按鍵按下,比如key10(ROW1,COL2)有按下,由于COL2線與ROW1線直接相連,COL2線即被拉低,只要COL線有被拉低的,內部按鍵中斷便會響應,內部按鍵中斷產生后,BB就知道有按鍵產生,這時就進行按鍵掃描,判斷出事哪個按鍵按下,然后進行相應的處理。
中斷產生后,BB先發出消息將所有COL線置高,所有ROW線置低,掃描COL線,比如key10(ROW1,COL2)有按下,會掃描到COL2被拉低;再將將所有ROW線置高,所有COL線置低,掃描ROW線,比如key10(ROW1,COL2)有按下,會掃描到ROW1被拉低;那么COL2和ROW1組合起來就知道哪個按鍵按下了。
??
?? 但是實際上按鍵中斷產生后,掃描過程已經在BB內部迅速完成,然后把相應的按鍵位置用寄存器保存起來。
每個寄存器16位,每一位代表一個按鍵,那么總共53個按鍵,需要4個寄存器去保存。按鍵的對應位置如下圖:
寄存器的每個位對應一個按鍵,默認為1,當有按鍵按下,那么相應位置0。然后系統去讀這四個寄存器,就能知道是哪一個按鍵按下。
讀取代碼如下:
???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函數。上層MMI處理在keybrd.c文件里。
首先,在Kbd_Init初始化時注冊按鍵中斷
DRV_Register_HISR(DRV_KP_HISR_ID, Kbd_HisrEntry);
其次,一旦有按鍵產生,那么在中斷處理函數里面發送一個按鍵事件,在kbd_task_main函數里會有一個死循環一直不停的掃描這個按鍵時間,若沒有按鍵事件發生,那么就退出此次循環(continue),一旦檢測到有按鍵事件發生,便開始讀取寄存器中的值并進行相關處理。
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);?//設置按鍵事件?????????
}
在kbd_task_main函數中檢查按鍵事件
?if?(!(event_group?&?1))????????continue;
最后,將按鍵時間發送到MMI層進行處理。
KBD_PUSH_ONEKEY_TO_KBDBUFFER(kbd_onekey_press,kbd_press_key[count]);另外附加補充一下:
如果是全鍵盤的話,NEOTEL53_09B_GPRS.mak中的KEYPAD_TYPE=QWERTY_KEYPAD。如果有擴展按鍵的話(即用地或GPIO口模擬ROW線來擴展按鍵)=KEYPAD_TYPE=EXTEND_QWERTY_KEYPAD
轉載于:https://www.cnblogs.com/IamEasy_Man/archive/2010/12/16/1908204.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的【摘录】MTK按键扫描原理及相关代码的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python 项目实践三(Web应用程序
- 下一篇: 特征选择算法(机器学习)