From 56f2f2dfee6fc256628f2222a4f4335e2e2b1579 Mon Sep 17 00:00:00 2001 From: reinelt <> Date: Sun, 21 Sep 2003 06:43:02 +0000 Subject: [lcd4linux @ 2003-09-21 06:43:02 by reinelt] MatrixOrbital: bidirectional communication HD44780: special handling for 16x1 displays (thanks to anonymous bug report on sf.net) --- HD44780.c | 21 ++++++++++++++++++++- MatrixOrbital.c | 52 +++++++++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 71 insertions(+), 2 deletions(-) diff --git a/HD44780.c b/HD44780.c index d26ebde..df8dce9 100644 --- a/HD44780.c +++ b/HD44780.c @@ -1,4 +1,4 @@ -/* $Id: HD44780.c,v 1.41 2003/09/13 06:20:39 reinelt Exp $ +/* $Id: HD44780.c,v 1.42 2003/09/21 06:43:02 reinelt Exp $ * * driver for display modules based on the HD44780 chip * @@ -27,6 +27,12 @@ * * * $Log: HD44780.c,v $ + * Revision 1.42 2003/09/21 06:43:02 reinelt + * + * + * MatrixOrbital: bidirectional communication + * HD44780: special handling for 16x1 displays (thanks to anonymous bug report on sf.net) + * * Revision 1.41 2003/09/13 06:20:39 reinelt * HD44780 timings changed; deactivated libtool * @@ -342,6 +348,9 @@ static void HD_write (unsigned char controller, char *string, int len, int delay { unsigned char enable; + // sanity check + if (len<=0) return; + if (Bits==8) { // enable signal: 'controller' is a bitmask @@ -549,6 +558,12 @@ void HD_goto (int row, int col) Controller = 1; } + // 16x1 Displays are organized as 8x2 :-( + if (Lcd.rows==1 && Lcd.cols==16 && col>7) { + row++; + col-=8; + } + pos=(row%2)*64+(row/2)*20+col; HD_command (Controller, (0x80|pos), T_EXEC); } @@ -619,6 +634,10 @@ int HD_flush (void) pos2=col; equal=0; } + // special handling of 16x1 displays + if (Lcd.rows==1 && Lcd.cols==16 && col==7) { + break; + } } HD_write (Controller, FrameBuffer1+row*Lcd.cols+pos1, pos2-pos1+1, T_EXEC); } diff --git a/MatrixOrbital.c b/MatrixOrbital.c index 1ce3b2b..b25bc37 100644 --- a/MatrixOrbital.c +++ b/MatrixOrbital.c @@ -1,4 +1,4 @@ -/* $Id: MatrixOrbital.c,v 1.41 2003/09/13 06:45:43 reinelt Exp $ +/* $Id: MatrixOrbital.c,v 1.42 2003/09/21 06:43:02 reinelt Exp $ * * driver for Matrix Orbital serial display modules * @@ -20,6 +20,12 @@ * * * $Log: MatrixOrbital.c,v $ + * Revision 1.42 2003/09/21 06:43:02 reinelt + * + * + * MatrixOrbital: bidirectional communication + * HD44780: special handling for 16x1 displays (thanks to anonymous bug report on sf.net) + * * Revision 1.41 2003/09/13 06:45:43 reinelt * icons for all remaining drivers * @@ -252,6 +258,28 @@ static int MO_open (void) } +#if 1 +static int MO_read (char *string, int len) +{ + int ret; + + if (Device==-1) return -1; + ret=read (Device, string, len); + if (ret<0 && errno==EAGAIN) { + debug ("read(): EAGAIN"); + usleep(10000); + ret=read (Device, string, len); + } + + if (ret<0) { + error("Cwlinux: read() failed: %s", strerror(errno)); + } + + return ret; +} +#endif + + static void MO_write (char *string, int len) { if (Device==-1) return; @@ -331,6 +359,9 @@ int MO_clear2 (int full) static int MO_init (LCD *Self, int protocol) { + // Fixme + char buffer[256]; + char *port; int speed; @@ -401,6 +432,25 @@ static int MO_init (LCD *Self, int protocol) MO_write ("\376D", 2); // line wrapping off MO_write ("\376R", 2); // auto scroll off + #if 1 + MO_write ("\3767", 2); // read module type + usleep(100000); + MO_read (buffer, 1); + debug ("Read module type=<0x%x>", *buffer); + + MO_write ("\3765", 2); // read serial number + usleep(100000); + MO_read (buffer, 2); + debug ("Serial Number=<0x%x>", *(short*)buffer); + + MO_write ("\3766", 2); // read version number + usleep(100000); + MO_read (buffer, 1); + debug ("Version number=<0x%x>", *buffer); + + + #endif + return 0; } -- cgit v1.2.3