summaryrefslogtreecommitdiff
path: root/recipes/linux/openzaurus-sa-2.4.18-rmk7-pxa3-embedix20030509/unb0rk-rightarrow.patch
blob: 42547ca27aaa1f0e536cdae638b57afc463e8f7b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
--- linux/arch/arm/mach-sa1100/collie_apm.c.orig	2005-06-25 22:49:51.842092545 +0200
+++ linux/arch/arm/mach-sa1100/collie_apm.c	2005-06-25 22:49:56.931171657 +0200
@@ -57,6 +57,7 @@
 #include <asm/arch/collie.h>
 #include <linux/ioctl.h>
 #include <asm/sharp_char.h>
+#include <asm/arch/keyboard_collie.h>
 #endif	// CONFIG_SA1100_COLLIE
 #include <asm/arch/power.h>
 
@@ -89,6 +90,8 @@
 int collie_get_on_mode;
 int idleCancel	    = 0;
 
+extern kbd_keyinfo sharppda_kbdstate[(NR_KEYCODES+1)];
+
 #endif	// CONFIG_SA1100_COLLIE
 
 
@@ -584,7 +587,7 @@
 
 	if (irq == IRQ_GPIO_ON_KEY) {	/* suspend */
 		//DPRINTK("irq=%d count=%d collie_suspend_request%d\n",irq, count, collie_suspend_request);
-		if ( GPLR & GPIO_ON_KEY ) {
+		if ( GPLR & GPIO_ON_KEY || (!sharppda_kbdstate[1].in)) { //1 is the hard keycode for Cancel. GPIO_ON_KEY is active for all 4 keys in that row (why? no idea.)
 			/* release */
 			count = 0;
 		} else {