Provided by: libsane-common_1.2.1-7build4_all bug

NAME

       sane-canon_pp - SANE backend for Canon CanoScan Parallel Port flatbed scanners

DESCRIPTION

       The sane-canon_pp library implements a SANE (Scanner Access Now Easy) backend that provides access to the
       following Canon flatbed scanners:

              CanoScan FB320P
              CanoScan FB620P
              CanoScan FB330P
              CanoScan FB630P
              CanoScan N340P
              CanoScan N640P
              CanoScan N640P ex

       No USB scanners are supported and there are no plans to support them in the future.  Other  projects  are
       working  on  support  for USB scanners. See the PROJECTS file for more detail.  The FB310P and FB610P are
       re-badged Avision scanners which use a different command set, so are unlikely to  be  supported  by  this
       backend in the future.

       IMPORTANT:  this  is  alpha  code. While we have made every effort to make it as reliable as possible, it
       will not always work as expected.  Feedback is still appreciated.  Please send any  bug  reports  to  the
       maintainers as listed on the web page (listed in SEE ALSO below).

DEVICE NAMES

       This  backend  expects  device  names  of  the  form presented by libieee1284(3).  These names are highly
       dependent on operating system and version.

       On Linux 2.4 kernels this will be of the form parport0 or older (2.2  and  before)  kernels  may  produce
       names  like  0x378  (the  base  address of your port) or simply 0 depending on your module configuration.
       Check the contents of /proc/parport if it exists.  If you don't want to specify a default port (or  don't
       know its name), the backend should be able to detect which port your scanner is on.

CONFIGURATION

       The contents of the canon_pp.conf file is a list of options for the driver to use.  Empty lines and lines
       starting with a hash mark (#) are ignored.

       The supported options are currently ieee1284, calibrate, init_mode, and force_nibble

       Option ieee1284 port-name defines which port to use.  The format of port-name is OS dependent,  based  on
       the names presented by libieee1284.  Please only have one of these lines, or all but one will be ignored.

       Option  calibrate cal-file [port-name] defines which calibration file to use on a per-port basis.  If you
       only have one parport, the port-name argument may be omitted - but be careful as this will cause problems
       on  multi-scanner systems.  You may have as many of these lines as you like, as long as each has a unique
       port name.  The tilde (`~') character is acceptable and will  be  expanded  to  the  value  of  the  HOME
       environment.

       Option  init_mode <AUTO|FB620P|FB630P> [portname] defines which initialisation (wake-up) mode to use on a
       per-port basis.  If you only have one parport, the portname argument may be omitted - but be  careful  as
       this  may  cause  problems on multi-scanner systems.  You may have as many of these lines as you like, as
       long as each has a unique port name.  The valid initialisation modes are FB620P (which  strobes  10101010
       and  01010101  on the data pins), FB630P (which strobes 11001100 and 00110011 on the data pins) and AUTO,
       which will try FB630P mode first then FB620P mode second.  The FB620P mode is also used  by  the  FB320P.
       The FB630P mode is used by the FB330P, N340P, and N640P.

       Option  force_nibble  forces  the  driver  to  use  nibble  mode  even if ECP mode is reported to work by
       libieee1284.  This works-around the rare issue of ECP mode being reported to work by  the  library,  then
       not working.

TIPS

       Hit the "Calibrate" button before scanning.  It vastly improves the quality of scans.

       To enable automatic detection of your scanner, uncomment the "canon_pp" line from /etc/sane.d/dll.conf

FILES

       /etc/sane.d/canon_pp.conf
              The backend configuration file (see also description of SANE_CONFIG_DIR below).

       /usr/lib/x86_64-linux-gnu/sane/libsane-canon_pp.a
              The static library implementing this backend.

       /usr/lib/x86_64-linux-gnu/sane/libsane-canon_pp.so
              The shared library implementing this backend (present on systems that support dynamic loading).

ENVIRONMENT

       SANE_CONFIG_DIR
              This  environment  variable  specifies  the list of directories that may contain the configuration
              file.  On *NIX systems, the directories are separated by a  colon  (`:'),  under  OS/2,  they  are
              separated  by a semi-colon (`;').  If this variable is not set, the configuration file is searched
              in two default directories: first, the current working directory (".") and  then  in  /etc/sane.d.
              If  the  value  of  the environment variable ends with the directory separator character, then the
              default directories are searched after the explicitly specified directories. For example,  setting
              SANE_CONFIG_DIR to "/tmp/config:" would result in directories tmp/config, ., and /etc/sane.d being
              searched (in this order).

       SANE_DEBUG_CANON_PP
              If the library was compiled with debug support enabled, this  environment  variable  controls  the
              debug level for this backend.  Higher debug levels increase the verbosity of the output.

              Example: export SANE_DEBUG_CANON_PP=4

NOTES

       Features available in the Windows interface

       Brightness and Contrast
              These are not implemented, and probably never will be.  These appear to be implemented entirely in
              software.  Use GIMP or a similar program if you need these features.

       Descreen Mode
              This appears on our first analysis to be just oversampling with an anti-aliasing  filter.   Again,
              it seems to be implemented entirely in software, so GIMP is your best bet for now.

       Gamma Tables
              This  is under investigation, but for now only a simple gamma profile (ie: the one returned during
              calibration) will be loaded.

       Communication Problems

       ECP mode in libieee1284 doesn't always work properly, even with new hardware.  We believe that this is  a
       ppdev  problem.  If you change the configuration file to include force_nibble , the problem will go away,
       but you will only be able to scan in nibble mode.

       Sometimes the scanner can be left in a state where our code cannot revive it.  If the backend reports  no
       scanner present, try unplugging the power and plugging it back in.  Also try unplugging printers from the
       pass-through port.

       The scanner will not respond correctly to our commands when you first plug in the power.  You may find if
       you  try  a  scan very soon after plugging in the power that the backend will incorrectly report that you
       have no scanner present.  To avoid this, give it about 10 seconds to reset itself before  attempting  any
       scans.

       Repeated Lines

       Sometimes  at  high  resolutions  (ie.  600dpi)  you  will  notice lines which appear twice.  These lines
       correspond to points where the scanner head has stopped during the scan (it stops every time the internal
       64kb  buffer  is  full).   Basically  it's a mechanical problem inside the scanner, that the tolerance of
       movement for a start/stop event is greater than 1/600 inches.  I've never tried the windows driver so I'm
       not sure how (or if) it works around this problem, but as we don't know how to rewind the scanner head to
       do these bits again, there's currently no nice way to deal with the problem.

       Grey-scale Scans

       Be aware that the scanner uses the green LEDs to read grey-scale scans,  meaning  green  coloured  things
       will  appear  lighter  than  normal, and red and blue coloured items will appear darker than normal.  For
       high-accuracy grey-scale scans of colour items, it's best just to scan in colour  and  convert  to  grey-
       scale in graphics software such as the GIMP.

       FB620P/FB320P Caveats

       These  models  can  not  be  reset in the same way as the others.  The windows driver doesn't know how to
       reset them either - when left with an inconsistent scanner, it will start  scanning  half  way  down  the
       page!

       Aborting is known to work correctly on the FB*30P models, and is known to be broken on the FB*20P models.
       The FB620P which I tested on simply returns garbage after a scan has been aborted  using  the  method  we
       know.   Aborting is able to leave the scanner in a state where it can be shut down, but not where another
       scan can be made.

SEE ALSO

       sane(7), sane-dll(5), libieee1284(3),
       http://canon-fb330p.sourceforge.net/

AUTHOR

       This backend is primarily the work  of  Simon  Krix  (Reverse  Engineering),  and  Matthew  Duggan  (SANE
       interface).

       Many thanks to Kevin Easton for his comments and help, and Kent A. Signorini for his help with the N340P.

                                                   11 Jul 2008                                  sane-canon_pp(5)