summaryrefslogtreecommitdiff
path: root/firmware/target/arm/imx233/creative-zenxfi2/button-zenxfi2.c
diff options
context:
space:
mode:
authorJean-Louis Biasini <jlbiasini@gmail.com>2013-09-02 11:03:56 +0200
committerAmaury Pouly <amaury.pouly@gmail.com>2013-09-05 20:02:07 +0200
commitdf6eb82f5156256e1999374ce9b1a159610ff9a0 (patch)
treeec79d078c7deaba74ad0b83d6dc48c3776e8f7f0 /firmware/target/arm/imx233/creative-zenxfi2/button-zenxfi2.c
parentef2dd06d5ee7415684f45afadad6deaf0fb0c615 (diff)
downloadrockbox-df6eb82f5156256e1999374ce9b1a159610ff9a0.tar.gz
rockbox-df6eb82f5156256e1999374ce9b1a159610ff9a0.zip
touch devices: Disable touch on softlock.
Target that have a touchpad/touchscreen should disable it while being locked (In order to avoid LCD to drain battery power due to "key locked" constant reporting messages. If they a have a keylock button this was already handled at driver level. If not (e.g. fuze+), they will have to implement a switch at driver level that action.c can operate on softlock. This patch does the following for any target having a touchpad or a touchscreen and no HAS_BUTTON_HOLD (ie any softlock target) 1) it implements the code to call button_enable_touch(bool en) in action.c. 2) button_enable_touch is implemented in button.c and call either touchpad_enable or touchscreen_enable 3) those two function are implemented respectively in touchscreen.c and a new touchpad.c file. They provide a generic way to silents touch's device and call a function at driver level where target specific code can be implemented if possible/needed (for power saving for instance). Those function name are touchpad_enable_device and touchscreen_enable_device 4) we implement an empty function at driver level of targets that need it to have them still being able to compiled. Change-Id: I9ead78a25bd33466a8533f5b9f259b395cb5ce49 Reviewed-on: http://gerrit.rockbox.org/569 Reviewed-by: Thomas Martitz <kugel@rockbox.org> Reviewed-by: Amaury Pouly <amaury.pouly@gmail.com>
Diffstat (limited to 'firmware/target/arm/imx233/creative-zenxfi2/button-zenxfi2.c')
-rw-r--r--firmware/target/arm/imx233/creative-zenxfi2/button-zenxfi2.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/firmware/target/arm/imx233/creative-zenxfi2/button-zenxfi2.c b/firmware/target/arm/imx233/creative-zenxfi2/button-zenxfi2.c
index 74b8d649b3..4f2a2775bf 100644
--- a/firmware/target/arm/imx233/creative-zenxfi2/button-zenxfi2.c
+++ b/firmware/target/arm/imx233/creative-zenxfi2/button-zenxfi2.c
@@ -66,7 +66,7 @@ void button_init_device(void)
66 66
67 bottomright.px_x = LCD_WIDTH; 67 bottomright.px_x = LCD_WIDTH;
68 bottomright.px_y = LCD_HEIGHT; 68 bottomright.px_y = LCD_HEIGHT;
69 69
70 imx233_touchscreen_init(); 70 imx233_touchscreen_init();
71 imx233_touchscreen_enable(true); 71 imx233_touchscreen_enable(true);
72 72
@@ -104,6 +104,11 @@ static int touch_to_pixels(int *val_x, int *val_y)
104 return (x<<16)|y; 104 return (x<<16)|y;
105} 105}
106 106
107void touchscreen_enable_device(bool en)
108{
109 imx233_touchscreen_enable(en);
110}
111
107static int touchscreen_read_device(int *data) 112static int touchscreen_read_device(int *data)
108{ 113{
109 int x, y; 114 int x, y;