kopia lustrzana https://gitlab.com/sane-project/backends
458 wiersze
15 KiB
Plaintext
458 wiersze
15 KiB
Plaintext
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
|
|
|
|
|
|
-------------------------
|
|
|