Hello, after scanning a document, when the "Lampoff-time" has been reached, the lamp will turn off. After choosing another scan mode, "Color" for example, will immediately exit "xsane". "strace" will show, that the process received a "SIGSEGV" signal: --- SIGSEGV {si_signo=SIGSEGV, si_code=SI_KERNEL, si_addr=NULL} --- +++ killed by SIGSEGV +++ [1] 12919 segmentation fault xsane I cannot pinpoint this issue any further. -Ramon --- This might be related: HP Scanjet 2200c ("plustek"): Lamp does not turn off after scan process: https://gitlab.com/sane-project/backends/-/issues/515 Reproducible: Always Steps to Reproduce: 1. Go to a temporary directory: cd "$(mktemp --directory)" 2. Open "xsane" and write "strace" information to "strace_xsane": strace xsane 2>&1 | tee "strace_xsane" 3. Navigate to "Preferences - Load device settings" 4. Load the configuration attached file "Hewlett-Packard:Scanjet2200c.drc" 3.1. Configure "xsane" like in the attached screenshot 3.2. Set "Lampoff-time" to "10" 5. Click on the button "Scan" and wait for the end of the scan process. 4.1. Wait for 10 seconds until the lamp turns off 6. Navigate to "scan mode (Gray)" 7. Choose "Color" 7.1. "xsane" should immediately close. 8. Analyse the file "strace_xsane" Actual Results: "xsane" closes immediately. Expected Results: The scan mode "Color" is chosen successfully. Client: $ xsane --version xsane-0.999 (c) 1998-2013 Oliver Rauch This package is modified from the original version. Please contact your vendor or report problems at http://bugs.gentoo.org E-mail: Oliver.Rauch@xsane.org package xsane-0.999 compiled with GTK-2.24.33 with color management function with GIMP support, compiled with GIMP-2.10.22 XSane output formats: jpeg, pdf(compr.), png, pnm, ps(compr.), tiff, txt $ eix --installed sane [I] acct-user/saned Available versions: 0 Installed versions: 0(11:36:44 03/09/21) Description: User for media-gfx/sane-backends [I] media-gfx/sane-backends Available versions: 1.0.31-r2 {gphoto2 ipv6 snmp systemd threads usb v4l xinetd +zeroconf ABI_MIPS="n32 n64 o32" ABI_S390="32 64" ABI_X86="32 64 x32" SANE_BACKENDS="+abaton +agfafocus +apple +artec +artec_eplus48u +as6e +avision +bh +canon +canon630u +canon_dr +canon_lide70 canon_pp +cardscan +coolscan +coolscan2 +coolscan3 +dc25 +dc210 +dc240 +dell1600n_net +dmc +epjitsu +epson +epson2 +escl +fujitsu +genesys +gt68xx +hp +hp3500 +hp3900 +hp4200 +hp5400 +hp5590 +hpljm1005 hpsj5s +hs2p +ibm +kodak +kodakaio +kvs20xx kvs40xx +kvs1025 +leo +lexmark +ma1509 +magicolor +matsushita +microtek +microtek2 +mustek mustek_pp +mustek_usb mustek_usb2 +nec +net +niash +p5 +pie +pieusb +pixma +plustek +plustek_pp pnm +qcam +ricoh +ricoh2 +rts8891 +s9036 +sceptre +sharp +sm3600 +sm3840 +snapscan +sp15c +st400 +stv680 +tamarack +teco1 +teco2 +teco3 +test +u12 +umax +umax1220u +umax_pp +xerox_mfp"} Installed versions: 1.0.31-r2(13:54:39 14/09/21)(ipv6 usb zeroconf -gphoto2 -snmp -systemd -threads -v4l -xinetd ABI_MIPS="-n32 -n64 -o32" ABI_S390="-32 -64" ABI_X86="64 -32 -x32" SANE_BACKENDS="net -abaton -agfafocus -apple -artec -artec_eplus48u -as6e -avision -bh -canon -canon630u -canon_dr -canon_lide70 -canon_pp -cardscan -coolscan -coolscan2 -coolscan3 -dc25 -dc210 -dc240 -dell1600n_net -dmc -epjitsu -epson -epson2 -escl -fujitsu -genesys -gt68xx -hp -hp3500 -hp3900 -hp4200 -hp5400 -hp5590 -hpljm1005 -hpsj5s -hs2p -ibm -kodak -kodakaio -kvs20xx -kvs40xx -kvs1025 -leo -lexmark -ma1509 -magicolor -matsushita -microtek -microtek2 -mustek -mustek_pp -mustek_usb -mustek_usb2 -nec -niash -p5 -pie -pieusb -pixma -plustek -plustek_pp -pnm -qcam -ricoh -ricoh2 -rts8891 -s9036 -sceptre -sharp -sm3600 -sm3840 -snapscan -sp15c -st400 -stv680 -tamarack -teco1 -teco2 -teco3 -test -u12 -umax -umax1220u -umax_pp -xerox_mfp") Homepage: http://www.sane-project.org/ Description: Scanner Access Now Easy - Backends [I] media-gfx/xsane Available versions: 0.999-r3 {gimp jpeg lcms nls ocr png tiff} Installed versions: 0.999-r3(20:53:33 03/09/21)(gimp jpeg lcms png tiff -nls -ocr) Homepage: http://www.xsane.org/ Description: Graphical scanning frontend $ Portage 3.0.20 (python 3.9.6-final-0, default/linux/amd64/17.1/no-multilib, gcc-10.3.0, glibc-2.33-r1, 5.10.61-gentoo x86_64) ================================================================= System uname: Linux-5.10.61-gentoo-x86_64-Intel-R-_Core-TM-_i5-3450_CPU_@_3.10GHz-with-glibc2.33 KiB Mem: 16353228 total, 11709280 free KiB Swap: 10485756 total, 10485756 free Timestamp of repository gentoo: Thu, 23 Sep 2021 19:06:31 +0000 Head commit of repository gentoo: 34c2d7c6a721994cac1f42115bcffcd269ff2e49 Head commit of repository pf4public: c2ad78b76ffc55e80768e6737badc6324843e9d6 sh bash 5.1_p8 ld GNU ld (Gentoo 2.37_p1 p0) 2.37 distcc 3.4 x86_64-pc-linux-gnu [disabled] ccache version 4.3 [enabled] app-shells/bash: 5.1_p8::gentoo dev-java/java-config: 2.3.1::gentoo dev-lang/perl: 5.34.0-r2::gentoo dev-lang/python: 2.7.18_p13::gentoo, 3.8.12::gentoo, 3.9.6_p2::gentoo dev-lang/rust-bin: 1.53.0::gentoo dev-util/ccache: 4.3-r3::gentoo dev-util/cmake: 3.20.5::gentoo sys-apps/baselayout: 2.7::gentoo sys-apps/openrc: 0.43.5::gentoo sys-apps/sandbox: 2.24::gentoo sys-devel/autoconf: 2.13-r1::gentoo, 2.69-r5::gentoo sys-devel/automake: 1.16.4::gentoo sys-devel/binutils: 2.37_p1::gentoo sys-devel/gcc: 10.3.0-r2::gentoo sys-devel/gcc-config: 2.4::gentoo sys-devel/libtool: 2.4.6-r6::gentoo sys-devel/make: 4.3::gentoo sys-kernel/linux-headers: 5.10::gentoo (virtual/os-headers) sys-libs/glibc: 2.33-r1::gentoo Repositories: gentoo location: /home/ramon/.var/db/repos/gentoo sync-type: git sync-uri: https://github.com/gentoo-mirror/gentoo.git priority: -1000 keks24 location: /usr/local/share/git/keks24/gentoo-overlay masters: gentoo pf4public location: /home/ramon/.var/db/repos/pf4public sync-type: git sync-uri: https://github.com/PF4Public/gentoo-overlay.git masters: gentoo ACCEPT_KEYWORDS="amd64" ACCEPT_LICENSE="* -@EULA" CBUILD="x86_64-pc-linux-gnu" CFLAGS="-ftree-vectorize -O2 -pipe -march=ivybridge -mtune=ivybridge" CHOST="x86_64-pc-linux-gnu" CONFIG_PROTECT="/etc /usr/lib64/libreoffice/program/sofficerc /usr/share/gnupg/qualified.txt" CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/dconf /etc/env.d /etc/fonts/fonts.conf /etc/gconf /etc/gentoo-release /etc/revdep-rebuild /etc/sandbox.d /etc/terminfo" CXXFLAGS="-ftree-vectorize -O2 -pipe -march=ivybridge -mtune=ivybridge" DISTDIR="/var/db/repos/gentoo/distfiles" EMERGE_DEFAULT_OPTS="--jobs 4 --load-average 3.6" ENV_UNSET="CARGO_HOME DBUS_SESSION_BUS_ADDRESS DISPLAY GOBIN GOPATH PERL5LIB PERL5OPT PERLPREFIX PERL_CORE PERL_MB_OPT PERL_MM_OPT XAUTHORITY XDG_CACHE_HOME XDG_CONFIG_HOME XDG_DATA_HOME XDG_RUNTIME_DIR" FCFLAGS="-ftree-vectorize -O2 -pipe -march=ivybridge -mtune=ivybridge" FEATURES="assume-digests binpkg-docompress binpkg-dostrip binpkg-logs ccache config-protect-if-modified distlocks ebuild-locks fixlafiles ipc-sandbox merge-sync multilib-strict network-sandbox news parallel-fetch pid-sandbox preserve-libs protect-owned qa-unresolved-soname-deps sandbox sfperms strict unknown-features-warn unmerge-logs unmerge-orphans userfetch userpriv usersandbox usersync xattr" FFLAGS="-ftree-vectorize -O2 -pipe -march=ivybridge -mtune=ivybridge" GENTOO_MIRRORS="http://ftp-stud.hs-esslingen.de/pub/Mirrors/gentoo/ http://ftp.daum.net/gentoo/ http://ftp.dei.uc.pt/pub/linux/gentoo/" LANG="en_GB.utf8" LC_ALL="en_GB.UTF-8" LDFLAGS="-Wl,-O1 -Wl,--as-needed" MAKEOPTS="--jobs 4 --load-average 3.6" PKGDIR="/var/db/repos/gentoo/packages" PORTAGE_CONFIGROOT="/" PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --omit-dir-times --compress --force --whole-file --delete --stats --human-readable --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages --exclude=/.git " PORTAGE_TMPDIR="/var/tmp" USE="X a52 acl alsa amd64 bluetooth bzip2 cdda cdr cli crypt css cups dbus dri dts dvd dvdr elogind ffmpeg fortran gdbm iconv icu ipv6 libglvnd libtirpc ncurses nptl openmp pam pcre policykit pulseaudio readline seccomp split-usr ssl tcpd udev unicode usb vdpau xattr zlib zsh-completion zstd" ABI_X86="64" ADA_TARGET="gnat_2019" ALSA_CARDS="ali5451 als4000 atiixp atiixp-modem bt87x ca0106 cmipci emu10k1x ens1370 ens1371 es1938 es1968 fm801 hda-intel intel8x0 intel8x0m maestr o3 trident usb-audio via82xx via82xx-modem ymfpci" APACHE2_MODULES="authn_core authz_core socache_shmcb unixd actions alias auth_basic authn_alias authn_anon authn_dbm authn_default authn_file authz_dbm authz_default authz_groupfile authz_ host authz_owner authz_user autoindex cache cgi cgid dav dav_fs dav_lock deflate dir disk_cache env expires ext_filter file_cache filter headers include info log_config logio mem_cache mime mime_magic negotiation rewrite setenvif speling s tatus unique_id userdir usertrack vhost_alias" CALLIGRA_FEATURES="karbon sheets words" COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog" CPU_FLAGS_X86="aes avx f16c mmx mmxext pclmul popcnt sse sse2 sse3 sse4_1 sse4_2 sss e3" ELIBC="glibc" GPSD_PROTOCOLS="ashtech aivdm earthmate evermore fv18 garmin garmintxt gpsclock greis isync itrax mtk3301 nmea ntrip navcom oceanserver oldstyle oncore rtcm104v2 rtcm104v3 sirf skytraq superstar2 timing tsip tripmate tnt ublox ubx" GRUB_PLATFORMS="efi-64" INPUT_DEVICES="libinput" KERNEL="linux" L10N="en-GB" LCD_DEVICES="bayrad cfontz cfontz633 glk hd44780 lb216 lcdm001 mtxorb ncurses text" LIBREOFFICE_EXTENSIONS="presenter-console presenter-minimizer" LUA_ SINGLE_TARGET="lua5-1" LUA_TARGETS="lua5-1" OFFICE_IMPLEMENTATION="libreoffice" PHP_TARGETS="php7-3 php7-4" POSTGRES_TARGETS="postgres12 postgres13" PYTHON_SINGLE_TARGET="python3_9" PYTHON_TARGETS="python3_9 python3_8" SANE_BACKENDS="net" USERLAND="GNU" VIDEO_CARDS="intel mesa r600 radeon virtualbox" XTABLES_ADDONS="quota2 psd pknock lscan length2 ipv4options ipset ipp2p iface geoip fuzzy condition tee tarpit sysrq proto steal rawnat logmark ipmark dhcpmac delude chaos acco unt" Unset: CC, CPPFLAGS, CTARGET, CXX, INSTALL_MASK, LINGUAS, PORTAGE_BINHOST, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS, RUSTFLAGS Server: $ dpkg --list | grep "sane" ii libsane:armhf 1.0.27-3.2 armhf API library for scanners ii libsane-common 1.0.27-3.2 all API library for scanners -- documentation and support files ii sane-utils 1.0.27-3.2 armhf API library for scanners -- utilities
Created attachment 741807 [details] Hewlett-Packard:Scanjet2200c.drc Hewlett-Packard:Scanjet2200c.drc
Created attachment 741810 [details] xsane configuration 20210928-211026_screenshot.png
Created attachment 741813 [details] Censored strace_xsane strace_xsane
Created attachment 741825 [details] plustek.conf Server driver configuration file.
I would suggest rebuilding xsane with debug symbols enabled and getting a backtrace. https://wiki.gentoo.org/wiki/Project:Quality_Assurance/Backtraces
Created attachment 746178 [details] xsane_backtrace.log (In reply to Mike Gilbert from comment #5) > I would suggest rebuilding xsane with debug symbols enabled and getting a > backtrace. > > https://wiki.gentoo.org/wiki/Project:Quality_Assurance/Backtraces I recompiled "xsane-0.999-r3" with debug information and without any optimisations: $ CFLAGS="-Og -pipe -march=ivybridge -mtune=ivybridge -ggdb" CXXFLAGS="${CFLAGS}" FEATURES="nostrip" emerge --ask xsane $ < "/var/db/pkg/media-gfx/xsane-0.999-r3/CFLAGS" -Og -pipe -march=ivybridge -mtune=ivybridge -ggdb $ < "/var/db/pkg/media-gfx/xsane-0.999-r3/CXXFLAGS" -Og -pipe -march=ivybridge -mtune=ivybridge -ggdb I then installed "gdb" to get backtrace information: $ emerge --ask --oneshot gdb After that logged the program crash with backtrace information: $ cd "$(mktemp --directory)" $ scanimage --list-devices device `net:<some_server_hostname>:plustek:libusb:001:006' is a Hewlett-Packard Scanjet 2200c flatbed scanner default device is `net:<some_server_hostname>:plustek:libusb:001:006' $ gdb -quiet xsane Reading symbols from xsane... (gdb) set logging file xsane_backtrace.log (gdb) set logging on Copying output to xsane_backtrace.log. Copying debug output to xsane_backtrace.log. (gdb) set environment SANE_DEFAULT_DEVICE="net:<some_server_hostname>:plustek:libusb:001:006" (gdb) show environment SANE_DEFAULT_DEVICE SANE_DEFAULT_DEVICE="net:<some_server_hostname>:plustek:libusb:001:006" (gdb) run Starting program: /usr/bin/xsane [...] Thread 1 "xsane" received signal SIGPIPE, Broken pipe. 0x00007ffff755108f in write () from /lib64/libpthread.so.0 (gdb) thread apply all bt full Thread 7 (Thread 0x7ffff3c1b640 (LWP 27516) "xsane"): #0 0x00007ffff747389f in poll () at /lib64/libc.so.6 #1 0x00007ffff2b06e4a in () at /usr/lib64/libavahi-common.so.3 [...] (gdb) continue Continuing. free(): invalid pointer Thread 1 "xsane" received signal SIGABRT, Aborted. 0x00007ffff73be811 in raise () from /lib64/libc.so.6 (gdb) thread apply all bt full Thread 7 (Thread 0x7ffff3c1b640 (LWP 27516) "xsane"): #0 0x00007ffff747389f in poll () at /lib64/libc.so.6 #1 0x00007ffff2b06e4a in () at /usr/lib64/libavahi-common.so.3 [...] (gdb) continue Continuing. [Thread 0x7ffff3c1b640 (LWP 27516) exited] Program terminated with signal SIGABRT, Aborted. The program no longer exists. (gdb) thread apply all bt full (gdb) set logging off Done logging to xsane_backtrace.log. (gdb) quit For some reason "xsane" is behaving differently, when executed from "gdb". It is asking for authorisation, when I change the scan mode, instead of dying with the signal "SIGSEGV". I also cannot get to the point, where the process receives the signal "SIGSEGV". I tried the following handling settings, but without success: (gdb) handle SIGPIPE SIGABRT nostop noprint noignore pass Signal Stop Print Pass to program Description SIGABRT No No Yes Aborted SIGPIPE No No Yes Broken pipe "xsane" then just exits and "gdb" returns: Program terminated with signal SIGABRT, Aborted. The program no longer exists. -Ramon