aboutsummaryrefslogtreecommitdiffstats
path: root/drv_Crystalfontz.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--drv_Crystalfontz.c84
1 files changed, 73 insertions, 11 deletions
diff --git a/drv_Crystalfontz.c b/drv_Crystalfontz.c
index e179a15..e63d803 100644
--- a/drv_Crystalfontz.c
+++ b/drv_Crystalfontz.c
@@ -1,4 +1,4 @@
-/* $Id: drv_Crystalfontz.c,v 1.39 2006/02/19 15:37:38 reinelt Exp $
+/* $Id: drv_Crystalfontz.c,v 1.40 2006/02/21 05:50:34 reinelt Exp $
*
* new style driver for Crystalfontz display modules
*
@@ -23,6 +23,9 @@
*
*
* $Log: drv_Crystalfontz.c,v $
+ * Revision 1.40 2006/02/21 05:50:34 reinelt
+ * keypad support from Cris Maj
+ *
* Revision 1.39 2006/02/19 15:37:38 reinelt
* CF635 GPO patch from cmaj
*
@@ -200,10 +203,12 @@
#include "widget_text.h"
#include "widget_icon.h"
#include "widget_bar.h"
+#include "widget_keypad.h"
#include "drv.h"
#include "drv_generic_text.h"
#include "drv_generic_gpio.h"
#include "drv_generic_serial.h"
+#include "drv_generic_keypad.h"
static char Name[] = "Crystalfontz";
@@ -244,20 +249,22 @@ typedef struct {
int gpos;
int protocol;
int payload;
+ int keypadsize;
} MODEL;
/* Fixme #1: number of GPI's & GPO's should be verified */
/* Fixme #2: protocol should be verified */
+/* Fixme #3: number of keys on the keypad should be verified */
static MODEL Models[] = {
- {626, "626", 2, 16, 0, 0, 1, 0},
- {631, "631", 2, 20, 0, 0, 3, 22},
- {632, "632", 2, 16, 0, 0, 1, 0},
- {633, "633", 2, 16, 4, 4, 2, 18},
- {634, "634", 4, 20, 0, 0, 1, 0},
- {635, "635", 4, 20, 4, 12, 3, 22},
- {636, "636", 2, 16, 0, 0, 1, 0},
- {-1, "Unknown", -1, -1, 0, 0, 0, 0}
+ {626, "626", 2, 16, 0, 0, 1, 0, 0},
+ {631, "631", 2, 20, 0, 0, 3, 22, 4},
+ {632, "632", 2, 16, 0, 0, 1, 0, 0},
+ {633, "633", 2, 16, 4, 4, 2, 18, 6},
+ {634, "634", 4, 20, 0, 0, 1, 0, 0},
+ {635, "635", 4, 20, 0, 0, 3, 22, 6},
+ {636, "636", 2, 16, 0, 0, 1, 0, 0},
+ {-1, "Unknown", -1, -1, 0, 0, 0, 0, 0}
};
@@ -312,6 +319,7 @@ static void drv_CF_process_packet(void)
case 0x00:
/* Key Activity */
debug("Key Activity: %d", Packet.data[0]);
+ drv_generic_keypad_press(Packet.data[0]);
break;
case 0x01:
@@ -666,6 +674,52 @@ static int drv_CF_backlight(int backlight)
}
+static int drv_CF_keypad(const int num)
+{
+ int val = 0;
+
+ switch (Protocol) {
+ case 1:
+ case 2:
+ break;
+ case 3:
+ if (num < 8)
+ val = KEY_PRESSED;
+ else
+ val = KEY_RELEASED;
+ switch (num) {
+ case 1:
+ case 8:
+ val += KEY_UP;
+ break;
+ case 2:
+ case 9:
+ val += KEY_DOWN;
+ break;
+ case 3:
+ case 10:
+ val += KEY_LEFT;
+ break;
+ case 4:
+ case 11:
+ val += KEY_RIGHT;
+ break;
+ case 5:
+ case 12:
+ val += KEY_CONFIRM;
+ break;
+ case 7:
+ case 13:
+ val += KEY_CANCEL;
+ break;
+ }
+ break;
+ }
+
+ return val;
+}
+
+
static int drv_CF_GPI(const int num)
{
if (num < 0 || num > 3) {
@@ -677,7 +731,7 @@ static int drv_CF_GPI(const int num)
static int drv_CF_GPO(const int num, const int val)
{
- static unsigned char PWM2[4] = { 0, 0, 0, 0};
+ static unsigned char PWM2[4] = { 0, 0, 0, 0 };
static unsigned char PWM3[2];
int v = val;
@@ -931,6 +985,7 @@ static int drv_CF_start(const char *section)
GPOS = Models[Model].gpos;
Protocol = Models[Model].protocol;
Payload = Models[Model].payload;
+ KEYPADSIZE = Models[Model].keypadsize;
switch (Protocol) {
@@ -1027,6 +1082,7 @@ static void plugin_backlight(RESULT * result, const int argc, RESULT * argv[])
/* using drv_generic_text_icon_draw(W) */
/* using drv_generic_text_bar_draw(W) */
/* using drv_generic_gpio_draw(W) */
+/* using drv_generic_keypad_draw(W) */
/****************************************/
@@ -1052,7 +1108,7 @@ int drv_CF_init(const char *section, const int quiet)
WIDGET_CLASS wc;
int ret;
- info("%s: %s", Name, "$Revision: 1.39 $");
+ info("%s: %s", Name, "$Revision: 1.40 $");
/* start display */
if ((ret = drv_CF_start(section)) != 0) {
@@ -1087,6 +1143,7 @@ int drv_CF_init(const char *section, const int quiet)
drv_generic_text_real_defchar = drv_CF_defchar23;
drv_generic_gpio_real_get = drv_CF_GPI;
drv_generic_gpio_real_set = drv_CF_GPO;
+ drv_generic_keypad_real_press = drv_CF_keypad;
break;
}
@@ -1120,6 +1177,10 @@ int drv_CF_init(const char *section, const int quiet)
if ((ret = drv_generic_gpio_init(section, Name)) != 0)
return ret;
+ /* initialize generic key pad driver */
+ if ((ret = drv_generic_keypad_init(section, Name)) != 0)
+ return ret;
+
/* register text widget */
wc = Widget_Text;
wc.draw = drv_generic_text_draw;
@@ -1151,6 +1212,7 @@ int drv_CF_quit(const int quiet)
drv_generic_text_quit();
drv_generic_gpio_quit();
+ drv_generic_keypad_quit();
/* clear display */
drv_CF_clear();