FreeCalypso > hg > fc-tourmaline
diff src/cs/drivers/drv_app/kpd/board/kpd_scan_functions.c @ 280:82665effff30
keypad boot init overhaul: handle initially held-down keys
This change fixes two previous behavioural defects:
1) On Compal phones, the PWR key had to be released before the boot
sequence would proceed at all - it was stuck in an endless IRQ loop
at the point of Nucleus enabling interrupts, before anything else.
2) On both Compal and sane platforms including Luna, if some regular
non-PWR key was held down at boot time, the boot sequence would
proceed and complete normally, but all non-PWR keypad buttons would
be dead for the remainder of that boot cycle.
The fix is a generic solution - no Compal-specific hack ended up being
needed for the special case of their idiotic PWON-to-ROW4 hw wiring.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 24 Sep 2021 00:47:12 +0000 |
parents | 4dd30fac5933 |
children |
line wrap: on
line diff
--- a/src/cs/drivers/drv_app/kpd/board/kpd_scan_functions.c Thu Sep 23 23:42:41 2021 +0000 +++ b/src/cs/drivers/drv_app/kpd/board/kpd_scan_functions.c Fri Sep 24 00:47:12 2021 +0000 @@ -11,9 +11,9 @@ /* * History: * - * Date Author Modification + * Date Author Modification * ------------------------------------ - * 10/10/2001 L Sollier Create + * 10/10/2001 L Sollier Create * * * (C) Copyright 2001 by Texas Instruments Incorporated, All Rights Reserved @@ -274,6 +274,13 @@ #endif +/* + * FreeCalypso change: we remove keypad interrupt unmasking + * from this point in the boot process, and instead our call + * to kpd_wait_for_key_release() at the beginning of kpd_core() + * will unmask interrupts after getting to a clear state first. + */ +#if 0 /* Activate all outputs */ *(volatile UINT16*) KP_COL_OUT = KP_ALL_ON; @@ -285,6 +292,7 @@ #else IQ_Unmask (IQ_ARMIO); #endif +#endif }