yc_keypad.c 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847
  1. /**
  2. * COPYRIGHT NOTICE
  3. *Copyright(c) 2014,YICHIP
  4. *
  5. * @file yc_keypad.c
  6. * @brief ...
  7. *
  8. * @version 1.0
  9. * @author jingzou
  10. * @data Jan 23, 2018
  11. **/
  12. #include<string.h>
  13. #include<stdio.h>
  14. #include "yc_keypad.h"
  15. #include "yc11xx.h"
  16. #include "yc_timer.h"
  17. #include "yc_queue.h"
  18. #define KEY_EVT_QUEUE_MAX 10
  19. KEY_EVT_ELE gQueueKeyEvt[KEY_EVT_QUEUE_MAX];
  20. QUEUE_HEADER gEvtHeader;
  21. KEYPAD_CONTROL gKeypadCtr;
  22. KEYPAD_CONFIG gKeypadConfig=
  23. {
  24. 10, //polling_timer
  25. { //keypad_combokey_array
  26. { //COMBKEY_CONFIG
  27. KEY_0_MASK|KEY_1_MASK,
  28. KEYPAD_PRESS_NONE,
  29. {0,0,TIMER_STOP,0,0,0,},
  30. {50,30,100,100},
  31. },
  32. {
  33. KEY_0_MASK|KEY_1_MASK,
  34. KEYPAD_PRESS_NONE,
  35. {0,0,TIMER_STOP,0,0,0,},
  36. {50,30,100,100},
  37. },
  38. {
  39. KEY_0_MASK|KEY_1_MASK,
  40. KEYPAD_PRESS_NONE,
  41. {0,0,TIMER_STOP,0,0,0,},
  42. {50,30,100,100},
  43. },
  44. {
  45. KEY_0_MASK|KEY_1_MASK,
  46. KEYPAD_PRESS_NONE,
  47. {0,0,TIMER_STOP,0,0,0,},
  48. {50,30,100,100},
  49. },
  50. },
  51. {//keypad_gpio_array
  52. {//KEY_CONFIG
  53. GPIO_3, //0
  54. KEYPAD_PRESS_NONE,
  55. {0,0,TIMER_STOP,0,0,0,},
  56. {50,30,100,100},
  57. },
  58. {
  59. GPIO_4,
  60. KEYPAD_PRESS_NONE,
  61. {0,0,TIMER_STOP,0,0,0,},
  62. {50,100,100,100},
  63. },
  64. {
  65. GPIO_5,
  66. KEYPAD_PRESS_NONE,
  67. {0,0,TIMER_STOP,0,0,0,},
  68. {50,100,100},
  69. },
  70. {
  71. GPIO_MAX_NUM, //3
  72. KEYPAD_PRESS_NONE,
  73. {0},
  74. {50,100,100},
  75. },
  76. {
  77. GPIO_MAX_NUM, //4
  78. KEYPAD_PRESS_NONE,
  79. {0},
  80. {50,100,100},
  81. },
  82. {
  83. GPIO_MAX_NUM, //5
  84. KEYPAD_PRESS_NONE,
  85. {0},
  86. {10,100,100},
  87. },
  88. {
  89. GPIO_MAX_NUM, //6
  90. KEYPAD_PRESS_NONE,
  91. {0},
  92. {10,100,100},
  93. },
  94. {
  95. GPIO_MAX_NUM, //7
  96. KEYPAD_PRESS_NONE,
  97. {0},
  98. {10,100,100},
  99. },
  100. {
  101. GPIO_MAX_NUM, //8
  102. KEYPAD_PRESS_NONE,
  103. {0},
  104. {10,100,100},
  105. },
  106. {
  107. GPIO_MAX_NUM, //9
  108. KEYPAD_PRESS_NONE,
  109. {0},
  110. {10,100,100},
  111. },
  112. {
  113. GPIO_MAX_NUM, //10
  114. KEYPAD_PRESS_NONE,
  115. {0,},
  116. {10,100,100},
  117. },
  118. {
  119. GPIO_MAX_NUM, //11
  120. KEYPAD_PRESS_NONE,
  121. {0,},
  122. {10,100,100},
  123. },
  124. {
  125. GPIO_MAX_NUM, //12
  126. KEYPAD_PRESS_NONE,
  127. {0,},
  128. {10,100,100},
  129. },
  130. {
  131. GPIO_MAX_NUM, //13
  132. KEYPAD_PRESS_NONE,
  133. {0,},
  134. {10,100,100},
  135. },
  136. {
  137. GPIO_MAX_NUM, //14
  138. KEYPAD_PRESS_NONE,
  139. {0,},
  140. {10,100,100},
  141. },
  142. {
  143. GPIO_MAX_NUM, //15
  144. KEYPAD_PRESS_NONE,
  145. {0,},
  146. {10,100,100},
  147. },
  148. },
  149. 1, //comboKeyNum
  150. 3, //keyNum
  151. };
  152. typedef union
  153. {
  154. uint32_t value32;
  155. uint16_t value16[2];
  156. uint8_t value8[4];
  157. }UNION_32BIT;
  158. SYS_TIMER_TYPE gKeypadPolling_Timer;
  159. void keypad_init(KeyPad_Evt_CB_Handle cb)
  160. {
  161. uint8_t i;
  162. UNION_32BIT wakeup_mask;
  163. //clear keypad control information
  164. memset(&gKeypadCtr, 0, sizeof(gKeypadCtr));
  165. //set call back event handle
  166. gKeypadCtr.keypad_evt_callback = cb;
  167. for (i = 0; i < gKeypadConfig.keyNum; i++)
  168. {
  169. if (gKeypadConfig.keypad_gpio_array[i].gpio_ind != GPIO_MAX_NUM)
  170. {
  171. HWRITE((CORE_GPIO_CONF+(gKeypadConfig.keypad_gpio_array[i].gpio_ind)), GPCFG_PULLUP|GPCFG_INPUT);
  172. gKeypadCtr.gpio_key_mask |= (1 << i);
  173. gKeypadCtr.gpio_hid_key_mask |= (1 << i);
  174. wakeup_mask.value32 |= (1 << gKeypadConfig.keypad_gpio_array[i].gpio_ind);
  175. }
  176. }
  177. // //enable low wakeup function
  178. // HWRITEW(CORE_GPIO_WAKEUP_LOW, wakeup_mask.value16[0]);
  179. // HWRITEW(CORE_GPIO_WAKEUP_LOW+2, wakeup_mask.value16[1]);
  180. SYS_SetTimer(&gKeypadPolling_Timer,17,TIMER_CYCLE,keypad_check_keypress);
  181. if (!queue_init(&gEvtHeader, (void *)&gQueueKeyEvt, sizeof(KEY_EVT_ELE), KEY_EVT_QUEUE_MAX))
  182. {
  183. printf("Queue init fail\n");
  184. }
  185. }
  186. void key_send_evt_to_Queue(KEY_INDEX index,KEYPAD_EVT_TYPE key_evt)
  187. {
  188. KEY_EVT_ELE key_ele_temp;
  189. key_ele_temp.key_ind = index;
  190. key_ele_temp.evt_type = key_evt;
  191. //YC_LOG_INFO("KEYPAD send ind=%d ,type=%d\r\n",index,key_evt);
  192. if (!Insert_Queue(&gEvtHeader,(void *)&key_ele_temp))
  193. {
  194. printf("put to queue fail\n");
  195. //put queue is error
  196. //TO DO
  197. }
  198. }
  199. void keypad_gpio_mapping_process(KEY_KEYMAP keyBitmap_L , KEY_KEYMAP keyBitmap_H )
  200. {
  201. uint8_t i;
  202. KEY_KEYMAP keyBitmap_Local;
  203. keyBitmap_Local.keymap_u16 = 0;
  204. gKeypadCtr.key_mapping_result_old.keymap_u16 = gKeypadCtr.key_mapping_result.keymap_u16;//save old for next time to compare
  205. gKeypadCtr.key_hid_mapping_result_old.keymap_u16 = gKeypadCtr.key_hid_mapping_result.keymap_u16;//save old for next time to compare
  206. //for( i = 0 ; i < KEY_MAX_NUM ; i++ )
  207. for(i = 0; i < gKeypadConfig.keyNum; i++)
  208. {
  209. switch( gKeypadConfig.keypad_gpio_array[i].gpio_ind)
  210. {
  211. case GPIO_0:
  212. if( keyBitmap_L.keymap_u8[0] & 0x01 )//gpio0 = 1
  213. {
  214. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  215. }
  216. else
  217. {
  218. keyBitmap_Local.keymap_u16 |= (1<<i);
  219. }
  220. break;
  221. case GPIO_1:
  222. if( keyBitmap_L.keymap_u8[0] & 0x02 )//gpio0 = 1
  223. {
  224. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  225. }
  226. else
  227. {
  228. keyBitmap_Local.keymap_u16 |= (1<<i);
  229. }
  230. break;
  231. case GPIO_2:
  232. if( keyBitmap_L.keymap_u8[0] & 0x04 )//gpio0 = 1
  233. {
  234. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  235. }
  236. else
  237. {
  238. keyBitmap_Local.keymap_u16 |= (1<<i);
  239. }
  240. break;
  241. case GPIO_3:
  242. if( keyBitmap_L.keymap_u8[0] & 0x08 )//gpio0 = 1
  243. {
  244. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  245. }
  246. else
  247. {
  248. keyBitmap_Local.keymap_u16 |= (1<<i);
  249. }
  250. break;
  251. case GPIO_4:
  252. if( keyBitmap_L.keymap_u8[0] & 0x10 )//gpio0 = 1
  253. {
  254. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  255. }
  256. else
  257. {
  258. keyBitmap_Local.keymap_u16 |= (1<<i);
  259. }
  260. break;
  261. case GPIO_5:
  262. if( keyBitmap_L.keymap_u8[0] & 0x20 )//gpio0 = 1
  263. {
  264. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  265. }
  266. else
  267. {
  268. keyBitmap_Local.keymap_u16 |= (1<<i);
  269. }
  270. break;
  271. case GPIO_6:
  272. if( keyBitmap_L.keymap_u8[0] & 0x40 )//gpio0 = 1
  273. {
  274. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  275. }
  276. else
  277. {
  278. keyBitmap_Local.keymap_u16 |= (1<<i);
  279. }
  280. break;
  281. case GPIO_7:
  282. if( keyBitmap_L.keymap_u8[0] & 0x80 )//gpio0 = 1
  283. {
  284. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  285. }
  286. else
  287. {
  288. keyBitmap_Local.keymap_u16 |= (1<<i);
  289. }
  290. break;
  291. case GPIO_8:
  292. if( keyBitmap_L.keymap_u8[1] & 0x01 )//
  293. {
  294. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  295. }
  296. else
  297. {
  298. keyBitmap_Local.keymap_u16 |= (1<<i);
  299. }
  300. break;
  301. case GPIO_9:
  302. if( keyBitmap_L.keymap_u8[1] & 0x02 )//
  303. {
  304. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  305. }
  306. else
  307. {
  308. keyBitmap_Local.keymap_u16 |= (1<<i);
  309. }
  310. break;
  311. case GPIO_10:
  312. if( keyBitmap_L.keymap_u8[1] & 0x04 )//
  313. {
  314. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  315. }
  316. else
  317. {
  318. keyBitmap_Local.keymap_u16 |= (1<<i);
  319. }
  320. break;
  321. case GPIO_11:
  322. if( keyBitmap_L.keymap_u8[1] & 0x08 )//
  323. {
  324. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  325. }
  326. else
  327. {
  328. keyBitmap_Local.keymap_u16 |= (1<<i);
  329. }
  330. break;
  331. case GPIO_12:
  332. if( keyBitmap_L.keymap_u8[1] & 0x10 )//
  333. {
  334. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  335. }
  336. else
  337. {
  338. keyBitmap_Local.keymap_u16 |= (1<<i);
  339. }
  340. break;
  341. case GPIO_13:
  342. if( keyBitmap_L.keymap_u8[1] & 0x20 )//
  343. {
  344. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  345. }
  346. else
  347. {
  348. keyBitmap_Local.keymap_u16 |= (1<<i);
  349. }
  350. break;
  351. case GPIO_14:
  352. if( keyBitmap_L.keymap_u8[1] & 0x40 )//
  353. {
  354. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  355. }
  356. else
  357. {
  358. keyBitmap_Local.keymap_u16 |= (1<<i);
  359. }
  360. break;
  361. case GPIO_15:
  362. if( keyBitmap_L.keymap_u8[1] & 0x80 )//
  363. {
  364. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  365. }
  366. else
  367. {
  368. keyBitmap_Local.keymap_u16 |= (1<<i);
  369. }
  370. break;
  371. case GPIO_16:
  372. if( keyBitmap_H.keymap_u8[0] & 0x01 )
  373. {
  374. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  375. }
  376. else
  377. {
  378. keyBitmap_Local.keymap_u16 |= (1<<i);
  379. }
  380. break;
  381. case GPIO_17:
  382. if( keyBitmap_H.keymap_u8[0] & 0x02 )
  383. {
  384. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  385. }
  386. else
  387. {
  388. keyBitmap_Local.keymap_u16 |= (1<<i);
  389. }
  390. break;
  391. case GPIO_18:
  392. if( keyBitmap_H.keymap_u8[0] & 0x04 )
  393. {
  394. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  395. }
  396. else
  397. {
  398. keyBitmap_Local.keymap_u16 |= (1<<i);
  399. }
  400. break;
  401. case GPIO_19:
  402. if( keyBitmap_H.keymap_u8[0] & 0x08 )
  403. {
  404. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  405. }
  406. else
  407. {
  408. keyBitmap_Local.keymap_u16 |= (1<<i);
  409. }
  410. break;
  411. case GPIO_20:
  412. if( keyBitmap_H.keymap_u8[0] & 0x10 )
  413. {
  414. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  415. }
  416. else
  417. {
  418. keyBitmap_Local.keymap_u16 |= (1<<i);
  419. }
  420. break;
  421. case GPIO_21:
  422. if( keyBitmap_H.keymap_u8[0] & 0x20 )
  423. {
  424. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  425. }
  426. else
  427. {
  428. keyBitmap_Local.keymap_u16 |= (1<<i);
  429. }
  430. break;
  431. case GPIO_22:
  432. if( keyBitmap_H.keymap_u8[0] & 0x40 )
  433. {
  434. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  435. }
  436. else
  437. {
  438. keyBitmap_Local.keymap_u16 |= (1<<i);
  439. }
  440. break;
  441. case GPIO_23:
  442. if( keyBitmap_H.keymap_u8[0] & 0x80 )
  443. {
  444. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  445. }
  446. else
  447. {
  448. keyBitmap_Local.keymap_u16 |= (1<<i);
  449. }
  450. break;
  451. case GPIO_24:
  452. if( keyBitmap_H.keymap_u8[1] & 0x01 )
  453. {
  454. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  455. }
  456. else
  457. {
  458. keyBitmap_Local.keymap_u16 |= (1<<i);
  459. }
  460. break;
  461. case GPIO_25:
  462. if( keyBitmap_H.keymap_u8[1] & 0x02 )
  463. {
  464. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  465. }
  466. else
  467. {
  468. keyBitmap_Local.keymap_u16 |= (1<<i);
  469. }
  470. break;
  471. case GPIO_26:
  472. if( keyBitmap_H.keymap_u8[1] & 0x04 )
  473. {
  474. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  475. }
  476. else
  477. {
  478. keyBitmap_Local.keymap_u16 |= (1<<i);
  479. }
  480. break;
  481. case GPIO_27:
  482. if( keyBitmap_H.keymap_u8[1] & 0x08 )
  483. {
  484. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  485. }
  486. else
  487. {
  488. keyBitmap_Local.keymap_u16 |= (1<<i);
  489. }
  490. break;
  491. case GPIO_28:
  492. if( keyBitmap_H.keymap_u8[1] & 0x10 )
  493. {
  494. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  495. }
  496. else
  497. {
  498. keyBitmap_Local.keymap_u16 |= (1<<i);
  499. }
  500. break;
  501. case GPIO_29:
  502. if( keyBitmap_H.keymap_u8[1] & 0x20 )
  503. {
  504. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  505. }
  506. else
  507. {
  508. keyBitmap_Local.keymap_u16 |= (1<<i);
  509. }
  510. break;
  511. case GPIO_30:
  512. if( keyBitmap_H.keymap_u8[1] & 0x40 )
  513. {
  514. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  515. }
  516. else
  517. {
  518. keyBitmap_Local.keymap_u16 |= (1<<i);
  519. }
  520. break;
  521. case GPIO_31:
  522. if( keyBitmap_H.keymap_u8[1] & 0x80 )
  523. {
  524. keyBitmap_Local.keymap_u16 &= (~(1<<i));
  525. }
  526. else
  527. {
  528. keyBitmap_Local.keymap_u16 |= (1<<i);
  529. }
  530. break;
  531. }
  532. }
  533. //YC_LOG_INFO("local bitmap %x ,%x in\r\n",keyBitmap_Local.keymap_u16,gKeypadCtr.gpio_key_mask);
  534. gKeypadCtr.gpio_mapping_result.keymap_u16 = keyBitmap_Local.keymap_u16;
  535. gKeypadCtr.key_mapping_result.keymap_u16 = (gKeypadCtr.gpio_mapping_result.keymap_u16 & gKeypadCtr.gpio_key_mask );
  536. gKeypadCtr.key_hid_mapping_result.keymap_u16 = (gKeypadCtr.gpio_mapping_result.keymap_u16 & gKeypadCtr.gpio_hid_key_mask );
  537. if(gKeypadCtr.key_hid_mapping_result_old.keymap_u16 ^ gKeypadCtr.key_hid_mapping_result.keymap_u16 )//key change happen
  538. {
  539. gKeypadCtr.Key_Change_happen = 1;
  540. }
  541. }
  542. void keypad_keyExpired(int keyIndex)
  543. {
  544. switch(gKeypadConfig.keypad_gpio_array[keyIndex].press_type)
  545. {
  546. case KEYPAD_PRESS_MULTI:
  547. if (gKeypadCtr.key_mapping_result.keymap_u16 & (1 << keyIndex))
  548. {
  549. if (gKeypadCtr.key_multi_count == 0)
  550. {
  551. gKeypadConfig.keypad_gpio_array[keyIndex].press_type = KEYPAD_PRESS_PRESS;
  552. gKeypadConfig.keypad_gpio_array[keyIndex].key_timer.cbParams = keyIndex;
  553. SYS_SetTimer(&gKeypadConfig.keypad_gpio_array[keyIndex].key_timer,
  554. gKeypadConfig.keypad_gpio_array[keyIndex].key_timer_cfg.press_timer,
  555. TIMER_SINGLE,
  556. keypad_keyExpired);
  557. }
  558. else
  559. {
  560. if (gKeypadCtr.key_multi_count > 3)
  561. key_send_evt_to_Queue(keyIndex,KEYPAD_TRIPLE);
  562. else
  563. key_send_evt_to_Queue(keyIndex,gKeypadCtr.key_multi_count);
  564. gKeypadCtr.key_multi_count = 0;
  565. }
  566. }
  567. else
  568. {
  569. if (gKeypadCtr.key_multi_count > 3)
  570. key_send_evt_to_Queue(keyIndex,KEYPAD_TRIPLE);
  571. else
  572. key_send_evt_to_Queue(keyIndex,gKeypadCtr.key_multi_count);
  573. gKeypadCtr.key_multi_count = 0;
  574. gKeypadConfig.keypad_gpio_array[keyIndex].press_type = KEYPAD_PRESS_NONE;
  575. }
  576. //YC_LOG_INFO("multi timer %d\r\n",keyIndex);
  577. break;
  578. case KEYPAD_PRESS_PRESS:
  579. gKeypadConfig.keypad_gpio_array[keyIndex].press_type = KEYPAD_PRESS_LONG_PRESS;
  580. gKeypadConfig.keypad_gpio_array[keyIndex].key_timer.cbParams = keyIndex;
  581. SYS_SetTimer(&gKeypadConfig.keypad_gpio_array[keyIndex].key_timer,
  582. gKeypadConfig.keypad_gpio_array[keyIndex].key_timer_cfg.long_press_timer,
  583. TIMER_SINGLE,
  584. keypad_keyExpired);
  585. key_send_evt_to_Queue(keyIndex,KEYPAD_PRESS);
  586. //YC_LOG_INFO("press timer %d\r\n",keyIndex);
  587. break;
  588. case KEYPAD_PRESS_LONG_PRESS:
  589. gKeypadConfig.keypad_gpio_array[keyIndex].press_type = KEYPAD_PRESS_LONGLONG_PRESS;
  590. gKeypadConfig.keypad_gpio_array[keyIndex].key_timer.cbParams = keyIndex;
  591. SYS_SetTimer(&gKeypadConfig.keypad_gpio_array[keyIndex].key_timer,
  592. gKeypadConfig.keypad_gpio_array[keyIndex].key_timer_cfg.longlong_press_timer,
  593. TIMER_SINGLE,
  594. keypad_keyExpired);
  595. key_send_evt_to_Queue(keyIndex,KEYPAD_LONG_PRESS);
  596. //YC_LOG_INFO("long press timer %d\r\n",keyIndex);
  597. break;
  598. case KEYPAD_PRESS_LONGLONG_PRESS:
  599. gKeypadConfig.keypad_gpio_array[keyIndex].press_type = KEYPAD_PRESS_EXTREME_LONG_PESS;
  600. gKeypadConfig.keypad_gpio_array[keyIndex].key_timer.cbParams = keyIndex;
  601. SYS_SetTimer(&gKeypadConfig.keypad_gpio_array[keyIndex].key_timer,
  602. gKeypadConfig.keypad_gpio_array[keyIndex].key_timer_cfg.longlong_press_timer,
  603. TIMER_CYCLE,
  604. SYS_TimerExpireDefaultHandle);
  605. key_send_evt_to_Queue(keyIndex,KEYPAD_LONGLONG_PRESS);
  606. //YC_LOG_INFO("long long timer %d\r\n",keyIndex);
  607. break;
  608. case KEYPAD_PRESS_EXTREME_LONG_PESS:
  609. break;
  610. }
  611. }
  612. void keypad_comboKeyExpired(int keyIndex)
  613. {
  614. switch(gKeypadConfig.keypad_combokey_array[keyIndex].press_type)
  615. {
  616. case KEYPAD_PRESS_PRESS:
  617. gKeypadConfig.keypad_combokey_array[keyIndex].press_type = KEYPAD_PRESS_LONG_PRESS;
  618. gKeypadConfig.keypad_combokey_array[keyIndex].key_timer.cbParams = keyIndex;
  619. SYS_SetTimer(&gKeypadConfig.keypad_combokey_array[keyIndex].key_timer,
  620. gKeypadConfig.keypad_combokey_array[keyIndex].key_timer_cfg.long_press_timer,
  621. TIMER_SINGLE,
  622. keypad_comboKeyExpired);
  623. key_send_evt_to_Queue(keyIndex+COMB_KEY1,KEYPAD_PRESS);
  624. //YC_LOG_INFO("press timer %d\r\n",keyIndex);
  625. break;
  626. case KEYPAD_PRESS_LONG_PRESS:
  627. gKeypadConfig.keypad_combokey_array[keyIndex].press_type = KEYPAD_PRESS_LONGLONG_PRESS;
  628. gKeypadConfig.keypad_combokey_array[keyIndex].key_timer.cbParams = keyIndex;
  629. SYS_SetTimer(&gKeypadConfig.keypad_combokey_array[keyIndex].key_timer,
  630. gKeypadConfig.keypad_combokey_array[keyIndex].key_timer_cfg.longlong_press_timer,
  631. TIMER_SINGLE,
  632. keypad_comboKeyExpired);
  633. key_send_evt_to_Queue(keyIndex+COMB_KEY1,KEYPAD_LONG_PRESS);
  634. //YC_LOG_INFO("long press timer %d\r\n",keyIndex);
  635. break;
  636. case KEYPAD_PRESS_LONGLONG_PRESS:
  637. gKeypadConfig.keypad_combokey_array[keyIndex].press_type = KEYPAD_PRESS_EXTREME_LONG_PESS;
  638. gKeypadConfig.keypad_combokey_array[keyIndex].key_timer.cbParams = keyIndex;
  639. SYS_SetTimer(&gKeypadConfig.keypad_combokey_array[keyIndex].key_timer,
  640. gKeypadConfig.keypad_combokey_array[keyIndex].key_timer_cfg.longlong_press_timer,
  641. TIMER_CYCLE,
  642. SYS_TimerExpireDefaultHandle);
  643. key_send_evt_to_Queue(keyIndex+COMB_KEY1,KEYPAD_LONGLONG_PRESS);
  644. //YC_LOG_INFO("long long timer %d\r\n",keyIndex);
  645. break;
  646. case KEYPAD_PRESS_EXTREME_LONG_PESS:
  647. break;
  648. }
  649. }
  650. void keypad_keyevtScan()
  651. {
  652. uint8_t i;
  653. if (gKeypadCtr.Key_Change_happen == 1)
  654. {
  655. gKeypadCtr.Key_Change_happen =0;
  656. // printf("key is change = d %d !\r\n",gKeypadCtr.key_mapping_result.keymap_u16);
  657. }
  658. //check combo key
  659. for(i = 0; i < gKeypadConfig.comboKeyNum; i++)
  660. {
  661. if ((gKeypadCtr.key_mapping_result.keymap_u16
  662. & gKeypadConfig.keypad_combokey_array[i].comkKeyMask) == gKeypadConfig.keypad_combokey_array[i].comkKeyMask)
  663. {
  664. // key press
  665. if ((gKeypadCtr.key_mapping_result_old.keymap_u16
  666. & gKeypadConfig.keypad_combokey_array[i].comkKeyMask) != gKeypadConfig.keypad_combokey_array[i].comkKeyMask)
  667. {
  668. if (gKeypadConfig.keypad_combokey_array[i].press_type == KEYPAD_PRESS_NONE)
  669. {
  670. gKeypadConfig.keypad_combokey_array[i].press_type = KEYPAD_PRESS_PRESS;
  671. gKeypadConfig.keypad_combokey_array[i].key_timer.cbParams = i;
  672. SYS_SetTimer(&gKeypadConfig.keypad_combokey_array[i].key_timer,
  673. gKeypadConfig.keypad_combokey_array[i].key_timer_cfg.press_timer,
  674. TIMER_SINGLE,
  675. keypad_comboKeyExpired);
  676. // printf("combo key down\n",i);
  677. }
  678. }
  679. }
  680. else
  681. {
  682. //release key
  683. if ((gKeypadCtr.key_mapping_result_old.keymap_u16
  684. & gKeypadConfig.keypad_combokey_array[i].comkKeyMask) == gKeypadConfig.keypad_combokey_array[i].comkKeyMask)
  685. {
  686. SYS_ReleaseTimer(&gKeypadConfig.keypad_combokey_array[i].key_timer);
  687. switch(gKeypadConfig.keypad_combokey_array[i].press_type)
  688. {
  689. case KEYPAD_PRESS_PRESS:
  690. key_send_evt_to_Queue(i+COMB_KEY1,KEYPAD_TAP);
  691. break;
  692. case KEYPAD_PRESS_LONG_PRESS:
  693. key_send_evt_to_Queue(i+COMB_KEY1,KEYPAD_PRESS_RELEASE);
  694. break;
  695. case KEYPAD_PRESS_LONGLONG_PRESS:
  696. key_send_evt_to_Queue(i+COMB_KEY1,KEYPAD_LONG_RELEASE);
  697. break;
  698. case KEYPAD_PRESS_EXTREME_LONG_PESS:
  699. key_send_evt_to_Queue(i+COMB_KEY1,KEYPAD_LONGLONG_RELEASE);
  700. break;
  701. case KEYPAD_PRESS_NONE:
  702. break;
  703. }
  704. gKeypadConfig.keypad_combokey_array[i].press_type = KEYPAD_PRESS_NONE;
  705. }
  706. }
  707. }//end for
  708. //check single key
  709. for(i = 0; i < gKeypadConfig.keyNum; i++)
  710. {
  711. if (gKeypadCtr.key_mapping_result.keymap_u16 & (1 << i))
  712. {
  713. if (!(gKeypadCtr.key_mapping_result_old.keymap_u16 & (1 << i)))
  714. {
  715. key_send_evt_to_Queue(i,KEYPAD_DOWN);
  716. if (gKeypadConfig.keypad_gpio_array[i].press_type == KEYPAD_PRESS_NONE)
  717. {
  718. gKeypadConfig.keypad_gpio_array[i].press_type = KEYPAD_PRESS_MULTI;
  719. gKeypadConfig.keypad_gpio_array[i].key_timer.cbParams = i;
  720. SYS_SetTimer(&gKeypadConfig.keypad_gpio_array[i].key_timer,
  721. gKeypadConfig.keypad_gpio_array[i].key_timer_cfg.multi_timer,
  722. TIMER_SINGLE,
  723. keypad_keyExpired);
  724. }
  725. }
  726. }
  727. else
  728. {
  729. if ((gKeypadCtr.key_mapping_result_old.keymap_u16 & (1 << i)))
  730. {
  731. //send release event;
  732. // printf("key %d is up\r\n",i);
  733. key_send_evt_to_Queue(i,KEYPAD_UP);
  734. if (gKeypadConfig.keypad_gpio_array[i].press_type == KEYPAD_PRESS_MULTI)
  735. {
  736. if (gKeypadConfig.keypad_gpio_array[i].key_timer.mTimerStatus == TIMER_START)
  737. {
  738. gKeypadCtr.key_multi_count++;
  739. }
  740. else
  741. {
  742. gKeypadConfig.keypad_gpio_array[i].press_type = KEYPAD_PRESS_NONE;
  743. }
  744. }
  745. else
  746. {
  747. SYS_ReleaseTimer(&gKeypadConfig.keypad_gpio_array[i].key_timer);
  748. switch(gKeypadConfig.keypad_gpio_array[i].press_type)
  749. {
  750. case KEYPAD_PRESS_PRESS:
  751. key_send_evt_to_Queue(i,KEYPAD_TAP);
  752. break;
  753. case KEYPAD_PRESS_LONG_PRESS:
  754. key_send_evt_to_Queue(i,KEYPAD_PRESS_RELEASE);
  755. break;
  756. case KEYPAD_PRESS_LONGLONG_PRESS:
  757. key_send_evt_to_Queue(i,KEYPAD_LONG_RELEASE);
  758. break;
  759. case KEYPAD_PRESS_EXTREME_LONG_PESS:
  760. key_send_evt_to_Queue(i,KEYPAD_LONGLONG_RELEASE);
  761. break;
  762. case KEYPAD_PRESS_NONE:
  763. break;
  764. }
  765. gKeypadConfig.keypad_gpio_array[i].press_type = KEYPAD_PRESS_NONE;
  766. }//end else
  767. }
  768. }//end else
  769. }//end for
  770. }
  771. //scan key pad
  772. void keypad_check_keypress(int params)
  773. {
  774. KEY_KEYMAP key_bitmap1,key_bitmap2;
  775. KEY_KEYMAP tempkey_bitmap1,tempkey_bitmap2;
  776. int while1;
  777. key_bitmap1.keymap_u16 = HREADW(CORE_GPIO_IN);
  778. key_bitmap2.keymap_u16 = HREADW(CORE_GPIO_IN+2);
  779. while1 = 100;
  780. while(while1--);
  781. tempkey_bitmap1.keymap_u16 = HREADW(CORE_GPIO_IN);
  782. tempkey_bitmap2.keymap_u16 = HREADW(CORE_GPIO_IN+2);
  783. if (tempkey_bitmap1.keymap_u16 != key_bitmap1.keymap_u16)
  784. return;
  785. //YC_LOG_ERROR("output %x,%x \n",key_bitmap1.keymap_u16,key_bitmap2.keymap_u16);
  786. keypad_gpio_mapping_process(key_bitmap1,key_bitmap2);
  787. keypad_keyevtScan();
  788. }
  789. void keypad_polling_keyQueue()
  790. {
  791. KEY_EVT_ELE *evt_ele;
  792. if (!queue_is_empty(&gEvtHeader))
  793. {
  794. evt_ele = (KEY_EVT_ELE *)Delete_Queue(&gEvtHeader);
  795. //YC_LOG_INFO("key index %d, key evt %d\r\n",evt_ele->key_ind,evt_ele->evt_type);
  796. gKeypadCtr.keypad_evt_callback(evt_ele->key_ind,evt_ele->evt_type);
  797. }
  798. }
  799. /**
  800. byte __attribute__((noinline, aligned(32))) HREAD(word reg)
  801. {
  802. return (*(volatile uint8_t *)(reg_map(reg)));
  803. }
  804. **/