From 3aa3ab3ca4be03139791d5513d148b05e423361b Mon Sep 17 00:00:00 2001 From: harbaum <> Date: Mon, 30 Jan 2006 20:21:51 +0000 Subject: [lcd4linux @ 2006-01-30 20:21:51 by harbaum] LCD2USB: Added support for displays with two controllers --- drv_LCD2USB.c | 59 ++++++++++++++++++++++++++++++++++------------------------- 1 file changed, 34 insertions(+), 25 deletions(-) diff --git a/drv_LCD2USB.c b/drv_LCD2USB.c index dc7f380..5dd8de4 100644 --- a/drv_LCD2USB.c +++ b/drv_LCD2USB.c @@ -1,4 +1,4 @@ -/* $Id: drv_LCD2USB.c,v 1.3 2006/01/30 06:25:52 reinelt Exp $ +/* $Id: drv_LCD2USB.c,v 1.4 2006/01/30 20:21:51 harbaum Exp $ * * driver for USB2LCD display interface * see http://www.harbaum.org/till/lcd2usb for schematics @@ -24,6 +24,9 @@ * * * $Log: drv_LCD2USB.c,v $ + * Revision 1.4 2006/01/30 20:21:51 harbaum + * LCD2USB: Added support for displays with two controllers + * * Revision 1.3 2006/01/30 06:25:52 reinelt * added CVS Revision * @@ -52,6 +55,7 @@ #include #include #include +#include #include #include @@ -79,9 +83,9 @@ #define LCD_GET (4<<5) /* target is a bit map for CMD/DATA */ -#define LCD_ENABLE0 (1<<3) -#define LCD_ENABLE1 (1<<4) -#define LCD_BOTH (LCD_ENABLE0 | LCD_ENABLE1) +#define LCD_CTRL_0 (1<<3) +#define LCD_CTRL_1 (1<<4) +#define LCD_BOTH (LCD_CTRL_0 | LCD_CTRL_1) /* target is value to set */ #define LCD_SET_CONTRAST (LCD_SET | (0<<3)) @@ -195,7 +199,7 @@ static void drv_L2U_flush(void) return; /* build request byte */ - request = buffer_current_type | LCD_ENABLE0 | (buffer_current_fill - 1); + request = buffer_current_type | (buffer_current_fill - 1); /* fill value and index with buffer contents. endianess should IMHO not */ /* be a problem, since usb_control_msg() will handle this. */ @@ -225,24 +229,29 @@ static void drv_L2U_enqueue(int command_type, int value) drv_L2U_flush(); } -static void drv_L2U_command(const unsigned char cmd) +static void drv_L2U_command(const unsigned char ctrl, const unsigned char cmd) { - drv_L2U_enqueue(LCD_CMD, cmd); + drv_L2U_enqueue(LCD_CMD | ctrl, cmd); } static void drv_L2U_clear(void) { - drv_L2U_command(0x01); /* clear display */ - drv_L2U_command(0x03); /* return home */ + drv_L2U_command(LCD_BOTH, 0x01); /* clear display */ + drv_L2U_command(LCD_BOTH, 0x03); /* return home */ } - -static void drv_L2U_write(const int row, const int col, const char *data, int len) +static void drv_L2U_write(int row, const int col, const char *data, int len) { - int pos; - -// printf("write %d/%d %s(%d)\n", row, col, data, len); + int pos, ctrl = LCD_CTRL_0; + + /* displays with more two rows and 20 columns have a logical width */ + /* of 40 chars and use more than one controller */ + if ((DROWS > 2) && (DCOLS > 20) && (row > 1)) { + /* use second controller */ + row -= 2; + ctrl = LCD_CTRL_1; + } /* 16x4 Displays use a slightly different layout */ if (DCOLS == 16 && DROWS == 4) { @@ -251,10 +260,10 @@ static void drv_L2U_write(const int row, const int col, const char *data, int le pos = (row % 2) * 64 + (row / 2) * 20 + col; } - drv_L2U_command(0x80 | pos); + drv_L2U_command(ctrl, 0x80 | pos); while (len--) { - drv_L2U_enqueue(LCD_DATA, *data++); + drv_L2U_enqueue(LCD_DATA | ctrl, *data++); } drv_L2U_flush(); @@ -264,10 +273,10 @@ static void drv_L2U_defchar(const int ascii, const unsigned char *matrix) { int i; - drv_L2U_command(0x40 | 8 * ascii); + drv_L2U_command(LCD_BOTH, 0x40 | 8 * ascii); for (i = 0; i < 8; i++) { - drv_L2U_enqueue(LCD_DATA, *matrix++ & 0x1f); + drv_L2U_enqueue(LCD_DATA | LCD_BOTH, *matrix++ & 0x1f); } drv_L2U_flush(); @@ -322,13 +331,13 @@ static int drv_L2U_start(const char *section, const int quiet) error("%s: could not find a LCD2USB USB LCD", Name); return -1; } - +#if 0 // already done by driver /* initialize display */ - drv_L2U_command(0x29); /* 8 Bit mode, 1/16 duty cycle, 5x8 font */ - drv_L2U_command(0x08); /* Display off, cursor off, blink off */ - drv_L2U_command(0x0c); /* Display on, cursor off, blink off */ - drv_L2U_command(0x06); /* curser moves to right, no shift */ - + drv_L2U_command(LCD_BOTH, 0x29); /* 8 Bit mode, 1/16 duty cycle, 5x8 fnt */ + drv_L2U_command(LCD_BOTH, 0x08); /* Display off, cursor off, blink off */ + drv_L2U_command(LCD_BOTH, 0x0c); /* Display on, cursor off, blink off */ + drv_L2U_command(LCD_BOTH, 0x06); /* curser moves to right, no shift */ +#endif if (cfg_number(section, "Contrast", 0, 0, 255, &contrast) > 0) { drv_L2U_contrast(contrast); @@ -405,7 +414,7 @@ int drv_L2U_init(const char *section, const int quiet) int asc255bug; int ret; - info("%s: %s", Name, "$Revision: 1.3 $"); + info("%s: %s", Name, "$Revision: 1.4 $"); /* display preferences */ XRES = 5; /* pixel width of one char */ -- cgit v1.2.3