MyWebUniversity.com Home Page
 



OpenSolaris man pages main menu


SANE Scanner Access Now Easy                         sane-scsi(5)



NAME
     sane-scsi - SCSI adapter tips for scanners

DESCRIPTION
     This manual page contains various operating-system  specific
     tips and tricks on how to get scanners with a SCSI interface
     working.

GENERAL INFO
     For scanners with a SCSI interface, it may be  necessary  to
     edit the appropriate backend configuration file before using
     SANE for the first time.  For most systems,  the  configura-
     tion  file  should  list the name of the generic SCSI device
     that  the  scanner  is  connected  to  (e.g.,  under  Linux,
     /dev/sg4  or /dev/sge is such a generic SCSI device).  It is
     customary to create a symlink from /dev/scanner to the  gen-
     eric  SCSI device that the scanner is connected to.  In this
     case,  the  configuration  file  simply   lists   the   line
     /dev/scanner.   For a detailed description of each backend's
     configuration file, please refer  to  the  relevant  backend
     manual  page  (e.g., sane-epson(5) for Epson scanners, sane-
     hp(5) for HP scanners, etc.).

     For some operating systems (e.g. Linux and OS/2),  there  is
     an alternate way of specifying scanner devices.  This alter-
     nate way allows to identify scanners by the SCSI vendor  and
     model  string  and/or by the SCSI device address (consisting
     of bus number, channel number, id, and logical unit number).
     The syntax for specifying a scanner in this way is:

          scsi VENDOR MODEL TYPE BUS CHANEL ID

     where VENDOR is the SCSI vendor string, MODEL  is  the  SCSI
     model  string,  TYPE is type SCSI device type string, BUS is
     the SCSI bus number (named "host" in /proc/scsi/scsi), CHAN-
     NEL  is  the SCSI channel number, ID is the SCSI id, and LUN
     is the logical unit number of the scanner device.  The first
     two  fields  are  strings  which must be enclosed in double-
     quotes if they contain any whitespace.  The  remaining  four
     fields are non-negative integer numbers.  The correct values
     for these fields can be  found  by  using  operating  system
     specific  tools,  e.g. for Linux by looking at the output of
     the command "cat /proc/scsi/scsi".  To  simplify  configura-
     tion,  a field's value can be replaced with an asterisk sym-
     bol (``*'').  An asterisk has the effect that any  value  is
     allowed for that particular field.  This can have the effect
     that a single scsi-line matches multiple devices.  When this
     happens,  each matching device will be probed by the backend
     one by one and registered if the backend thinks it is a com-
     patible device.  For example, the line





sane-backends 1.0.19Last change: 28 Oct 2003                    1






SANE Scanner Access Now Easy                         sane-scsi(5)



          scsi MUSTEK MFS-06000CX Scanner 0 00 03 00

     would attach the Mustek  SCSI  scanner  with  the  following
     /proc/scsi/scsi entry:

       Host: scsi0 Channel: 00 Id: 03 Lun: 00
         Vendor: MUSTEK   Model: MFS-06000CX Rev: 4.04
         Type:   Scanner  ANSI SCSI revision: 0

     Usually it's sufficient to use vendor and model strings only
     or even only the vendor string. The following example

          scsi MUSTEK * * * * * *

     would have the effect that all SCSI devices  in  the  system
     with  a  vendor  string of MUSTEK would be probed and recog-
     nized by the backend.

     If the remainder of  a  scsi-string  consists  of  asterisks
     only,  the  asterisks can be omitted.  For example, the fol-
     lowing line is equivalent to the one specified previously:

          scsi MUSTEK

     On some platforms (e.g., OpenStep), SANE device names take a
     special  form.   This  is  explained  below  in the relevant
     platform-specific section.

     When using a SCSI scanner, ensure that the access permission
     for the generic SCSI device is set appropriately.  We recom-
     mend to add a group "scanner" to /etc/group  which  contains
     all  users that should have access to the scanner.  The per-
     mission of the device should then be set to allow group read
     and write access.  For example, if the scanner is at generic
     SCSI device /dev/sg0, then the following two commands  would
     set the permission correctly:

          $ chgrp scanner /dev/sg0
          $ chmod 660 /dev/sg0

     When your system uses the  device  filesystem  (devfs),  you
     have  to edit /etc/devfs/perms.  There you should search the
     line

          REGISTER ^sg[^/]* PERMISIONS root.root 0600

     and add a new line (eg. for changing permissions of sg4):

          REGISTER ^sg4 PERMISIONS root.scanner 0660

FREBSD INFO
     Auto-configuration using the "scsi *" lines  in  the  config



sane-backends 1.0.19Last change: 28 Oct 2003                    2






SANE Scanner Access Now Easy                         sane-scsi(5)



     files  only  works  if  the  user  running  the frontend has
     read/write acces to /dev/xpt0. Instead, you can also  set  a
     link /dev/scanner to the appropriate /dev/uk device.

          Adaptec AHA1542CF
               Reported to work fine under  FreeBSD  2.2.2R  with
               the aha driver.

          Adaptec 2940
               Reported to work fine under FreeBSD 2.2.2.

          Adaptec 1522
               The scanner probes ok but any attempt to access it
               hangs  the  entire system. It looks like something
               is disabling interrupts and then  not  re-enabling
               them,  so  it  looks like a bug in the FreeBSD aic
               driver.

          Adaptec 1505
               Works on FreeBSD 2.2.5R  and  3.0  using  the  aic
               driver,  provided  that  Plug-and-Play  support is
               disabled on the card.  If there are no uk devices,
               just  do  a  ``sh MAKEDEV uk0'' in the /dev direc-
               tory. The scanner should  then  be  accessible  as
               /dev/uk0 if it was probed during boot.

          Tekram DC390
               Reported to work fine under  FreeBSD  2.2.2R  with
               the amd driver.


LINUX INFO
     First, make  sure  your  kernel  has  SCSI  generic  support
     enabled.   In  ``make  xconfig'', this shows up under ``SCSI
     support->SCSI generic support''.

     To keep scanning times to a minimum, it is  strongly  recom-
     mended  to  use  a  large  buffer  size for the generic SCSI
     driver. From SG driver version 2.0 on,  the  maximum  buffer
     size  can  be  changed  at program run time, and there is no
     restriction in size. This driver  version  is  part  of  the
     Linux kernels from version 2.2.7 on. If the new SG driver is
     available some backends (e.g. sane-umax, sane-mustek,  sane-
     sharp) automatically request larger scsi buffers. If a back-
     end does not automatically request a larger scsi buffer, set
     the  environment  variable SANESGBUFERSIZE to the desired
     buffer size in bytes. It is not recommended to use more than
     1  MB,  because  for  large values the probability increases
     that the SG driver cannot allocate the necessary  buffer(s).
     For  ISA  cards, even 1 MB might be a too large value. For a
     detailed discussion of memory issues of the SG  driver,  see
     http:/www.torque.net/sg.



sane-backends 1.0.19Last change: 28 Oct 2003                    3






SANE Scanner Access Now Easy                         sane-scsi(5)



     For Linux kernels before  version  2.2.7  the  size  of  the
     buffer  is  only  32KB.   This  works,  but for many cheaper
     scanners this causes scanning to be slower by about a factor
     of  four than when using a size of 127KB.  Linux defines the
     size of this buffer by  macro  SGBIGBUF  in  header  file
     /usr/include/scsi/sg.h.   Unless a system is seriously short
     on memory, it is recommended to increase this value  to  the
     maximum  legal  value  of  128*1024-512=130560 bytes.  After
     changing this value, it is necessary to recompile  both  the
     kernel  (or  the SCSI generic module) and the SCSI backends.
     Keep in mind that this is only necessary  with  older  Linux
     kernels.


     A common issue with SCSI scanners is what  to  do  when  you
     booted the system while the scanner was turned off?  In such
     a case, the scanner won't be recognized by  the  kernel  and
     SANE  won't  be  able to access it.  Fortunately, Linux pro-
     vides a simple mechanism to probe a SCSI device  on  demand.
     Suppose  you  have a scanner connected to SCSI bus 2 and the
     scanner has a SCSI id of 5.  When the system is up and  run-
     ning  and  the  scanner is turned on, you can issue the com-
     mand:

          echo "scsi add-single-device 2 0 5 0" > /proc/scsi/scsi

     and the kernel will probe and recognize your  scanner  (this
     needs  to  be  done as root).  It's also possible to dynami-
     cally remove a SCSI device  by  using  the  ``remove-single-
     device''  command.   For  details,  please  refer  to to the
     SCSI-2.4-HOWTO.

     Scanners are known to work with the following SCSI  adapters
     under  Linux.  This  list  isn't  complete, usually any SCSI
     adapter supported by Linux should work.

          Acard/Advance SCSI adapters
               Some old versions of the kernel driver (atp870u.c)
               cut   the   inquiry  information.   Therefore  the
               scanner couldn't  be  detected  correctly.  Use  a
               current kernel.

          Adaptec AHA-1505/AHA-1542/AHA-2940
               Reported to work fine with Linux  since  v2.0.  If
               you  encounter  kernel freezes or other unexpected
               behaviour get  the  latest  Linux  kernel  (2.2.17
               seems  to  work)  or reduce SCSI buffer size to 32
               kB.

          ASUS SC200
               Reported to work fine with Linux v2.0.




sane-backends 1.0.19Last change: 28 Oct 2003                    4






SANE Scanner Access Now Easy                         sane-scsi(5)



          BusLogic BT958
               To configure the BusLogic card, you  may  need  to
               follow  these  instructions (contributed by Jeremy
               ):  During  boot,  when  your
               BusLogic   adapter  is  being  initialized,  press
               Ctrl-B  to  enter  your  BusLogic  adapter  setup.
               Choose  the address which your BusLogic containing
               your scanner is located. Choose ``SCSI Device Con-
               figuration''.   Choose  ``Scan SCSI Bus''.  Choose
               whatever SCSI id that contains  your  scanner  and
               then  choose  ``View/Modify  SCSI configuration''.
               Change ``Negotiation''  to  ``async''  and  change
               ``Disconnect''  to  ``off''.  Press Esc, save, and
               Esc again until you are asked to reboot.

          (DTCT436/436P) ISA SCSI card
          NCR/Symbios   53c400/53c400a    or    Domex    DTC3181E/L/LE
               This  card  is  supplied by Mustek (and other ven-
               dors). It's supported since Linux 2.2.   The  SCSI
               cards are supported by the module gNCR5380.  It's
               necessary to tell the kernel the io port and  type
               of   card.   Example  for  a  53c400a:  ``modprobe
               gNCR5380  ncraddr=0x280  ncr53c400a=1''.   Once
               the  kernel  detects  the card, it should work all
               right.  However, while  it  should  work,  do  not
               expect  good performance out of this card---it has
               no interrupt line and therefore while a scan is in
               progress, the system becomes almost unusable.  You
               may change the values  of  the  USLEP  macros  in
               drivers/scsi/gNCR5380.c.   Some  documentation is
               in this file and NCR5380.c.

          NCR/Symbios 810
               For some scanners it may be necessary  to  disable
               disconnect/reconnect.  To  achieve  this  use  the
               option ncr53c8xx="disc:n".  Some  people  reported
               that  their  scanner only worked with the 53c7,8xx
               driver, not the ncr53c8xx. Try both  if  you  have
               trouble.
               For Linux kernels before 2.0.33 it may  be  neces-
               sary  to  increase  the  SCSI timeout. The default
               timeout for the Linux kernels before 2.0.33 is  10
               seconds,  which is way too low when scanning large
               area.  If you get messages of the  form  ``restart
               (ncr  dead  ?)'' in your /var/log/messages file or
               on the system console, it's an indication that the
               timeout is too short.  In this case, find the line
               ``if (np->latetime>10)'' in file ncr53c8xx.c (nor-
               mally  in  directory  /usr/src/linux/drivers/scsi)
               and change  the  constant  10  to,  say,  60  (one
               minute).   Then  rebuild the kernel/module and try
               again.



sane-backends 1.0.19Last change: 28 Oct 2003                    5






SANE Scanner Access Now Easy                         sane-scsi(5)



          Tekram DC315
               The    driver    can    be     downloaded     from
               http:/www.garloff.de/kurt/linux/dc395/.  For some
               older scanners it may be necessary to disable  all
               the  more advanced features by using e.g. modprobe
               dc395xtrm dc395xtrm=7,5,1,32.

          Tekram DC390
               Version 1.11 of the Tekram driver  seems  to  work
               fine  mostly,  except  that the scan does not ter-
               minate properly (it causes a SCSI timeout after 10
               minutes).  The generic AM53C974 also seems to work
               fine and does not suffer from  the  timeout  prob-
               lems.


SOLARIS, OPENSTEP AND NEXTSTEP INFO
     Under Solaris, OpenStep and NeXTStep, the generic SCSI  dev-
     ice  name refers to a SCSI bus, not to an individual device.
     For example, /dev/sg0 refers to the first SCSI bus.  To tell
     SANE which device to use, append the character 'a']target-id
     to the special device name.  For example,  the  SCSI  device
     connected  to the first SCSI controller and with target-id 0
     would be called /dev/sg0a, and the device with  target-id  1
     on that same bus would be called /dev/sg0b, and so on.

ENVIRONMENT
     SANEDEBUGSANEISCSI
          If the library was compiled with debug support enabled,
          this  environment variable controls the debug level for
          the generic SCSI I/O subsystem.  E.g., a value  of  128
          requests all debug output to be printed by the backend.
          A value of 255 also prints  kernel  messages  from  the
          SCSI   subsystem  (where  available).   Smaller  levels
          reduce verbosity.

     SANESCSICMDTIMEOUT
          sets the timeout value for SCSI  commands  in  seconds.
          Overriding the default value of 120 seconds should only
          be necessary for very slow scanners.


SEE ALSO
     sane(7), sane-find-scanner(1), " .}S 3 1 "sane-backendname""
     "(5)," "" "" "" "" sane-usb(5)


AUTHOR
     David Mosberger

ATRIBUTES
     See  attributes(5)  for  descriptions   of   the   following



sane-backends 1.0.19Last change: 28 Oct 2003                    6






SANE Scanner Access Now Easy                         sane-scsi(5)



     attributes:

     
       ATRIBUTE TYPE     ATRIBUTE VALUE 
    
     Availability         SUNWsane-backend
    
     Interface Stability  Uncommitted     
    

NOTES
     Source for SANE is available on http:/opensolaris.org.











































sane-backends 1.0.19Last change: 28 Oct 2003                    7



OpenSolaris man pages main menu

Contact us      |       About us      |       Term of use      |       Copyright © 2000-2010 MyWebUniversity.com ™