sane-canon_pp.5
sane-canon_pp(5) SANE Scanner Access Now Easy sane-canon_pp(5)
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 un-
likely 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. Feed-
back is still appreciated. Please send any bug reports to the main-
tainers as listed on the web page (listed in SEE ALSO below).
DEVICE NAMES
This backend expects device names of the form presented by li-
bieee1284(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 spec-
ify 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
ieee1284 port-name
Defines which port to use. The format of port-name is OS depen-
dent, based on the names presented by libieee1284(3). Please
only have one of these lines, or all but one will be ignored.
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 en-
vironment variable.
init_mode <AUTO|FB620P|FB630P> [port-name]
Defines which initialisation (wake-up) mode 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 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 ini-
tialisation 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.
force_nibble
Forces the driver to use nibble mode even if ECP mode is re-
ported to work by libieee1284(3). 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 /usr/local/etc/sane.d/dll.conf
FILES
/usr/local/etc/sane.d/canon_pp.conf
The backend configuration file (see also description of
SANE_CONFIG_DIR below).
/usr/local/lib/sane/libsane-canon_pp.a
The static library implementing this backend.
/usr/local/lib/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 direc-
tories are separated by a colon (`:'), under OS/2, they are sep-
arated 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 /usr/lo-
cal/etc/sane.d. If the value of the environment variable ends
with the directory separator character, then the default direc-
tories are searched after the explicitly specified directories.
For example, setting SANE_CONFIG_DIR to "/tmp/config:" would re-
sult in directories tmp/config, ., and /usr/local/etc/sane.d be-
ing searched (in this order).
SANE_DEBUG_CANON_PP
If the library was compiled with debug support enabled, this en-
vironment 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 en-
tirely 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(3) 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 re-
vive 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 buf-
fer 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-accu-
racy 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 win-
dows 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. Sig-
norini for his help with the N340P.
11 Jul 2008 sane-canon_pp(5)
Man(1) output converted with
man2html