diff options
| author | reinelt <reinelt@3ae390bd-cb1e-0410-b409-cd5a39f66f1f> | 2004-01-27 06:34:14 +0000 | 
|---|---|---|
| committer | reinelt <reinelt@3ae390bd-cb1e-0410-b409-cd5a39f66f1f> | 2004-01-27 06:34:14 +0000 | 
| commit | 927b0b86ce4fffd3fc1645d6ece156fdd6bc31fc (patch) | |
| tree | 079aaf4d1c7ca0fc7790f7c6d2894b06d529792d | |
| parent | 88ce09c638bfba523e758e8a9e245335d3e6a591 (diff) | |
| download | lcd4linux-927b0b86ce4fffd3fc1645d6ece156fdd6bc31fc.tar.gz | |
[lcd4linux @ 2004-01-27 06:34:14 by reinelt]
Cwlinux driver portet to NextGeneration (compiles, but not tested!)
git-svn-id: https://ssl.bulix.org/svn/lcd4linux/trunk@341 3ae390bd-cb1e-0410-b409-cd5a39f66f1f
| -rw-r--r-- | Makefile.am | 2 | ||||
| -rw-r--r-- | Makefile.in | 4 | ||||
| -rw-r--r-- | aclocal.m4 | 26 | ||||
| -rwxr-xr-x | configure | 4 | ||||
| -rw-r--r-- | configure.in | 4 | ||||
| -rw-r--r-- | drv.c | 13 | ||||
| -rw-r--r-- | drv_Cwlinux.c | 343 | 
7 files changed, 371 insertions, 25 deletions
| diff --git a/Makefile.am b/Makefile.am index 07c6ebb..afbcac4 100644 --- a/Makefile.am +++ b/Makefile.am @@ -88,7 +88,7 @@ EXTRA_lcd4linux_SOURCES= \  parport.c parport.h \  BeckmannEgle.c \  drv_Crystalfontz.c Crystalfontz.c \ -Cwlinux.c \ +drv_Cwlinux.c Cwlinux.c \  HD44780.c \  M50530.c \  T6963.c \ diff --git a/Makefile.in b/Makefile.in index e9caa48..16a6dc5 100644 --- a/Makefile.in +++ b/Makefile.in @@ -125,7 +125,7 @@ lcd4linux_SOURCES =  lcd4linux.c pid.c pid.h hash.c hash.h parser.c parser.h pro  #fontmap.c fontmap.h \  #udelay.c udelay.h -EXTRA_lcd4linux_SOURCES =  parport.c parport.h BeckmannEgle.c drv_Crystalfontz.c Crystalfontz.c Cwlinux.c HD44780.c M50530.c T6963.c USBLCD.c drv_MatrixOrbital.c MatrixOrbital.c MilfordInstruments.c PalmPilot.c Raster.c SIN.c XWindow.c Text.c +EXTRA_lcd4linux_SOURCES =  parport.c parport.h BeckmannEgle.c drv_Crystalfontz.c Crystalfontz.c drv_Cwlinux.c Cwlinux.c HD44780.c M50530.c T6963.c USBLCD.c drv_MatrixOrbital.c MatrixOrbital.c MilfordInstruments.c PalmPilot.c Raster.c SIN.c XWindow.c Text.c  EXTRA_DIST =  lcd4linux.conf.sample lcd4kde.conf lcd4linux.kdelnk lcd4linux.xpm lcd4linux.lsm curses.m4 AUTHORS CREDITS FAQ NEWS TODO README README.Rows README.Tokens README.Drivers README.Plugins README.KDE Skeleton.c plugin_sample.c @@ -182,7 +182,7 @@ DEP_FILES =  .deps/BeckmannEgle.P .deps/Crystalfontz.P .deps/Cwlinux.P \  .deps/MilfordInstruments.P .deps/PalmPilot.P .deps/Raster.P .deps/SIN.P \  .deps/T6963.P .deps/Text.P .deps/USBLCD.P .deps/XWindow.P .deps/bar.P \  .deps/battery.P .deps/cfg.P .deps/debug.P .deps/display.P .deps/drv.P \ -.deps/drv_Crystalfontz.P .deps/drv_MatrixOrbital.P \ +.deps/drv_Crystalfontz.P .deps/drv_Cwlinux.P .deps/drv_MatrixOrbital.P \  .deps/drv_generic_parport.P .deps/drv_generic_serial.P \  .deps/drv_generic_text.P .deps/dvb.P .deps/evaluator.P .deps/exec.P \  .deps/expr.P .deps/filter.P .deps/fontmap.P .deps/hash.P .deps/icon.P \ @@ -10,7 +10,7 @@ dnl but WITHOUT ANY WARRANTY, to the extent permitted by law; without  dnl even the implied warranty of MERCHANTABILITY or FITNESS FOR A  dnl PARTICULAR PURPOSE. -# lib-prefix.m4 serial 3 (gettext-0.12.2) +# lib-prefix.m4 serial 3 (gettext-0.13)  dnl Copyright (C) 2001-2003 Free Software Foundation, Inc.  dnl This file is free software, distributed under the terms of the GNU  dnl General Public License.  As a special exception to the GNU General @@ -718,7 +718,7 @@ AC_DEFUN([AC_LIB_APPENDTOVAR],    done  ]) -# lib-ld.m4 serial 2 (gettext-0.12) +# lib-ld.m4 serial 3 (gettext-0.13)  dnl Copyright (C) 1996-2003 Free Software Foundation, Inc.  dnl This file is free software, distributed under the terms of the GNU  dnl General Public License.  As a special exception to the GNU General @@ -734,11 +734,12 @@ dnl From libtool-1.4. Sets the variable with_gnu_ld to yes or no.  AC_DEFUN([AC_LIB_PROG_LD_GNU],  [AC_CACHE_CHECK([if the linker ($LD) is GNU ld], acl_cv_prog_gnu_ld,  [# I'd rather use --version here, but apparently some GNU ld's only accept -v. -if $LD -v 2>&1 </dev/null | egrep '(GNU|with BFD)' 1>&5; then -  acl_cv_prog_gnu_ld=yes -else -  acl_cv_prog_gnu_ld=no -fi]) +case `$LD -v 2>&1 </dev/null` in +*GNU* | *'with BFD'*) +  acl_cv_prog_gnu_ld=yes ;; +*) +  acl_cv_prog_gnu_ld=no ;; +esac])  with_gnu_ld=$acl_cv_prog_gnu_ld  ]) @@ -808,11 +809,12 @@ AC_CACHE_VAL(acl_cv_path_LD,        # Check to see if the program is GNU ld.  I'd rather use --version,        # but apparently some GNU ld's only accept -v.        # Break only if it was the GNU/non-GNU ld that we prefer. -      if "$acl_cv_path_LD" -v 2>&1 < /dev/null | egrep '(GNU|with BFD)' > /dev/null; then -	test "$with_gnu_ld" != no && break -      else -	test "$with_gnu_ld" != yes && break -      fi +      case `"$acl_cv_path_LD" -v 2>&1 < /dev/null` in +      *GNU* | *'with BFD'*) +	test "$with_gnu_ld" != no && break ;; +      *) +	test "$with_gnu_ld" != yes && break ;; +      esac      fi    done    IFS="$ac_save_ifs" @@ -20955,8 +20955,8 @@ _ACEOF  fi  if test "$CWLINUX" = "yes"; then -#  DRIVERS="$DRIVERS Cwlinux.lo" -   DRIVERS="$DRIVERS Cwlinux.o" +#  DRIVERS="$DRIVERS Cwlinux.lo drv_Cwlinux.lo" +   DRIVERS="$DRIVERS Cwlinux.o drv_Cwlinux.o"  cat >>confdefs.h <<\_ACEOF  #define WITH_CWLINUX 1 diff --git a/configure.in b/configure.in index 6031ea2..e0a3b01 100644 --- a/configure.in +++ b/configure.in @@ -152,8 +152,8 @@ if test "$CRYSTALFONTZ" = "yes"; then  fi  if test "$CWLINUX" = "yes"; then -#  DRIVERS="$DRIVERS Cwlinux.lo" -   DRIVERS="$DRIVERS Cwlinux.o" +#  DRIVERS="$DRIVERS Cwlinux.lo drv_Cwlinux.lo" +   DRIVERS="$DRIVERS Cwlinux.o drv_Cwlinux.o"     AC_DEFINE(WITH_CWLINUX,1,[junk])  fi @@ -1,4 +1,4 @@ -/* $Id: drv.c,v 1.4 2004/01/21 12:36:19 reinelt Exp $ +/* $Id: drv.c,v 1.5 2004/01/27 06:34:14 reinelt Exp $   *   * new framework for display drivers   * @@ -23,6 +23,9 @@   *   *   * $Log: drv.c,v $ + * Revision 1.5  2004/01/27 06:34:14  reinelt + * Cwlinux driver portet to NextGeneration (compiles, but not tested!) + *   * Revision 1.4  2004/01/21 12:36:19  reinelt   * Crystalfontz NextGeneration driver added   * @@ -117,11 +120,9 @@ DRIVER *Driver[] = {  #ifdef WITH_CRYSTALFONTZ    &drv_Crystalfontz,  #endif -  /* Fixme -     #ifdef WITH_CWLINUX -     &Cwlinux, -     #endif -  */ +#ifdef WITH_CWLINUX +  &drv_Cwlinux, +#endif  #ifdef WITH_HD44780    &drv_HD44780,  #endif diff --git a/drv_Cwlinux.c b/drv_Cwlinux.c new file mode 100644 index 0000000..87c43cc --- /dev/null +++ b/drv_Cwlinux.c @@ -0,0 +1,343 @@ +/* $Id: drv_Cwlinux.c,v 1.1 2004/01/27 06:34:14 reinelt Exp $ + * + * new style driver for Cwlinux display modules + * + * Copyright 1999, 2000 Michael Reinelt <reinelt@eunet.at> + * Copyright 2004 The LCD4Linux Team <lcd4linux-devel@users.sourceforge.net> + * + * This file is part of LCD4Linux. + * + * LCD4Linux is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2, or (at your option) + * any later version. + * + * LCD4Linux is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + * + * + * $Log: drv_Cwlinux.c,v $ + * Revision 1.1  2004/01/27 06:34:14  reinelt + * Cwlinux driver portet to NextGeneration (compiles, but not tested!) + * + */ + +/*  + * + * exported fuctions: + * + * struct DRIVER drv_Cwlinux + * + */ + +#include <stdlib.h> +#include <stdio.h> +#include <string.h> +#include <unistd.h> + +#include "debug.h" +#include "cfg.h" +#include "plugin.h" +#include "widget.h" +#include "widget_text.h" +#include "widget_icon.h" +#include "widget_bar.h" +#include "drv.h" +#include "drv_generic_text.h" +#include "drv_generic_serial.h" + + +static char Name[]="Cwlinux"; + +static int Model; +static int Protocol; + +// Fixme: +// static int GPO[8]; +static int GPOS; + + +typedef struct { +  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, 40,  6,  0,  2 }, +  { 0xff, "Unknown", -1, -1, -1, -1, -1 } +}; + + +// **************************************** +// ***  hardware dependant functions    *** +// **************************************** + +static void drv_CW_goto (int row, int col) +{ +  char cmd[6]="\376Gxy\375"; +  cmd[2]=(char)col; +  cmd[3]=(char)row; +  drv_generic_serial_write(cmd, 5); +} + + +static void drv_CW1602_defchar (int ascii, char *buffer) +{ +  int i; +  char cmd[12]="\376Nn12345678\375"; + +  cmd[2]=(char)(ascii+1); + +  for (i=0; i<8; i++) { +    cmd[3+i]=buffer[i]; +  } +  drv_generic_serial_write(cmd,12); +  usleep(20);  // delay for cw1602 to settle the character defined! +} + + +static void drv_CW12232_defchar (int ascii, char *buffer) +{ +  int i, j; +  char cmd[10]="\376Nn123456\375"; +   +  cmd[2]=(char)(ascii+1); +   +  // 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_generic_serial_write (cmd, 10); +} + + +static int drv_CW_start (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; +    } +    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) 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]); +#endif + +  // initialize global variables +  DROWS    = Models[Model].rows; +  DCOLS    = Models[Model].cols; +  XRES     = Models[Model].xres; +  GPOS     = Models[Model].gpos; +  Protocol = Models[Model].protocol; + +#if 0 +  drv_generic_serial_write("\376X\375",3); // Clear Display +#else +  // for some mysterious reason, we have to sleep after  +  // the command _and_ after the CMD_END... +  usleep(20); +  drv_generic_serial_write("\376X",2); // Clear Display +  usleep(20); +  drv_generic_serial_write("\375",1);  // Command End +  usleep(20); +#endif + +  drv_generic_serial_write ("\376D\375", 3); // auto line wrap off +  drv_generic_serial_write ("\376R\375", 3); // auto scroll off +  drv_generic_serial_write ("\376K\375", 3); // underline cursor off +  drv_generic_serial_write ("\376B\375", 3); // backlight on + +  return 0; +} + + +// **************************************** +// ***            plugins               *** +// **************************************** + + +static void plugin_backlight (RESULT *result, RESULT *arg1) +{ +  char cmd[5]="\376A_\375"; +  double backlight; +   +  backlight=R2N(arg1); +  if (backlight<0) backlight=0; +  if (backlight>8) backlight=8; + +  switch ((int)backlight) { +  case 0: +    drv_generic_serial_write ("\376F\375", 3); // backlight off +    break; +  case 8: +    drv_generic_serial_write ("\376B\375", 3); // backlight on +    break; +  default: +    cmd[2]=(char)backlight; +    drv_generic_serial_write (cmd, 4); // backlight level +    break; +  } + +  SetResult(&result, R_NUMBER, &backlight);  +} + + +// **************************************** +// ***        widget callbacks          *** +// **************************************** + +// using drv_generic_text_draw(W) +// using drv_generic_text_icon_draw(W) +// using drv_generic_text_bar_draw(W) + + +// **************************************** +// ***        exported functions        *** +// **************************************** + + +// list models +int drv_CW_list (void) +{ +  int i; +   +  for (i=0; Models[i].type!=0xff; i++) { +    printf ("%s ", Models[i].name); +  } +  return 0; +} + + +// initialize driver & display +int drv_CW_init (char *section) +{ +  WIDGET_CLASS wc; +  int ret;   +   +  // display preferences +  XRES  = 6;      // pixel width of one char  +  YRES  = 8;      // pixel height of one char  +  CHARS = 8;      // number of user-defineable characters +  CHAR0 = 128;    // ASCII of first user-defineable char +  GOTO_COST = 3;  // number of bytes a goto command requires + +  // real worker functions +  drv_generic_text_real_write   = drv_generic_serial_write; +  drv_generic_text_real_goto    = drv_CW_goto; + +  switch (Protocol) { +    case 1: +      drv_generic_text_real_defchar = drv_CW1602_defchar; +      break; +    case 2: +      drv_generic_text_real_defchar = drv_CW12232_defchar; +      break; +  } +   +  // start display +  if ((ret=drv_CW_start (section))!=0) +    return ret; +   +  // 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) +    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 ("backlight", 1, plugin_backlight); +   +  return 0; +} + + +// close driver & display +int drv_CW_quit (void) { + +  info("%s: shutting down.", Name); +  drv_generic_serial_close(); +  drv_generic_text_quit(); +   +  return (0); +} + + +DRIVER drv_Cwlinux = { +  name: Name, +  list: drv_CW_list, +  init: drv_CW_init, +  quit: drv_CW_quit,  +}; + | 
