Linux sane scanner access now easy

Содержание
  1. Linux sane scanner access now easy
  2. Пакет SANE-1.0.19
  3. Знакомимся с пакетом SANE
  4. Информация о движках
  5. Информация о внешних интерфейсах
  6. Зависимости пакета SANE
  7. Необязательные (движки)
  8. Необязательные (внешние интерфейсы)
  9. Конфигурирование ядра
  10. Установка пакета SANE
  11. Установка движков пакета SANE
  12. Установка внешних интерфейсов пакета SANE
  13. Пояснение команд
  14. Конфигурирование пакета SANE
  15. Конфигурационные файлы
  16. Подробнее о конфигурировании
  17. Конфигурирование движков
  18. Общая информация
  19. Конфигурирование и настройка демона ‘saned’
  20. Описание пакета
  21. Движки:
  22. Внешние интерфейсы:
  23. Linux sane scanner access now easy
  24. Contents
  25. Installation
  26. Verification
  27. Installing a scanner driver
  28. Firmware
  29. Fujitsu fi series
  30. Install a frontend
  31. Network scanning
  32. Network attached scanners
  33. Scanning over the network with Canon PIXMA or imageCLASS all-in-one printer/scanners
  34. Scanning over the network with EPSON WorkForce printer/scanners
  35. Sharing your scanner over a network
  36. Accessing your scanner from a remote workstation
  37. Windows clients
  38. Troubleshooting
  39. Invalid argument
  40. Missing firmware file
  41. Wrong firmware file permissions
  42. Multiple backends claim scanner
  43. Communication via xHCI not working (older scanner models)
  44. Firewall
  45. Slow startup
  46. Device busy
  47. Permission problem
  48. Parallel port scanners
  49. avahi-daemon is not mandatory

Linux sane scanner access now easy

Библиотека сайта rus-linux.net

На главную -> MyLDP -> Электронные книги по ОС Linux

Beyond Linux From Scratch. Version 2011-12-30
Назад 44. Сканирование Вперед

Пакет SANE-1.0.19

Знакомимся с пакетом SANE

SANE — это сокращение Scanner Access Now Easy (Доступ к сканеру стал простым). Однако доступ к сканеру далеко не прост, поскольку каждый производитель имеет свои собственные протоколы. Известен единственный протокол, который должен внести некоторое единство в этот хаос, это — интерфейс TWAIN, но он слишком нечеткий с тем, чтобы стать стабильным фреймворком сканирования. Поэтому пакет SANE поставляется со своим собственным протоколом и драйверы, поставляемые производителями сканеров, использоваться не могут.

SANE состоит из движков (back ends) и внешних интерфейсов (front ends). Движки являются драйверами для поддерживаемых сканеров и фотокамер. Внешние интерфейсы являются пользовательскими интерфейсами для доступа к движкам.

Информация о движках

  • Загрузка (HTTP): http://alioth.debian.org/download.php/2318/sane-backends-1.0.19.tar.gz
  • Загрузка (FTP): ftp://ftp2.sane-project.org/pub/sane/old-versions/sane-backends-1.0.19/sane-backends-1.0.19.tar.gz
  • Контрольная сумма MD5: 8c0936272dcfd4e98c51512699f1c06f
  • Размер загружаемого пакета: 4,1 MB
  • Оценочный размер требуемого дискового пространства: 71 MB
  • Оценочное время сборки: 1,5 SBU

Информация о внешних интерфейсах

  • Загрузка (HTTP): http://alioth.debian.org/download.php/1140/sane-frontends-1.0.14.tar.gz
  • Загрузка (FTP): ftp://ftp2.sane-project.org/pub/sane/sane-frontends-1.0.14/sane-frontends-1.0.14.tar.gz
  • Контрольная сумма MD5: c63bf7b0bb5f530cf3c08715db721cd3
  • Размер загружаемого пакета: 231 KB
  • Оценочный размер требуемого дискового пространства: 3,0 MB
  • Оценочное время сборки: менее 0,1 SBU

Зависимости пакета SANE

Необязательные (движки)

Необязательные (внешние интерфейсы)

Конфигурирование ядра

Чтобы получить доступ к сканеру, вам, возможно, потребуются соответствующие драйверы ядра и / или дополнительные пакеты поддержки. Для сканера SCSI понадобятся драйверы SCSI, сканеру, подключаемому к параллельному порту, потребуется поддержка работы с параллельным портом (вы должны использовать расширенные режимы EPP) и, возможно, пакет libieee1284 , а для сканера USB понадобится пакет libusb-1.0.8. Убедитесь, что у вас есть необходимые драйверы, которые должным образом настроены для доступа к устройствам.

Установка пакета SANE

Установка движков пакета SANE

Демон SANE должен работать в своей собственной группе. Создайте эту группу в роли пользователя root с помощью следующих команд:

Установите пакет SANE-backends с помощью следующих команд:

В этом пакете набор тестов отсутствует.

Теперь в роли пользователя root выполните:

Установка внешних интерфейсов пакета SANE

В состав пакета SANE-frontends входят внешние графические интерфейсы xscanimage и xcam, а также интерфейс командной строки scanadf. Вам не нужен этот пакет в случае, если вы собираетесь использовать один из более продвинутых графических внешних интерфейсов, например, XSane-0.994. Список пакетов с внешними интерфейсвми можно найти по ссылке http://www.sane-project.org/sane-frontends.html .

Чтобы установить пакет SANE-frontends используйте следующие команды:

В этом пакете набор тестов отсутствует.

Теперь в роли пользователя root выполните:

Если к сборке был прикомпонован GIMP и вы хотите, чтобы в GIMP в качестве плагина сканирования использовался xscanimage, то в роли пользователя root выполните следующую команду:

Пояснение команд

sed -i ‘s/SYSFS/ATTRS/g’ tools/sane-desc.c: Данная команда исправляет устаревший параметр udev.

—sysconfdir=/etc : С помощью этого переключателя указывается, что конфигурационные файлы будут установлены в директории /etc/sane.d , а не в директории /usr/etc/sane.d .

Конфигурирование пакета SANE

Конфигурационные файлы

Подробнее о конфигурировании

Конфигурирование движков

Конфигурационные файлы движков находятся в директории /etc/sane.d . Информацию о конфигурировании различных движков можно найдены на странице man(5) соответствующего движка. для желаемого бэкэнда. Запустите команду man sane- , подставив название соответствующего движка.

Добавьте любого необходимого пользователя в группу scanner .

Общая информация

Для получения общей информации о конфигурировании и использовании пакета SANE смотрите страницу man sane. Ядро Linux-2.6.x вносит в общую картину некоторые специальные вопросы. Информацию об использовании SANE с ядром Linux-2.6.x смотрите по ссылке http://www.sane-project.org/README.linux . Чтобы получить информацию о сканирующих устройствах, использующих USB, запустите команду man sane-usb. Для получения информации об устройствах SCSI запустите команду man sane-scsi.

Конфигурирование и настройка демона ‘saned’

Демон saned не должен использоваться с ненадежными клиентами. Вы должны с помощью пакетов TCP Wrapper-7.6 и/или Firewalling обеспечить защиту с тем, чтобы только доверенные клиенты могли получить доступ к демону. Из-за сложных требований к безопасности, которые могут гарантировать что только доверенные клиенты будут получать доступ к демону, в BLFS не предлагаются инструкции по настройке демона saned. Если вы желаете иметь доступ к демону, убедитесь, что вы обеспечили надлежащую безопасность, настройте файл [x]inetd.conf и отправьте демону [x]inetd команду SIGHUP . Некоторую полезную информацию по настройке демона saned и обеспечения его безопасности можно найти по ссылке http://penguin-breeder.org/sane/saned/ .

Читайте также:  Оригинальный реестр windows 10

Описание пакета

Движки:

Установленные программы: gamma4scanimage, sane-config, saned, sane-find-scanner и scanimage

Установленные библиотеки: libsane.so и многочисленные модули движков

Установленные директории: /etc/sane.d, /usr/include/sane, /usr/lib/sane, /usr/share/sane и /usr/share/doc/sane-1.0.19

Внешние интерфейсы:

Установленные программы: scanadf, xcam и xscanimage

Установленные библиотеки: плагин GIMP, встроенный в xscanimage

Установленные директории: Нет

создает гамма-таблицу в формате, пригодном для scanimage

инструментальное средство, используемое для определения флагов компиляции и компоновки, которые должны использоваться при компиляции и компоновке пакета SANE

демон SANE, который позволяет удаленным клиентам получать доступ к устройствам захвата изображений, доступным на локальном хосте

инструмент командной строки для поиска сканеров SCSI и USB и определения их файлов устройств. Его основной задачей является проверка, позволяющая убедиться, что сканеры могут быть обнаружены движками пакета SANE

интерфейс командной строки для управления устройствами захвата изображений, которые оснащены механизмом автоматической подачи документов (ADF)

интерфейс командной строки для сканирования с помощью устройств захвата изображений, таких как планшетные сканеры и фотокамеры. Также используется для вывода списка устройств, для которых есть движки

графический внешний интерфейс пакета SANE для использования с фотокамерой

графический пользовательский интерфейс, используемый при сканировании

интерфейс прикладного программирования, который используется для обмена данными между внешним интерфейсом и движками

модули, являющиеся библиотечными плагинами, используемыми в качестве движков для взаимодействия со сканирующими устройствами. Список поддерживаемых движков смотрите по ссылке http://www.sane-project.org/sane-supported-devices.html

Перевод сделан с варианта оригинала, датированного 2011-01-18 00:13:43 +0000

Источник

Linux sane scanner access now easy

SANE (Scanner Access Now Easy) provides a library and a command-line tool to use scanners under GNU/Linux.

Check if your scanner supports eSCL or WSD; chances are good if your device is on this Internet Printing Protocoll — IPP list of devices that support eSCL. If your device has eSCL/WSD support, modern «driverless» scanning is recommended.

Contents

Installation

Install the sane-airscan package if the scanner is known to work in driverless mode. If your scanner is using USB connection, make sure to also install the ipp-usb package and start/enable ipp-usb.service to allow using IPP protocol over USB connection.

If not, see [1] to check if SANE supports your scanner using a classic driver.

Install the sane package to use old driver-based scanning.

Verification

Now you can try to see if sane recognizes your scanner.

If that fails, run the command again as root to check for permission problems. If that fails as well, check that your scanner is plugged into the computer. You also might have to unplug/plug your scanner for /usr/lib/udev/rules.d/65-sane.rules to recognize your scanner.

Now you can see if it actually works

If the scanning fails with the message scanimage: sane_start: Invalid argument you may need to specify the device.

Then you would need to run

Sane provides many special backend options for numerous scanner types. To see what these are for your device:

Installing a scanner driver

Most scanners should work out of the box. If yours does not, see SANE/Scanner-specific problems for installation instructions.

Firmware

Firmwares usually have the .bin extension.

Firstly you need to put the firmware someplace safe, it is recommended to put it in a subdirectory of /usr/share/sane/ .

Then you need to tell sane where the firmware is:

  • Find the name of the backend for your scanner from the sane supported devices list.
  • Open the file /etc/sane.d/backend-name.conf .
  • Make sure the firmware entry is uncommented and let the file-path point to where you put the firmware file for your scanner. Be sure that members of the group scanner can access the /etc/sane.d/backend-name.conf file.

If the backend of your scanner is not part of the sane package (such as hpaio.conf which is part of hplip ), you need to uncomment the relevant entry in /etc/sane.d/dll.d or in /etc/sane.d/dll.conf .

Fujitsu fi series

For some of the Fujitsu fi series document scanners, the pfufs AUR proprietary driver offers advanced functionality over the already mature SANE default driver, such as control of an optional imprinter for stamping scanned documents or requesting accurate status of the consumables from the host.

Install a frontend

Many frontends exist for SANE, a non-exhaustive list of which can be found on the sane-project website.

  • Simple Scan — Simplified GUI that is intended to be easier to use and better integrated into the GNOME desktop than XSane. It was initially written for Ubuntu and is maintained by Robert Ancell of Canonical Ltd. for GNU/Linux.
Читайте также:  How to add user to group in windows

https://gitlab.gnome.org/GNOME/simple-scan || simple-scan

  • Skanlite — Simple image scanning application that does nothing more than scan and save images, based on the KSane backend.

https://www.kde.org/applications/graphics/skanlite || skanlite

  • XSane — Full-featured GTK-based frontend looking a bit old but providing extended functionalities.

http://www.xsane.org/ || xsane

Some OCR software are able to scan images using SANE: gImageReader, gscan2pdf, Linux-Intelligent-Ocr-Solution, OCRFeeder, Paperwork.

The factual accuracy of this article or section is disputed.

  • Using a frontend does not mean you do not have to apply some tricks. This is especially true with devices configured via mDNS. For example, skanlite needs to have additional info specified on the command line in order to detect a network scanner properly as it cannot handle mDNS. Here is an example with an HP Officejet Pro L7590: skanlite —device «hpaio:/net/Officejet_Pro_L7500?ip=192.168.0.17» .

Network scanning

Network attached scanners

Many modern scanners will immediately work over the network as long as you have sane-airscan installed.

Scanning over the network with Canon PIXMA or imageCLASS all-in-one printer/scanners

Find out your printer/scanner’s IP address, and add it on a new line to /etc/sane.d/pixma.conf in the format bjnp://10.0.0.20 . For imageCLASS printers you may need to use the format mfnp://10.0.0.20 instead.

Sane should now find your device. For more details refer to sane-pixma(5) .

Alternatively, scangearmp2 AUR can be used for some Canon PIXMA all-in-one printer/scanners which are not detected over the network.

Scanning over the network with EPSON WorkForce printer/scanners

Edit the configuration file /etc/utsushi/utsushi.conf . Find the [devices] section and edit the template for dev2 . Replace the IP address accordingly. You can find the IP address on your printer screen. For example,

Meanwhile, comment out epson2 in /etc/sane.d/dll.conf as it conflicts with ImageScan.

Once this is done you can use any SANE frontend to access this scanner.

Sharing your scanner over a network

You can share your scanner with other hosts on your network who use sane, xsane or xsane-enabled GIMP. To set up the server, first indicate which hosts on your network are allowed access.

Change the /etc/sane.d/saned.conf file to your liking, for example:

If you use iptables, insert the nf_conntrack_sane module to let the firewall track saned connections.

Conntrack helper seems to be disabled by default.[2] You can activate it with

To configure this permanently, set the nf_conntrack_helper=1 option for the nf_conntrack module, see Kernel module#Using files in /etc/modprobe.d/.

Now start/enable saned.socket . Your scanner is now available over the network. For more information, see saned(8) .

Accessing your scanner from a remote workstation

You can access your network-enabled scanner from a remote Arch Linux workstation.

First, specify the server’s host name or IP address in the /etc/sane.d/net.conf file:

Now test your workstation’s connection:

The network scanner should now also show up in any front-end.

Windows clients

Since the Windows port of SANE seems to be unsupported, outdated and difficult to get, you can try SANEWinDS or SaneTwain (old).

Troubleshooting

Invalid argument

If you get an «Invalid argument» error with xsane or another sane front-end, this could be caused by one of the following reasons:

Missing firmware file

No firmware file was provided for the used scanner (see #Firmware for details).

Wrong firmware file permissions

The permissions for the used firmware file are wrong. Correct them using

Multiple backends claim scanner

It may happen, that multiple backends support (or pretend to support) your scanner, and sane chooses one that does not do after all (the scanner will not be displayed by scanimage -L then). This has happened with older Epson scanners and the epson2 resp. epson backends. In this case, the solution is to comment out the unwanted backend in /etc/sane.d/dll.conf . In the Epson case, that would be to change

This article or section is out of date.

It may also be possible that the independent iscan [broken link: package not found] epkowa backend interferes with your snapscan backend (epson scanners). You may get this error right after using the scanimage -L command. Starting the scanner app (like xsane ) twice can also solve the problem. Otherwise check your /etc/sane.d/epkowa.conf for wrong configurations or remove the iscan [broken link: package not found] package.

Communication via xHCI not working (older scanner models)

Some older scanner models do not work when connected via an USB3 port. If you experience this issue, try setting the SANE_USB_WORKAROUND=1 environment variable before starting your frontend.[4][5]

Читайте также:  Автозагрузка mac os чистка

If that does not work, try one of the following workarounds:

  • Use an USB2 port instead of an USB3 port, if available.
  • Disable xHCI via BIOS/EFI. eHCI will consequently be used and communication with the scanner will work. On the downside, USB3 speed can not be reached on any port.
  • On (some) intel chipsets the setpci command can be used to route specific usb ports to either the xHCI or the eHCI controller. See here and here (scroll down to where it says «setpci») for further information. With this it is possible to toggle single USB ports with a simple shell script.
  • Connect the scanner over the network instead if it is supported.

Firewall

When network scanning scanner hangs, then invalid argument error occured.

saned uses data port range, so you must enable connections to 6566/tcp and data_portrange from /etc/sane.d/saned.conf or use conntrack firewall module for sane to enable data ports as described above.

Slow startup

If you encounter slow startup issue (e.g. xsane or scanimage -L does not return results nearly instantly), one of the drivers you do not use may be the culprit.

You can resolve this by editing /etc/sane.d/dll.conf and commenting out the scanner drivers you do not use. You can use scanimage -L to determine which drivers you need:

The parts between the ` and the : in the output indicate the driver for the device. For example, if only want to use the Brother scanner and not the webcam or the generic scanner driver, you can comment out everything but the brother4 driver in /etc/sane.d/dll.conf .

Device busy

The factual accuracy of this article or section is disputed.

If your USB device is listed with scanimage -L but launching the test scanimage pixma:04A9173E_11DAD1 —format=tiff —output-file test.tiff always return the ‘Device busy’ error, you might try to add your username to the scanner group usermod -a -G scanner yourusername then blacklist the usblp kernel module by writing blacklist usblp in /etc/modprobe.d/no-usblp.conf (it prevents usblp from loading to support scanning, not needed by xsane and related tools, might also conflict with CUPS). Reboot to finish. [6]

In addition to this, some Cannon printers return «device busy» if the scan mode is set to «Computer». Setting this to the «Remote Scanner» mode should fix the issue.[7]

Permission problem

With systemd, the scanner and lp groups are deprecated. No need to add your user to those groups. See Users and groups#Pre-systemd groups for detail.

You can also try to change permissions of usb device but this is not recommended, a better solution is to fix the Udev rules so that your scanner is recognized.

First check connected usb devices with lsusb :

In our example we see the scanner: Bus 001 Device 006: ID 03f0:2504 Hewlett-Packard . Here 03f0 is the vendorID and 2504 is the productID.

Alternatively, running sane-find-scanner with root permission will also give you the same vendorID and productID.

Now open /usr/lib/udev/rules.d/49-sane.rules and see if there is there is a line with the vendorID and productID of your scanner. If there is not any, create the new file /etc/udev/rules.d/49-sane-missing-scanner.rules , with the following contents:

Save the file, plug out and back in your scanner and the file permissions should be now correct.

The factual accuracy of this article or section is disputed.

Another tip, is that you can add your device (scanner) in backend file:

Add usb 0x03f0 0x2504 to /etc/sane.d/hp4200.conf so it looks like this:

Parallel port scanners

All devices attached to a parallel port are assumed to be printers, and are given a lp group. Either create a udev rule to mark the relevant parallel port as libsane_matched , or add your user to the lp user group. CUPS also uses the lp group for read-only access to configuration files, so there are potential security implications to adding users to the lp group — see CUPS#Connection interfaces for more information.

avahi-daemon is not mandatory

This article or section needs language, wiki syntax or style improvements. See Help:Style for reference.

Some scanner applications may require you to start the avahi-daemon upon startup. This is actually the cause of SANE. If for some reason you do not want to enable the avahi-daemon service because you use a wired scanner or do not need it because your scanner’s driver supports networking already on setup, then comment out the net backend in the SANE configuration:

Источник

Оцените статью