Plustek-USB.txt (2005-08-08) Gerhard Jäger <gerhard@gjaeger.de>
===============================================================

NOTE:
-----

ALL YOU NEED TO RUN YOUR USB SCANNER IS ALREADY INCLUDED. THERE'S
NO NEED TO INSTALL THE KERNEL MODULE pt_drv. THIS ONE IS ONLY NEEDED
FOR THE PLUSTEK PARALLELPORT SCANNER.


List of all currently implemented devices
-----------------------------------------

Quite a lot of them are not tested or even identified. Please send me the ids
of your device...


PLUSTEK
=======
Vendor ID: 0x07B3

Product ID       Device-description and status
0x0005           not identified yet
0x0007           not identified yet
0x000F           not identified yet
0x0010           U12 - working
0x0011           U24 (LM9831) - working
0x0012           not identified yet
0x0013           UT12 (LM9831) - working
0x0014           not identified yet
0x0015           U24 (LM9832) - working
0x0016           not identified yet
0x0017           UT12 - working, UT16 - working, UT24 - working

MUSTEK
======
BearPaw vendor ID: 0x0400 (They use the NationalSemiconductors ID!!!)

Product ID       Device-description and status
0x1000           BearPaw 1200 (LM9831) - working
0x1001           BearPaw 1200 (LM9832) - not tested
0x1001           BearPaw 2400 (LM9832) - mostly working

KYE (Genius)
============
Vendor ID: 0x0458

Product ID       Device-description and status
0x2007           ColorPage-HR6 V2 - working
0x2008           ColorPage-HR6 V2 - not tested
0x2009           ColorPage-HR6A   - not tested
0x2013           ColorPage-HR7    - working
0x2015           ColorPage-HR7LE  - not tested
0x2016           ColorPage-HR6X   - not tested

Hewlett Packard
===============
Vendor ID: 0x03F0

Product ID       Device-description and status
0x0505           HP Scanjet 2100c - working
0x0605           HP Scanjet 2200c - working

EPSON
=====
Vendor ID: 0x04b8

Product ID       Device-description and status
0x010F           EPSON Perfection 1250/Photo - working
0x011D           EPSON Perfection 1260/Photo - working

UMAX
====
Vendor ID: 0x1606

Product ID       Device-description and status
0x0050           UMAX 3400 - working
0x0060           UMAX 3400/3450 - working
0x0160           UMAX 5400 - working

COMPAQ
======
Vendor ID: 0x049F

Product ID       Device-description and status
0x001A           S4-100 - working, identical with UMAX 3400

CANON
=====
Vendor ID: 0x04A9

Product ID       Device-description and status
0x????           FB620U        - not integrated
0x2206           N650U         - working
0x2207           N1220U        - working
0x2208           D660U         - working
0x220D           N670U/LiDE20  - working
0x2220           LiDE25        - working
0x220E           N1240U/LiDE30 - working


How to use and configure the Plustek USB backend
------------------------------------------------

Please note, that the following is only needed, if you need to upgrade
a SANE version...


Preparations
------------

What do we need ?

a SANE backends archive (i.e. sane-backends-1.0.9.tar.gz)
a driver archive (i.e. plustek-sane-0.45-1.tar.gz)

The latest SANE archive can be obtained at:
http://www.sane-project.org
and the latest backend at:
http://www.gjaeger.de/scanner/plustek.html

Assumptions
-----------

Our starting point is your home-directory:

:~>

The packages (here sane-backends-1.0.9.tar.gz und plustek-sane-0.45-1.tar.gz)
are in the /tmp directory.

Let's go:
---------

Change to your home directory and create a sane directory
cd ~
mkdir sane

unpack your sane tar-ball (here "sane-backends-1.0.9.tar.gz")
to this "sane" directory

cd sane
tar xvzf /tmp/sane-backends-1.0.9.tar.gz

Now unpack your plustek-sane tarball (here "plustek-sane-0.45-1.tar.gz")
to the backends directory:

cd sane-backends-1.0.9
tar xvzf /tmp/plustek-sane-0.45-1.tar.gz

Now do the ./configure step...
Especially for SuSE with a preinstalled SANE-RPM:
./configure --prefix=/usr --sysconfdir=/etc --mandir=/usr/share/man --infodir=/usr/share/info

Then do the make step and after that as root user perform the make install
step.

That's all!

Before using, make sure that the USB scanner device driver is loaded:
modprobe scanner
or
modprobe scanner vendor=0x7b3 product=0x17

You might need to add the following line to /etc/modules.conf, if the scanner is not
supported directly - vendor and product must match your device!
options scanner vendor=0x7b3 product=0x17

If you're not sure about the vendor and product id of your device, simply load
the USB subsystem and plug in your scanner. Then do a
cat /proc/bus/usb/devices
and look for the scanner

Now you have to configure the backend. Edit the file /etc/sane.d/plustek.conf
and fill in the appropriate vendor and product id (see there for examples)

This is it...


Autoloading scanner.o
---------------------

To perform an automatic load of the scanner module, you might add the modprobe
line to your boot.local file.
i.e. on SuSE system > 7.x
/etc/init.d/boot.local
An alternative way is to use the hotplug utilities.


Using hotplug utilities and libusb
----------------------------------

When using libusb with SANE, then you should also use the hotplug utilities to
automatically setup your device nodes (at least the permissions) and prevent
scanner.o from loading.

Assuming, that these utilites are properly installed on your box, you have
to tweak and add some files.

In directory (where of course the config files reside):
/etc/hotplug

Append the line
scanner
to file
blacklist

This prevents the scanner module from the usb-subsystem to be loaded.

Next thing is to add a new line in
usb.usermap:

usbscanner 0x0003 0x1606 0x0160 0x0000 0x0000 0x00 0x00 0x00 0x00 0x00 0x00 0x00 000000

The example line shows the vendor ID of UMAX 0x1606 and the product ID of the 5400
0x0160 - these values must match the ones of your scanner.

Last step is adding a script in
/etc/hotplug/usb/
It is called "usbscanner" (don't forget the executable rights)

-------------------------------------------------
# !/bin/bash

if [ "${ACTION}" = add ] && [ -f "${DEVICE}" ]
then
        chgrp users "${DEVICE}"
        chmod ug+rw "${DEVICE}"
fi
-------------------------------------------------

This script will correct the access right to your scanner device when the device
is plugged in.


Debugging your USB scanner (written by Kev Green)
-------------------------------------------------

Firstly, are you running the latest version of SANE, and the Plustek USB driver?

Double check at http://www.gjaeger.de/scanner/plustek.html
(Plustek USB driver) and http://www.sane-project.org (SANE Suite) to
make sure you are.

Now, in order to test and utilise your scanner with the Scanner Access Now Easy
(SANE) system, there are basically two programs that you will need to use from
the sane-frontends (versions post 1.0.3) or sane (versions pre 1.0.3) packages.

Firstly, the sane-find-scanner program will allow you to locate your scanner,
and help you work out if sane knows where it is. This is not definite however,
as (you'll see this too when using sane-find-scanner) it will find all the
scanners on your USB and SCSI bus, whereas sane will only work when you have
the relevant sane backend installed and configured correctly for the relevant
scanner.

So, if sane-find-scanner can find your scanner, but scanimage doesn't work,
then you need to check, double check, and even triple-check your SANE
configuration file for plustek scanners (plustek.conf, usually in
/etc/sane.d
or maybe in /usr/local/sane/ or somewhere, a "find" will be able to tell you
where. It may take a while though!).

If sane-find-scanner doesn't find your scanner, then you should check to see if
the kernel recognises it at all, which you can do with the following command,
as mentioned above:

cat /proc/bus/usb/devices

If your scanner doesn't appear in there, then the kernel has not recognised it.
There may however be a crypic-looking entry in there which doesn't name itself
as plustek, in which case it is recognised as being there by the kernel, but is
not know to the kernel's USB device database, in which case this should be
mentioned on the plustek list (<plustek@linuxhacker.org>), from where
the "powers that be" will deal with it.

If that file does not exist in the /proc filesystem, then you don't have the
"Preliminary USB filesystem" option set in your kernel, and you will need to
recompile your kernel to allow you to do this step in debugging. If it
exists, but is empty, you will have to make sure (use the kernel configure
help information and the details of your motherboard to ascertain this!)
you have the right one of UHCI or OHCI USB modules installed or compiled into
your kernel.

Once you've established that the kernel has recognised your scanner, you can
start pointing the finger at SANE, or simply the "scanner" module. You will
need to have selected the "USB Scanner" option in your kernel compilation as
a module, or compiled into the kernel. If you have done neither, then SANE will
simply not be able to recognise your scanner.  Rectify that, if you are missing
it.

If you have carried out all of the above steps, then sane-find-scanner should
be able to recognise your scanner correctly.

sane-find-scanner probes all of the devices on the SCSI and USB busses, and
so you may find that it outputs "unable to get minor data" errors or similar
to your terminal, or to your error logs, you can safely ignore these as long
as it does that, and has recognised your scanner.

Once you have found your scanner okay using sane-find-scanner, then you are
ready to start messing around with the actual scanimage program to attempt
to scan an image in.

Obviously (although this may turn out to be premature) you should now have
something in your scanner ready to scan for verification.

At this stage, you should begin to be warey, because while the USB stuff for
Plustek scanners is in development it may (like any kernel/module related software)
crash your system with a kernel panic, or simply just segfault, so for your own sake,
close down all the applications you are running and ONLY use text console, rather
than X-Windows at this point, as you will certainly want to avoid any
potential filesystem corruption.

At this point it's probably also good to ensure that you have selected the
"Magic SysRq Key" option in the kernel hacking section of the kernel config,
and done:

echo 1 > /proc/sys/kernel/sysrq

And of course read the readme for that in /usr/src/linux/Documentation, as that
should allow you to avoid filesystem corruption during any crashes that might
happen.

Now, before running scanimage, you should enable the maximum levels of
debugging possible in both the SANE core and in the Plustek scanner
backend.

To do this you should do:

export SANE_DEBUG_PLUSTEK=12
export SANE_DEBUG_DLL=12

Now, if you run scanimage, you should be able to see the maximum debugging
messages.

If those messages don't tell you what is wrong, then take note of your scanner
type, the contents of /proc/bus/usb/devices, and the contents of your error
log, as well as (where possible) the output of the scanimage command (if
you can't capture it directly, an as-accurate-as-possible description is
MUCH better than nothing!), and try and get all of the activity that
your scanner did as well (light
came on? didnt? motors came on? etc?) and email that to the plustek list
(<plustek@linuxhacker.org>).

For the particularly adventurous only...

You might want to try running the scanimage program through strace or
gdb to see if you can go some or all of the way to debugging the problem
yourself, and post the relevant (ie. last!) parts of those utilities
output to the plustek-help list. If you don't know what strace or gdb
are, then you should probably not try that.

It's probably safe to run your scanner in a normal operating environment
under Linux once you have got it working once in a text console.


How to add a new LM9831/2 based device description
--------------------------------------------------

If you have a LM9831 or LM9832 based scanner and your vendor and product id did
not appear in the list above and you're willing to do some experiments, then
simply add your device to the file plustek-devs.c at the end of the list.
See the list at the end of the file how this works...


Thanx guys for helping:
-----------------------

Henning Meier-Geinitz  henning@meier-geinitz.de  for Mustek Bearpaw testing, ideas and patches
Stefan Nilsen          stefan.nilsen@telia.com   for HP2200c testing and patches
Kev Green              kyrian@ore.org            for Documentation, UT12 testing and RPMS.
Holger Bischof         bischof@cs.tu-berlin.de   for OpticPro U12 testing
Abhijit Sovakar        a.sovakar@gmx.de          for OpticPro UT24 testing
Peter Koellner         peter@mezzo.net           for OpticPro U24 testing
Gene Heskett           gene_heskett@iolinc.net   for EPSON 1250 testing and patches
Tasnim Ahmed           tasnim_ahmed@yahoo.com    for KYE Colorpage HR6 testing
Reinhard Max           max@suse.de               for EPSON 1250 testing and patches
Allan N. Hessenflow    allan@kallisti.com        for UMAX 3400 testing and patches
Craig Smoothey         craig@smoothey.org        for HP2100c testing and patches
Till Kamppeter         till.kamppeter@gmx.net    for EPSON1260 testing
Christopher Montgomery monty@xiph.org            for CanoScan calibration works
Olaf Leidinger         leidola@newcon.de         for CanoScan LiDE25 testing

and a lot of other guys not named here...


Some equations which are used to calculate some stuff
-----------------------------------------------------

The stuff is used in plustek_usbscan.c to get the correct register settings
out of the hardware descriptions:

Crystalfrequency is 48MHz


Pixel Period (seconds/pixel)
----------------------------

              MCLK_DIV x 8 x CM
PixelPeriod = -----------------
                   48MHz


Integration Time (seconds)
--------------------------

Tint = PixelPeriod X LineLength

       MCLK_DIV x 8 x CM X LineLength
Tint = ------------------------------
                  48MHz


Ideal MCLK Divider
------------------
                        48MHz            (DataPixelsEnd - DataPixelStart)
MCLK_DIV = --------------------------- x --------------------------------
           HostIORate x 8 x LineLength          HDPI_ADJ x PP

                        48MHz                (DataPixelsEnd - DataPixelStart)    CM
         = ------------------------------- x -------------------------------- x ----
           BytesPerSecond x 8 x LineLength            HDPI_ADJ x PP              CM

                        48MHz                      1
         = --------------------------- x Tint x	---------
                     8 x LineLength                CM

                        48MHz             (Tint * 1000)
         = ----------------------- x --------------------
            1000 x 8 x LineLength             CM


Ideal Scan Speed (inches/second)

                 1            1         1
ScanSpeed = ----------- x -------- x --------
            PixelPeriod   FSPI x 4   StepSize

                   48MHz            1         1
ScanSpeed = ----------------- x -------- x --------
            MCLK_DIV x 8 x CM   FSPI x 4   StepSize


                             48MHz
MCLK_DIV = ------------------------------------------
            ScanSpeed x 8 x CM x FSPI x 4 x StepSize



----------------
Symbols:

CM - Color Mode (unitless), 3 for channel pixel rate color, else 1


-------------------------