summaryrefslogtreecommitdiff
path: root/meta-moblin/packages/linux/linux-moblin-2.6.29.1/linux-2.6.29-touchkit.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta-moblin/packages/linux/linux-moblin-2.6.29.1/linux-2.6.29-touchkit.patch')
-rw-r--r--meta-moblin/packages/linux/linux-moblin-2.6.29.1/linux-2.6.29-touchkit.patch130
1 files changed, 130 insertions, 0 deletions
diff --git a/meta-moblin/packages/linux/linux-moblin-2.6.29.1/linux-2.6.29-touchkit.patch b/meta-moblin/packages/linux/linux-moblin-2.6.29.1/linux-2.6.29-touchkit.patch
new file mode 100644
index 000000000..92e71fa31
--- /dev/null
+++ b/meta-moblin/packages/linux/linux-moblin-2.6.29.1/linux-2.6.29-touchkit.patch
@@ -0,0 +1,130 @@
+diff --git a/drivers/input/mouse/psmouse-base.c b/drivers/input/mouse/psmouse-base.c
+index f8f86de..5d4cea2 100644
+--- a/drivers/input/mouse/psmouse-base.c
++++ b/drivers/input/mouse/psmouse-base.c
+@@ -676,6 +676,9 @@ static int psmouse_extensions(struct psmouse *psmouse,
+
+ if (touchkit_ps2_detect(psmouse, set_properties) == 0)
+ return PSMOUSE_TOUCHKIT_PS2;
++
++ if (elftouch_ps2_detect(psmouse, set_properties) == 0)
++ return PSMOUSE_ELFTOUCH_PS2;
+ }
+
+ /*
+@@ -786,6 +789,12 @@ static const struct psmouse_protocol psmouse_protocols[] = {
+ .alias = "trackpoint",
+ .detect = trackpoint_detect,
+ },
++ {
++ .type = PSMOUSE_ELFTOUCH_PS2,
++ .name = "elftouchPS2",
++ .alias = "elftouch",
++ .detect = elftouch_ps2_detect,
++ },
+ #endif
+ #ifdef CONFIG_MOUSE_PS2_TOUCHKIT
+ {
+diff --git a/drivers/input/mouse/psmouse.h b/drivers/input/mouse/psmouse.h
+index 54ed267..8d1ba79 100644
+--- a/drivers/input/mouse/psmouse.h
++++ b/drivers/input/mouse/psmouse.h
+@@ -89,6 +89,7 @@ enum psmouse_type {
+ PSMOUSE_TRACKPOINT,
+ PSMOUSE_TOUCHKIT_PS2,
+ PSMOUSE_CORTRON,
++ PSMOUSE_ELFTOUCH_PS2,
+ PSMOUSE_HGPK,
+ PSMOUSE_ELANTECH,
+ PSMOUSE_AUTO /* This one should always be last */
+diff --git a/drivers/input/mouse/touchkit_ps2.c b/drivers/input/mouse/touchkit_ps2.c
+index 3fadb2a..e9c27f1 100644
+--- a/drivers/input/mouse/touchkit_ps2.c
++++ b/drivers/input/mouse/touchkit_ps2.c
+@@ -51,6 +51,11 @@
+ #define TOUCHKIT_GET_X(packet) (((packet)[1] << 7) | (packet)[2])
+ #define TOUCHKIT_GET_Y(packet) (((packet)[3] << 7) | (packet)[4])
+
++#define ELFTOUCH_MAX_XC 0x0fff
++#define ELFTOUCH_MAX_YC 0x0fff
++#define ELFTOUCH_GET_X(packet) (((packet)[3] << 7) | (packet)[4])
++#define ELFTOUCH_GET_Y(packet) (((packet)[1] << 7) | (packet)[2])
++
+ static psmouse_ret_t touchkit_ps2_process_byte(struct psmouse *psmouse)
+ {
+ unsigned char *packet = psmouse->packet;
+@@ -59,9 +64,15 @@ static psmouse_ret_t touchkit_ps2_process_byte(struct psmouse *psmouse)
+ if (psmouse->pktcnt != 5)
+ return PSMOUSE_GOOD_DATA;
+
+- input_report_abs(dev, ABS_X, TOUCHKIT_GET_X(packet));
+- input_report_abs(dev, ABS_Y, TOUCHKIT_GET_Y(packet));
++ if(psmouse->type==PSMOUSE_ELFTOUCH_PS2) {
++ input_report_abs(dev, ABS_X, ELFTOUCH_GET_X(packet));
++ input_report_abs(dev, ABS_Y, ELFTOUCH_GET_Y(packet));
++ } else {
++ input_report_abs(dev, ABS_X, TOUCHKIT_GET_X(packet));
++ input_report_abs(dev, ABS_Y, TOUCHKIT_GET_Y(packet));
++ }
+ input_report_key(dev, BTN_TOUCH, TOUCHKIT_GET_TOUCHED(packet));
++
+ input_sync(dev);
+
+ return PSMOUSE_FULL_PACKET;
+@@ -98,3 +109,33 @@ int touchkit_ps2_detect(struct psmouse *psmouse, int set_properties)
+
+ return 0;
+ }
++
++int elftouch_ps2_detect(struct psmouse *psmouse, int set_properties)
++{
++ struct input_dev *dev = psmouse->dev;
++ unsigned char param[16];
++ int command, res;
++
++ param[0]=0x0f4;
++ command = TOUCHKIT_SEND_PARMS(1, 0, TOUCHKIT_CMD);
++ res=ps2_command(&psmouse->ps2dev, param, command);
++ if(res) { return -ENODEV; }
++
++ param[0]=0x0b0;
++ command = TOUCHKIT_SEND_PARMS(1, 1, TOUCHKIT_CMD);
++ res=ps2_command(&psmouse->ps2dev, param, command);
++ if(res) { return -ENODEV; }
++
++ if (set_properties) {
++ dev->evbit[0] = BIT_MASK(EV_KEY) | BIT_MASK(EV_ABS);
++ set_bit(BTN_TOUCH, dev->keybit);
++ input_set_abs_params(dev, ABS_X, 0, ELFTOUCH_MAX_XC, 0, 0);
++ input_set_abs_params(dev, ABS_Y, 0, ELFTOUCH_MAX_YC, 0, 0);
++
++ psmouse->vendor = "ElfTouch";
++ psmouse->name = "Touchscreen";
++ psmouse->protocol_handler = touchkit_ps2_process_byte;
++ psmouse->pktsize = 5;
++ }
++ return 0;
++}
+diff --git a/drivers/input/mouse/touchkit_ps2.h b/drivers/input/mouse/touchkit_ps2.h
+index 8a0dd35..f32ef4c 100644
+--- a/drivers/input/mouse/touchkit_ps2.h
++++ b/drivers/input/mouse/touchkit_ps2.h
+@@ -14,12 +14,18 @@
+
+ #ifdef CONFIG_MOUSE_PS2_TOUCHKIT
+ int touchkit_ps2_detect(struct psmouse *psmouse, int set_properties);
++int elftouch_ps2_detect(struct psmouse *psmouse, int set_properties);
+ #else
+ static inline int touchkit_ps2_detect(struct psmouse *psmouse,
+ int set_properties)
+ {
+ return -ENOSYS;
+ }
++static inline int elftouch_ps2_detect(struct psmouse *psmouse,
++ int set_properties)
++{
++ return -ENOSYS;
++}
+ #endif /* CONFIG_MOUSE_PS2_TOUCHKIT */
+
+ #endif