aboutsummaryrefslogtreecommitdiffstats
path: root/drv_Cwlinux.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--drv_Cwlinux.c496
1 files changed, 252 insertions, 244 deletions
diff --git a/drv_Cwlinux.c b/drv_Cwlinux.c
index 1088a8a..cb1fa41 100644
--- a/drv_Cwlinux.c
+++ b/drv_Cwlinux.c
@@ -1,4 +1,4 @@
-/* $Id: drv_Cwlinux.c,v 1.21 2005/01/18 06:30:22 reinelt Exp $
+/* $Id: drv_Cwlinux.c,v 1.22 2005/05/08 04:32:44 reinelt Exp $
*
* new style driver for Cwlinux display modules
*
@@ -23,6 +23,9 @@
*
*
* $Log: drv_Cwlinux.c,v $
+ * Revision 1.22 2005/05/08 04:32:44 reinelt
+ * CodingStyle added and applied
+ *
* Revision 1.21 2005/01/18 06:30:22 reinelt
* added (C) to all copyright statements
*
@@ -146,7 +149,7 @@
#include "drv_generic_serial.h"
-static char Name[]="Cwlinux";
+static char Name[] = "Cwlinux";
static int Model;
static int Protocol;
@@ -157,22 +160,22 @@ static int GPOS;
typedef struct {
- int type;
- char *name;
- int rows;
- int cols;
- int xres;
- int gpos;
- int protocol;
+ int type;
+ char *name;
+ int rows;
+ int cols;
+ int xres;
+ int gpos;
+ int protocol;
} MODEL;
/* Fixme: number of gpo's should be verified */
static MODEL Models[] = {
- { 0x01, "CW1602", 2, 16, 5, 0, 1 },
- { 0x02, "CW12232", 4, 20, 6, 0, 2 },
- { 0xff, "Unknown", -1, -1, -1, -1, -1 }
+ {0x01, "CW1602", 2, 16, 5, 0, 1},
+ {0x02, "CW12232", 4, 20, 6, 0, 2},
+ {0xff, "Unknown", -1, -1, -1, -1, -1}
};
@@ -180,165 +183,170 @@ static MODEL Models[] = {
/*** hardware dependant functions ***/
/****************************************/
-static void drv_CW_send (const char *string, const int len)
+static void drv_CW_send(const char *string, const int len)
{
- drv_generic_serial_write (string, len);
- usleep (20);
+ drv_generic_serial_write(string, len);
+ usleep(20);
}
-static void drv_CW_write (const int row, const int col, const char *data, const int len)
+static void drv_CW_write(const int row, const int col, const char *data, const int len)
{
- char cmd[6]="\376Gxy\375";
-
- cmd[2]=(char)col;
- cmd[3]=(char)row;
- drv_CW_send (cmd, 5);
- drv_CW_send (data, len);
+ char cmd[6] = "\376Gxy\375";
+
+ cmd[2] = (char) col;
+ cmd[3] = (char) row;
+ drv_CW_send(cmd, 5);
+ drv_CW_send(data, len);
}
-static void drv_CW1602_defchar (const int ascii, const unsigned char *buffer)
+static void drv_CW1602_defchar(const int ascii, const unsigned char *buffer)
{
- int i;
- char cmd[12]="\376Nn12345678\375";
+ int i;
+ char cmd[12] = "\376Nn12345678\375";
- cmd[2]=(char)ascii;
+ cmd[2] = (char) ascii;
- for (i=0; i<8; i++) {
- cmd[3+i] = buffer[i] & 0x1f;
- }
- drv_CW_send(cmd,12);
+ for (i = 0; i < 8; i++) {
+ cmd[3 + i] = buffer[i] & 0x1f;
+ }
+ drv_CW_send(cmd, 12);
}
-static void drv_CW12232_defchar (const int ascii, const unsigned char *buffer)
+static void drv_CW12232_defchar(const int ascii, const unsigned char *buffer)
{
- int i, j;
- char cmd[10]="\376Nn123456\375";
-
- cmd[2]=(char)ascii;
-
- /* The CW12232 uses a vertical bitmap layout, */
- /* so we have to 'rotate' the bitmap. */
-
- for (i=0; i<6;i++) {
- cmd[3+i]=0;
- for (j=0; j<8;j++) {
- if (buffer[j] & (1<<(5-i))) {
- cmd[3+i]|=(1<<j);
- }
+ int i, j;
+ char cmd[10] = "\376Nn123456\375";
+
+ cmd[2] = (char) ascii;
+
+ /* The CW12232 uses a vertical bitmap layout, */
+ /* so we have to 'rotate' the bitmap. */
+
+ for (i = 0; i < 6; i++) {
+ cmd[3 + i] = 0;
+ for (j = 0; j < 8; j++) {
+ if (buffer[j] & (1 << (5 - i))) {
+ cmd[3 + i] |= (1 << j);
+ }
+ }
}
- }
- drv_CW_send (cmd, 10);
+ drv_CW_send(cmd, 10);
}
-static void drv_CW_clear (void)
+static void drv_CW_clear(void)
{
#if 1
- drv_CW_send("\376X\375",3); /* Clear Display */
- usleep(500000);
+ drv_CW_send("\376X\375", 3); /* Clear Display */
+ usleep(500000);
#else
- /* for some mysterious reason, we have to sleep after */
- /* the command _and_ after the CMD_END... */
- drv_CW_send("\376X",2); /* Clear Display */
- drv_CW_send("\375",1); /* Command End */
+ /* for some mysterious reason, we have to sleep after */
+ /* the command _and_ after the CMD_END... */
+ drv_CW_send("\376X", 2); /* Clear Display */
+ drv_CW_send("\375", 1); /* Command End */
#endif
}
-static int drv_CW_brightness (int brightness)
+static int drv_CW_brightness(int brightness)
{
- static unsigned char Brightness = 0;
- char cmd[5] = "\376A_\375";
-
- /* -1 is used to query the current brightness */
- if (brightness == -1) return Brightness;
-
- if (brightness < 0 ) brightness = 0;
- if (brightness > 255) brightness = 255;
- Brightness = brightness;
-
- switch (Brightness) {
- case 0:
- /* backlight off */
- drv_CW_send ("\376F\375", 3);
- break;
- case 8:
- /* backlight on */
- drv_CW_send ("\376B\375", 3);
- break;
- default:
- /* backlight level */
- cmd[2] = (char)Brightness;
- drv_CW_send (cmd, 4);
- break;
- }
-
- return Brightness;
+ static unsigned char Brightness = 0;
+ char cmd[5] = "\376A_\375";
+
+ /* -1 is used to query the current brightness */
+ if (brightness == -1)
+ return Brightness;
+
+ if (brightness < 0)
+ brightness = 0;
+ if (brightness > 255)
+ brightness = 255;
+ Brightness = brightness;
+
+ switch (Brightness) {
+ case 0:
+ /* backlight off */
+ drv_CW_send("\376F\375", 3);
+ break;
+ case 8:
+ /* backlight on */
+ drv_CW_send("\376B\375", 3);
+ break;
+ default:
+ /* backlight level */
+ cmd[2] = (char) Brightness;
+ drv_CW_send(cmd, 4);
+ break;
+ }
+
+ return Brightness;
}
-static int drv_CW_start (const char *section)
+static int drv_CW_start(const char *section)
{
- int i;
- char *model;
-
- model=cfg_get(section, "Model", NULL);
- if (model!=NULL && *model!='\0') {
- for (i=0; Models[i].type!=0xff; i++) {
- if (strcasecmp(Models[i].name, model)==0) break;
- }
- if (Models[i].type==0xff) {
- error ("%s: %s.Model '%s' is unknown from %s", Name, section, model, cfg_source());
- return -1;
+ int i;
+ char *model;
+
+ model = cfg_get(section, "Model", NULL);
+ if (model != NULL && *model != '\0') {
+ for (i = 0; Models[i].type != 0xff; i++) {
+ if (strcasecmp(Models[i].name, model) == 0)
+ break;
+ }
+ if (Models[i].type == 0xff) {
+ error("%s: %s.Model '%s' is unknown from %s", Name, section, model, cfg_source());
+ return -1;
+ }
+ Model = i;
+ info("%s: using model '%s'", Name, Models[Model].name);
+ } else {
+ error("%s: no '%s.Model' entry from %s", Name, section, cfg_source());
+ return -1;
}
- Model=i;
- info ("%s: using model '%s'", Name, Models[Model].name);
- } else {
- error ("%s: no '%s.Model' entry from %s", Name, section, cfg_source());
- return -1;
- }
-
- /* open serial port */
- if (drv_generic_serial_open(section, Name, 0) < 0) return -1;
-
- /* this does not work as I'd expect it... */
+
+ /* open serial port */
+ if (drv_generic_serial_open(section, Name, 0) < 0)
+ return -1;
+
+ /* this does not work as I'd expect it... */
#if 0
- /* read firmware version */
- generic_serial_read(buffer,sizeof(buffer));
- usleep(100000);
- generic_serial_write ("\3761", 2);
- usleep(100000);
- generic_serial_write ("\375", 1);
- usleep(100000);
- if (generic_serial_read(buffer,2)!=2) {
- info ("unable to read firmware version!");
- }
- info ("Cwlinux Firmware %d.%d", (int)buffer[0], (int)buffer[1]);
+ /* read firmware version */
+ generic_serial_read(buffer, sizeof(buffer));
+ usleep(100000);
+ generic_serial_write("\3761", 2);
+ usleep(100000);
+ generic_serial_write("\375", 1);
+ usleep(100000);
+ if (generic_serial_read(buffer, 2) != 2) {
+ info("unable to read firmware version!");
+ }
+ info("Cwlinux Firmware %d.%d", (int) buffer[0], (int) buffer[1]);
#endif
- /* initialize global variables */
- DROWS = Models[Model].rows;
- DCOLS = Models[Model].cols;
- XRES = Models[Model].xres;
- GPOS = Models[Model].gpos;
- Protocol = Models[Model].protocol;
+ /* initialize global variables */
+ DROWS = Models[Model].rows;
+ DCOLS = Models[Model].cols;
+ XRES = Models[Model].xres;
+ GPOS = Models[Model].gpos;
+ Protocol = Models[Model].protocol;
- drv_CW_clear();
+ drv_CW_clear();
- drv_CW_send ("\376D\375", 3); /* auto line wrap off */
- drv_CW_send ("\376R\375", 3); /* auto scroll off */
- drv_CW_send ("\376K\375", 3); /* underline cursor off */
- drv_CW_send ("\376B\375", 3); /* backlight on */
+ drv_CW_send("\376D\375", 3); /* auto line wrap off */
+ drv_CW_send("\376R\375", 3); /* auto scroll off */
+ drv_CW_send("\376K\375", 3); /* underline cursor off */
+ drv_CW_send("\376B\375", 3); /* backlight on */
- /* set brightness */
- if (cfg_number(section, "Brightness", 0, 0, 8, &i) > 0) {
- drv_CW_brightness(i);
- }
+ /* set brightness */
+ if (cfg_number(section, "Brightness", 0, 0, 8, &i) > 0) {
+ drv_CW_brightness(i);
+ }
- return 0;
+ return 0;
}
@@ -347,23 +355,23 @@ static int drv_CW_start (const char *section)
/****************************************/
-static void plugin_brightness (RESULT *result, const int argc, RESULT *argv[])
+static void plugin_brightness(RESULT * result, const int argc, RESULT * argv[])
{
- double brightness;
-
- switch (argc) {
- case 0:
- brightness = drv_CW_brightness(-1);
- SetResult(&result, R_NUMBER, &brightness);
- break;
- case 1:
- brightness = drv_CW_brightness(R2N(argv[0]));
- SetResult(&result, R_NUMBER, &brightness);
- break;
- default:
- error ("%s.brightness(): wrong number of parameters", Name);
- SetResult(&result, R_STRING, "");
- }
+ double brightness;
+
+ switch (argc) {
+ case 0:
+ brightness = drv_CW_brightness(-1);
+ SetResult(&result, R_NUMBER, &brightness);
+ break;
+ case 1:
+ brightness = drv_CW_brightness(R2N(argv[0]));
+ SetResult(&result, R_NUMBER, &brightness);
+ break;
+ default:
+ error("%s.brightness(): wrong number of parameters", Name);
+ SetResult(&result, R_STRING, "");
+ }
}
@@ -382,117 +390,117 @@ static void plugin_brightness (RESULT *result, const int argc, RESULT *argv[])
/* list models */
-int drv_CW_list (void)
+int drv_CW_list(void)
{
- int i;
-
- for (i=0; Models[i].type!=0xff; i++) {
- printf ("%s ", Models[i].name);
- }
- return 0;
+ int i;
+
+ for (i = 0; Models[i].type != 0xff; i++) {
+ printf("%s ", Models[i].name);
+ }
+ return 0;
}
/* initialize driver & display */
-int drv_CW_init (const char *section, const int quiet)
+int drv_CW_init(const char *section, const int quiet)
{
- WIDGET_CLASS wc;
- int ret;
-
- /* display preferences */
- XRES = 6; /* pixel width of one char */
- YRES = 8; /* pixel height of one char */
- CHARS = 16; /* number of user-defineable characters */
- CHAR0 = 1; /* ASCII of first user-defineable char */
- GOTO_COST = 3; /* number of bytes a goto command requires */
- INVALIDATE = 1; /* re-defined chars must be re-sent to the display */
-
- /* start display */
- if ((ret=drv_CW_start (section))!=0)
- return ret;
-
- /* real worker functions */
- drv_generic_text_real_write = drv_CW_write;
-
- switch (Protocol) {
+ WIDGET_CLASS wc;
+ int ret;
+
+ /* display preferences */
+ XRES = 6; /* pixel width of one char */
+ YRES = 8; /* pixel height of one char */
+ CHARS = 16; /* number of user-defineable characters */
+ CHAR0 = 1; /* ASCII of first user-defineable char */
+ GOTO_COST = 3; /* number of bytes a goto command requires */
+ INVALIDATE = 1; /* re-defined chars must be re-sent to the display */
+
+ /* start display */
+ if ((ret = drv_CW_start(section)) != 0)
+ return ret;
+
+ /* real worker functions */
+ drv_generic_text_real_write = drv_CW_write;
+
+ switch (Protocol) {
case 1:
- drv_generic_text_real_defchar = drv_CW1602_defchar;
- break;
+ drv_generic_text_real_defchar = drv_CW1602_defchar;
+ break;
case 2:
- drv_generic_text_real_defchar = drv_CW12232_defchar;
- break;
- }
-
- if (!quiet) {
- char buffer[40];
- qprintf(buffer, sizeof(buffer), "%s %s", Name, Models[Model].name);
- if (drv_generic_text_greet (buffer, "www.cwlinux.com")) {
- sleep (3);
- drv_CW_clear();
+ drv_generic_text_real_defchar = drv_CW12232_defchar;
+ break;
+ }
+
+ if (!quiet) {
+ char buffer[40];
+ qprintf(buffer, sizeof(buffer), "%s %s", Name, Models[Model].name);
+ if (drv_generic_text_greet(buffer, "www.cwlinux.com")) {
+ sleep(3);
+ drv_CW_clear();
+ }
}
- }
-
- /* initialize generic text driver */
- if ((ret=drv_generic_text_init(section, Name))!=0)
- return ret;
-
- /* initialize generic icon driver */
- if ((ret=drv_generic_text_icon_init())!=0)
- return ret;
-
- /* initialize generic bar driver */
- if ((ret=drv_generic_text_bar_init(0))!=0)
- return ret;
-
- /* add fixed chars to the bar driver */
- drv_generic_text_bar_add_segment (0, 0, 255, 32); /* ASCII 32 = blank */
-
- /* register text widget */
- wc=Widget_Text;
- wc.draw=drv_generic_text_draw;
- widget_register(&wc);
-
- /* register icon widget */
- wc=Widget_Icon;
- wc.draw=drv_generic_text_icon_draw;
- widget_register(&wc);
-
- /* register bar widget */
- wc=Widget_Bar;
- wc.draw=drv_generic_text_bar_draw;
- widget_register(&wc);
-
- /* register plugins */
- AddFunction ("LCD::brightness", -1, plugin_brightness);
-
- return 0;
+
+ /* initialize generic text driver */
+ if ((ret = drv_generic_text_init(section, Name)) != 0)
+ return ret;
+
+ /* initialize generic icon driver */
+ if ((ret = drv_generic_text_icon_init()) != 0)
+ return ret;
+
+ /* initialize generic bar driver */
+ if ((ret = drv_generic_text_bar_init(0)) != 0)
+ return ret;
+
+ /* add fixed chars to the bar driver */
+ drv_generic_text_bar_add_segment(0, 0, 255, 32); /* ASCII 32 = blank */
+
+ /* register text widget */
+ wc = Widget_Text;
+ wc.draw = drv_generic_text_draw;
+ widget_register(&wc);
+
+ /* register icon widget */
+ wc = Widget_Icon;
+ wc.draw = drv_generic_text_icon_draw;
+ widget_register(&wc);
+
+ /* register bar widget */
+ wc = Widget_Bar;
+ wc.draw = drv_generic_text_bar_draw;
+ widget_register(&wc);
+
+ /* register plugins */
+ AddFunction("LCD::brightness", -1, plugin_brightness);
+
+ return 0;
}
/* close driver & display */
-int drv_CW_quit (const int quiet) {
-
- info("%s: shutting down.", Name);
- drv_generic_text_quit();
-
- /* clear display */
- drv_CW_clear();
-
- /* say goodbye... */
- if (!quiet) {
- drv_generic_text_greet ("goodbye!", NULL);
- }
-
- drv_generic_serial_close();
-
- return (0);
+int drv_CW_quit(const int quiet)
+{
+
+ info("%s: shutting down.", Name);
+ drv_generic_text_quit();
+
+ /* clear display */
+ drv_CW_clear();
+
+ /* say goodbye... */
+ if (!quiet) {
+ drv_generic_text_greet("goodbye!", NULL);
+ }
+
+ drv_generic_serial_close();
+
+ return (0);
}
DRIVER drv_Cwlinux = {
- name: Name,
- list: drv_CW_list,
- init: drv_CW_init,
- quit: drv_CW_quit,
+ name:Name,
+ list:drv_CW_list,
+ init:drv_CW_init,
+ quit:drv_CW_quit,
};
-