« Epson Perfection 3490 Photo » : différence entre les versions

De Lea Linux
Aller à la navigation Aller à la recherche
Aucun résumé des modifications
 
(13 versions intermédiaires par 5 utilisateurs non affichées)
Ligne 1 : Ligne 1 :
= Epson Perfection 3490/3590 Photo =
Le scanner Epson Perfection 3490 n'est officiellement pas supporté par le [http://www.sane-project.org/sane-mfgs.html#Z-EPSON sane-projet.org].
Le scanner Epson Perfection 3490 n'est officiellement pas supporté par le [http://www.sane-project.org/sane-mfgs.html#Z-EPSON sane-projet.org].


Ligne 12 : Ligne 14 :
#libsane
#libsane
#xsane
#xsane
#le module « scanner » de doit PAS être installé
#le module « scanner » ne doit PAS être installé


libsane est nécessaire, car le pilote fourni par Epson s'appuie sur l'architecture de sane.
libsane est nécessaire, car le pilote fourni par Epson s'appuie sur l'architecture de sane.
Ligne 25 : Ligne 27 :
#Un câble USB2 à mettre sur votre ordinateur. Ca marche aussi en USB1 ou USB1.1 .
#Un câble USB2 à mettre sur votre ordinateur. Ca marche aussi en USB1 ou USB1.1 .
#un câble d’alimentation électrique
#un câble d’alimentation électrique
#Ne pas oublier de déverouiller le chariot (le bouton est en dessous, à l'avant du scanner)


== Installer les pilotes fournis par Epson ==
== Installer les pilotes fournis par Epson ==
Ligne 30 : Ligne 33 :


Il y a deux drivers différents ( selon le compilateur utilisé pour le noyau ). Dans mon cas, le deux ont marché de façon indifférente. Il semblerait que les utilisateurs Red Hat doivent utiliser la version pour GCC 3.2
Il y a deux drivers différents ( selon le compilateur utilisé pour le noyau ). Dans mon cas, le deux ont marché de façon indifférente. Il semblerait que les utilisateurs Red Hat doivent utiliser la version pour GCC 3.2
Il y a deux fichiers à installer :
#iscan
#les pilotes pour le modèle 3490


=== Utilisateurs dont le gestionnaire de paquetages utilise des rpm ===
=== Utilisateurs dont le gestionnaire de paquetages utilise des rpm ===
Installer directement le paquetage ( en tant que root ) :
Installer directement les paquetages ( en tant que root ) :
<div class="code"><pre>
<div class="code"><pre>
rpm -i iscan-1.17.0-1.c2.i386.rpm
rpm -i iscan-2.4.0-0.c2.i386.rpm
rpm -i iscan-plugin-gt-f520-1.0.0-1.c2.i386.rpm
</pre></div>
</pre></div>


=== Utilisateurs dont le gestionnaire de paquetages utilise des .deb ===
=== Utilisateurs dont le gestionnaire de paquetages utilise des .deb ===
Les utilisateurs de debian et assimilables doivent convertir le .rpm en .deb par la commande alien ( installer alien au besoin ), puis installer le paquetage ( en tant que root ) :
Les utilisateurs de debian et assimilables doivent convertir les .rpm en .deb par la commande alien ( installer alien au besoin ), puis installer les paquetages ( en tant que root ) :
<div class="code"><pre>
alien -i iscan-2.4.0-0.c2.i386.rpm
alien -i iscan-plugin-gt-f520-1.0.0-1.c2.i386.rpm
dpkg -i iscan_2.4.0-1_i386.deb
dpkg -i iscan-plugin-gt-f520_1.0.0-2_i386.deb
</pre></div>
 
=== Donner accès en lecture aux pilotes Epson ===
Les droits par défaut livrés avec les pilotes fournis par Epson ne permettent pas l'acquisition de données.
 
Il faut changer ces droits et/ou le propriétaire .
Le plus simple :
<div class="code"><pre>
<div class="code"><pre>
alien -i iscan-1.17.0-1.c2.i386.rpm<br>
chmod 444 /usr/share/iscan/*
dpkg -i iscan_1.14.0-4_i386.deb
</pre></div>
</pre></div>


Ligne 47 : Ligne 66 :
Indiquer que les scanners de marque « epkowa » sont autorisés en rajoutant epkowa dans le fichier suivant :
Indiquer que les scanners de marque « epkowa » sont autorisés en rajoutant epkowa dans le fichier suivant :
<div class="code"><pre>
<div class="code"><pre>
vi /etc/sane.d/dll.conf<br>
vi /etc/sane.d/dll.conf


epkowa
epkowa
Ligne 56 : Ligne 75 :
Pour vérifier l'efficacité de cette manoueuvre, en tant que root, taper :
Pour vérifier l'efficacité de cette manoueuvre, en tant que root, taper :
<div class="code"><pre>
<div class="code"><pre>
root@mimosa:~$ sane-find-scanner<br>
root@mimosa:~$ sane-find-scanner
   # sane-find-scanner will now attempt to detect your scanner. If the
   # sane-find-scanner will now attempt to detect your scanner. If the
   # result is different from what you expected, first make sure your
   # result is different from what you expected, first make sure your
Ligne 187 : Ligne 206 :


Le script /etc/hotplug.d/usb/libsane.hotplug se charge, entre autre, de gérer les bons droits sur le périphérique. Il est redondant avec /etc/hotplug/usb/iscan-device. Il faut éditer soit l'un, soit l'autre.
Le script /etc/hotplug.d/usb/libsane.hotplug se charge, entre autre, de gérer les bons droits sur le périphérique. Il est redondant avec /etc/hotplug/usb/iscan-device. Il faut éditer soit l'un, soit l'autre.
Enfin, si on veut vraiement gérer proprement les droits, ceux que nous avons octroyés aux bibliothèques fournis par Epson sont un peu larges.<br>
On va d'abord changer le groupe de ces fichiers : ce sera désormais "scanner"<br>
On va réduire les droits en lecture au propiétaire et au groupe.<br>
Ces deux opérations ne peuvent se faire qu'avec les droits root.<br>
<div class="code"><pre>
chgrp scanner /usr/share/iscan/*
chmod 440 /usr/share/iscan/*
</pre></div>


== Logiciels d'accès au scanner==
== Logiciels d'accès au scanner==
Ligne 341 : Ligne 369 :
LABEL="libsane_rules_end"
LABEL="libsane_rules_end"
</pre></div>
</pre></div>
<br/>
<br/>
'''<b>[[Matériel|@ Retour à la rubrique Matériel]]</b>'''
<br/>
{{Copy|Décembre 2005|[[Utilisateur:Martin.riondet|Martin.riondet]]|CC-BY-SA}}
[[Catégorie:Matériel]]

Dernière version du 28 décembre 2023 à 16:53

Epson Perfection 3490/3590 Photo

Le scanner Epson Perfection 3490 n'est officiellement pas supporté par le sane-projet.org.

Pour autant, il est possible de le faire fonctionner sous linux en utilisant les pilotes fournis par Epson.

Bien que je ne l'ai pas essayé, il semblerait que le scanner Perfection 3590 ne soit qu'un clone du 3490 et que la configuration soit la même.

La section de ce document concerne la gestion des droits sur les scanners USB et devrait pouvoir être adaptable à tous les scanners usb.

Pré requis

  1. noyau 2.6.12 ou supérieur avec udev
  2. libusb
  3. libsane
  4. xsane
  5. le module « scanner » ne doit PAS être installé

libsane est nécessaire, car le pilote fourni par Epson s'appuie sur l'architecture de sane. La configuration sur laquelle ce scanner a été installé est une debian sarge ( stable ) avec noyau 2.6.12 en provenance de debian sid ( unstable )

Par rapport au module scanner, tout en n'étant pas installé, il peut arriver qu'il existe un fichier /etc/modprobe.d/libsane qui génère des messages d'erreur au boot.
Commenter les deux ligne qu'il contient, ou carrément détruire le fichier.

Installation

Pour l’installation c’est pas trop compliqué :

  1. Un câble USB2 à mettre sur votre ordinateur. Ca marche aussi en USB1 ou USB1.1 .
  2. un câble d’alimentation électrique
  3. Ne pas oublier de déverouiller le chariot (le bouton est en dessous, à l'avant du scanner)

Installer les pilotes fournis par Epson

Vu qu'Epson nous met à disposition les pilotes, on va aller les chercher sur leur site internet.

Il y a deux drivers différents ( selon le compilateur utilisé pour le noyau ). Dans mon cas, le deux ont marché de façon indifférente. Il semblerait que les utilisateurs Red Hat doivent utiliser la version pour GCC 3.2

Il y a deux fichiers à installer :

  1. iscan
  2. les pilotes pour le modèle 3490

Utilisateurs dont le gestionnaire de paquetages utilise des rpm

Installer directement les paquetages ( en tant que root ) :

rpm -i iscan-2.4.0-0.c2.i386.rpm
rpm -i iscan-plugin-gt-f520-1.0.0-1.c2.i386.rpm

Utilisateurs dont le gestionnaire de paquetages utilise des .deb

Les utilisateurs de debian et assimilables doivent convertir les .rpm en .deb par la commande alien ( installer alien au besoin ), puis installer les paquetages ( en tant que root ) :

alien -i iscan-2.4.0-0.c2.i386.rpm
alien -i iscan-plugin-gt-f520-1.0.0-1.c2.i386.rpm
dpkg -i iscan_2.4.0-1_i386.deb
dpkg -i iscan-plugin-gt-f520_1.0.0-2_i386.deb

Donner accès en lecture aux pilotes Epson

Les droits par défaut livrés avec les pilotes fournis par Epson ne permettent pas l'acquisition de données.

Il faut changer ces droits et/ou le propriétaire . Le plus simple :

chmod 444 /usr/share/iscan/*

Configurer sane

Indiquer que les scanners de marque « epkowa » sont autorisés en rajoutant epkowa dans le fichier suivant :

vi /etc/sane.d/dll.conf

epkowa

Pour forcer un chargement du module fourni par Epson, débrancher et rebrancher le scanner.

Pour vérifier l'efficacité de cette manoueuvre, en tant que root, taper :

root@mimosa:~$ sane-find-scanner
  # sane-find-scanner will now attempt to detect your scanner. If the
  # result is different from what you expected, first make sure your
  # scanner is powered up and properly connected to your computer.

  # No SCSI scanners found. If you expected something different, make sure that
  # you have loaded a SCSI driver for your SCSI adapter.
  # Also you need support for SCSI Generic (sg) in your operating system.
  # If using Linux, try "modprobe sg".
found USB scanner (vendor=0x04b8 [EPSON], product=0x0122 [EPSON Scanner]) at libusb:001:002
  # Your USB scanner was (probably) detected. It may or may not be supported by
  # SANE. Try scanimage -L and read the backend's manpage.

  # Not checking for parallel port scanners.

  # Most Scanners connected to the parallel port or other proprietary ports
  # can't be detected by this program.

  # You may want to run this program as root to find all devices. Once you
  # found the scanner devices, be sure to adjust access permissions as
  # necessary.

Notre scanner a bien été reconnu.
Nous allons vérifier qu'il est bien supporté par sane :

root@mimosa:~$ scanimage -L
device `epkowa:libusb:001:002' is a Epson Perfection 3490/3590 flatbed scanner

Notre scanner est bien supporté désormais par sane ( si cette étape échoue, inutile de continuer ).

Vérifier qu'un utilisateur normal peut se connecter, en utilisant les mêmes commandes. Si il y a un pb, cf plus bas.

Dans tous les cas, afin d'améliorer la sécurité du système, il est préconisé d'effectuer les tâches de sécurisation décrites ci-après.

Gérer proprement les droits

Cette section s'applique à tous les scanners usb, quelle que soit la marque et le modèle. Cela évite d'avoir à se torturer en ce qui concerne la gestion des droits d'accès.

Sous debian, les utilisateurs du scanner sont ceux qui font partie du groupe « scanner ». Commencer donc par vérifier que vos utilisateurs habilités à l'utilisation du scanner font partie de ce groupe.

Si un utilisateur déjà loggé est ajouté à un groupe, il doit se délogguer et se relogguer pour que la modification prenne effet.

Il faut commencer par demander à lsusb quel est le modèle de notre scanner :

root@mimosa:~$ lsusb
Bus 002 Device 001: ID 0000:0000
Bus 001 Device 002: ID 04b8:0122 Seiko Epson Corp.
Bus 001 Device 001: ID 0000:0000

L'ID du vendeur est 04b8 ( normal, c'est un epson )
L'ID du scanner est 0122
Le scanner est sur le bus 001 et de device 002.
Le bus est donc : /proc/bus/usb/001
Le périphérique est le fichier 002 contenu dans ce répertoire.

Exemple :

martin@mimosa:~$ ls -lrt /proc/bus/usb/001/002
-rw-rw-rw-  1 root root 57 2005-12-17 19:55 002

On voit que les droits sont assez larges : rw- pour tous : tout le monde peut accéder au scanner.

Editer le fichier suivant ( en tant que root ) :

vi /etc/sane.d/hotplug/libsane.db

Rajouter les lignes suivantes :

 # Epson Corp.|Perfection 3490/3590
0x04b8  0x0122  root:scanner    0660

Ces lignes peuvent êtres rajoutées juste en dessous du scanner Perfection 2480, par exemple, qui a le numéro de produit précédent (0121 ).

D'une façon générale, la syntaxe est la suivante :
0x+IdVendeur Ox+IdScanner propriétaire:groupe droits

On reconnaît dans les deux premières positions l'ID du vendeur ( précédé de 0x ) et l'ID du scanner ( précédé de 0x )
On indique que le périphérique sera créé avec l'utilisateur root et le groupe scanner, avec des droits rw-rw---- ( 660 )

Débrancher et rebrancher le scanner :

martin@mimosa:~$ ls -lrt /proc/bus/usb/001/
total 0
-rw-r--r--  1 root root    43 2005-12-17 19:43 001
-rw-rw----  1 root scanner 57 2005-12-17 20:04 003

On constate que :
suite au débranchement du scanner, le numéro de périphérique a changé seuls l'utilisateur root et le groupe scanner ont désormais accès au périphérique

Pour les personnes utilisant le driver iscan, fourni par Epson, les droits par défaut sont gérés dans le fichier :

vi /etc/hotplug/usb/iscan-device

Remplacer :

DEFAULT_OWNER=root
DEFAULT_GROUP=root
DEFAULT_PERMS=0666

par :

DEFAULT_OWNER=root
#DEFAULT_GROUP=root
#DEFAULT_PERMS=0666
DEFAULT_GROUP=scanner
DEFAULT_PERMS=0660

Ce sont les droits par défaut qui étaient responsable de la largesse des droits octroyés avant de déclarer le scanner dans libsane.db.

il y a un autre fichier de conf qu'il est possible de renseigner, et qui devrait intéresser justement ceux qui n'utilisent pas iscan :

vi /etc/udev/libsane.rules

rajouter les lignes suivantes :

# Epson Corp.|Perfection 3490
SYSFS{idVendor}=="04b8", SYSFS{idProduct}=="0122", MODE="660", GROUP="scanner", RUN+="/etc/hotplug.d/usb/libsane.hotplug"

d'une façon plus générale :
SYSFS{idVendor}=="IdVendeur", SYSFS{idProduct}=="IdScanner, MODE="droits", GROUP="groupe", RUN+="/etc/hotplug.d/usb/libsane.hotplug"

Noter l'absence du 0x devant les id dans ce fichier

Le script /etc/hotplug.d/usb/libsane.hotplug se charge, entre autre, de gérer les bons droits sur le périphérique. Il est redondant avec /etc/hotplug/usb/iscan-device. Il faut éditer soit l'un, soit l'autre.

Enfin, si on veut vraiement gérer proprement les droits, ceux que nous avons octroyés aux bibliothèques fournis par Epson sont un peu larges.
On va d'abord changer le groupe de ces fichiers : ce sera désormais "scanner"
On va réduire les droits en lecture au propiétaire et au groupe.
Ces deux opérations ne peuvent se faire qu'avec les droits root.

chgrp scanner /usr/share/iscan/*
chmod 440 /usr/share/iscan/*

Logiciels d'accès au scanner

Le plus couremment utilisé est xsane, auquel on peut accéder directement comme une extension de Gimp.
Avec ses drivers, Epson fourni iscan, qui offre une interface simple mais efficace au scanner. Il est possible de rendre iscan accessible depuis gimp :

ln -s /usr/bin/iscan ~/.gimp2.2/plug-ins

Exemples de fichiers de conf ( extraits )

/etc/sane.d/dll.conf

# /etc/sane.d/dll.conf - Configuration file for the SANE dynamic backend loader
#
# On Debian systems, the dll backend will also look for pieces of configuration
# in the /etc/sane.d/dll.d directory -- packages providing backends should drop
# a config file similar to dll.conf in this directory.
#

# enable the next line if you want to allow access through the network:
net
abaton
agfafocus
[...]
dmc
epson
epkowa
fujitsu
#gphoto2
[...]
hp5400
ibm
[...]


/etc/sane.d/hotplug/libsane.db

# /etc/sane.d/dll.conf - Configuration file for the SANE dynamic backend loader
# This file is part of the SANE distribution
#
# USB Vendor/Product IDs for scanners supported by SANE
#
# 0xVVVV<tab>0xPPPP<tab>root:scanner<tab>0660<tab>[/usr/local/bin/foo.sh]
#
# The following list already contains a lot of scanners. If your scanner
# isn't mentioned there, add it as explained above and mail the entry to
# the sane-devel mailing list.
#
# Hewlett-Packard|ScanJet 4100C
0x03f0  0x0101  root:scanner    0660
[...]
# Epson Corp.|Perfection 2480
0x04b8  0x0121  root:scanner    0660
# Epson Corp.|Perfection 3490/3590
0x04b8  0x0122  root:scanner    0660
# Epson Corp.|GT-15000 (ES-7000)
[...]


/etc/hotplug/usb/iscan-device.
Ce fichier fait partie des éléments fournis par Epson dans son paquetage iscan.

#!/bin/sh
# iscan-device -- modifies device permissions for supported devices
# Copyright (C) 2005  SEIKO EPSON Corporation

# This file is part of "Image Scan! for Linux".
# You can redistribute it and/or modify it under the terms of the GNU
# General Public License as published by the Free Software Foundation;
# either version 2 of the License or at your option any later version.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY;  without even the implied warranty of FITNESS
# FOR A PARTICULAR PURPOSE or MERCHANTABILITY.
# See the GNU General Public License for more details.
#
# You should have received a verbatim copy of the GNU General Public
# License along with this program; if not, write to:
#
#      Free Software Foundation, Inc.
#      59 Temple Place, Suite 330
#      Boston, MA  02111-1307  USA

# This script changes the permissions and ownership of a USB device
# under /proc/bus/usb to grant access to the device to users.  This
# will be done according to system policy wherever possible, but as
# a fallback access will be granted to _all_ users.

# Of course, fallback behaviour can be customised ;-)
#
DEFAULT_OWNER=root
DEFAULT_GROUP=scanner
DEFAULT_PERMS=0660

# Rely on the sane-backends script (or a vendor specific script) if
# available.  Distributors have probably modified it to suit system
# policy.  Following is a list of scripts out there in the wild and
# some notes on where they have been observed.
#
#   libusbscanner       sane-backends (>= 1.0.14)
#   usbscanner          Mandrake 10
#   desktopdev          SUSE 9.1 Pro
#
USB_SCRIPTS="libusbscanner
             usbscanner
             desktopdev
            "
for script in $USB_SCRIPTS; do
    if [ -x $HOTPLUG_DIR/$TYPE/$script ]; then
        exec $HOTPLUG_DIR/$TYPE/$script
    fi
done

# Activate fallback settings
#
if [ "$ACTION" == add -a "$TYPE" == "usb" ]; then
    chown $DEFAULT_OWNER:$DEFAULT_GROUP "$DEVICE"
    chmod $DEFAULT_PERMS "$DEVICE"
fi                                                                         


/etc/udev/libsane.rules

# This file is part of the SANE distribution
#
# udev rules file for supported scanners
#
#
# For now, only USB scanners are listed/supported by this set of rules;
# feel free to add support for other busses.
#
# To add an USB scanner, add a rule to the list below between the SUBSYSTEM...
# and LABEL... lines.
#
# To run a script when your scanner is plugged in, add RUN="/path/to/script"
# to the appropriate rule.
#

SUBSYSTEM!="usb_device", ACTION!="add", GOTO="libsane_rules_end"

# Hewlett-Packard|ScanJet 4100C
SYSFS{idVendor}=="03f0", SYSFS{idProduct}=="0101", MODE="660", GROUP="scanner", RUN+="/etc/hotplug.d/usb/libsane.hotplug"
# Hewlett-Packard|PhotoSmart S20
SYSFS{idVendor}=="03f0", SYSFS{idProduct}=="0102", MODE="660", GROUP="scanner", RUN+="/etc/hotplug.d/usb/libsane.hotplug"
# Hewlett-Packard|ScanJet 4200C
[...]# Epson Corp.|Perfection 2480
SYSFS{idVendor}=="04b8", SYSFS{idProduct}=="0121", MODE="660", GROUP="scanner", RUN+="/etc/hotplug.d/usb/libsane.hotplug"
# Epson Corp.|Perfection 3490
SYSFS{idVendor}=="04b8", SYSFS{idProduct}=="0122", MODE="660", GROUP="scanner", RUN+="/etc/hotplug.d/usb/libsane.hotplug"
# Epson Corp.|GT-15000 (ES-7000)
SYSFS{idVendor}=="04b8", SYSFS{idProduct}=="0126", MODE="660", GROUP="scanner", RUN+="/etc/hotplug.d/usb/libsane.hotplug"
[...]

LABEL="libsane_rules_end"




@ Retour à la rubrique Matériel

Copyright

© Décembre 2005 Martin.riondet

Creative Commons License
Creative Commons Attribution iconCreative Commons Share Alike icon
Ce document est publié sous licence Creative Commons
Attribution, Partage à l'identique 4.0 :
https://creativecommons.org/licenses/by-sa/4.0/