You are not logged in.
Pages: 1
Similarly to this (old) thread, {lib,}gphoto2 refuses to work due to a permission error:
$ gphoto2 --summary
*** Error ***
An error occurred in the io-library ('I/O problem'): Could not open USB device (Permission denied).
*** Error (-7: 'I/O problem') ***
The relevant lines in the debug log:
0.072237 gphoto2-camera(2): Setting port info for port 'Universal Serial Bus' at 'usb:002,006'...
0.078216 gphoto2-port(0): Could not open USB device (Permission denied).
0.078293 context(0): An error occurred in the io-library ('I/O problem'): Could not open USB device (Permission denied).
One workaround is giving world write permissions to that device:
sudo chmod o+w /dev/bus/usb/002/006
... causing gphoto2 to work as expected:
$ gphoto2 --summary
Camera summary:
Manufacturer: Canon Inc.
Model: Canon EOS 550D
...
The wiki mentions that being part of the camera group is irrelevant.
As per the package file list, udev rules have moved to /usr/lib/udev/rules.d/40-gphoto.rules. Does this need modifying?
Edit: I don't use a desktop environment, instead logging in via the console and starting dwm using xinit. I've tried launching console kit (in conjunction with dwm as per the wiki) to no avail.
Last edited by tlvince (2012-05-22 14:25:49)
Offline
I just updated the wiki a bit. Hope it helps.
Edit: to check if your consolekit sessions are set up correctly check "ck-list-sessions". You should have "active" and "is-local" both be TRUE for you to have access to the device.
Last edited by tomegun (2012-05-23 21:45:40)
Offline
to check if your consolekit sessions are set up correctly check "ck-list-sessions". You should have "active" and "is-local" both be TRUE for you to have access to the device.
$ ck-list-sessions
Session6:
unix-user = '1000'
realname = '(null)'
seat = 'Seat1'
session-type = ''
active = TRUE
x11-display = ':0'
x11-display-device = '/dev/tty7'
display-device = ''
remote-host-name = ''
is-local = TRUE
on-since = '2012-06-23T19:31:03.492852Z'
login-session-id = '4294967295'
I have a number of digital cameras that are on the official gphoto2 support page but cannot access them unless I invoke the gphoto2 commands as the root user. My desktop user is indeed in the storage group.
$ gphoto2 --auto-detect
Model Port
----------------------------------------------------------
Fuji FinePix F40fd usb:001,013
$ gphoto2 --list-files
*** Error ***
An error occurred in the io-library ('I/O problem'): Could not open USB device (Permission denied).
*** Error (-7: 'I/O problem') ***
For debugging messages, please use the --debug option.
Debugging messages may help finding a solution to your problem.
If you intend to send any error or debug messages to the gphoto
developer mailing list <gphoto-devel@lists.sourceforge.net>, please run
gphoto2 as follows:
env LANG=C gphoto2 --debug --debug-logfile=my-logfile.txt --list-files
Please make sure there is sufficient quoting around the arguments.
But, if I follow tlvince's advice and change the permissions, it works as expected:
Before:
$ ls -l /dev/bus/usb/001/013
crw-rw-r-- 1 root root 189, 12 Jun 23 16:38 /dev/bus/usb/001/013
After:
# chmod o+w /dev/bus/usb/001/013
$ ls -l /dev/bus/usb/001/013
crw-rw-rw- 1 root root 189, 12 Jun 23 16:38 /dev/bus/usb/001/013
Last edited by graysky (2012-06-23 20:41:31)
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
By default you don't need to be in any particular group to make this work. Permission should be granted using ACL's (by consolekit/systemd). Did you read the wiki? https://wiki.archlinux.org/index.php/Gp … ion_issues
Offline
@tomegun - I sure did. I am running systemd and consolekit. I also believe that my users recognized -- I edited my post #3 while you wrote your reply, sorry for that. Please have a look above and thank you for any advice you can offer.
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
@graysky: only thing i can add is that if you have both CK and systemd running, then the latter will take precedence, so you should make sure that also systemd considers your user to be active: "loginctl session-status <your session id>" will tell you.
Offline
Thanks for the quick reply, tomegun... seems as though systemd does not consider ANY sessions active:
$ loginctl
SESSION UID USER SEAT
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
@graysky: then that explains your problem
If you log in on a tty, does it work?
What DE do you use? You need the pam systemd module to be set up correctly. AFAIC KDE and Gnome work fine, but there might be work to do if you use something else.
Essentially you need a pam-session to be set up for you, and you need pam_systemd.so to be in the right file in /etc/pam.d/. I would assume that without an active session a lot of other things would also not work? E.g. sound, graphics....? Though I suppose most things can be worked around by being in the right group.
Offline
@tomegun - I use xfce4 and lxdm to login.
I dropped down to multi-user and entered X. Now I am reconized by loginctl but both my 'active' and 'is-local' are now set to FALSE... ?
$ sudo systemctl isolate multi-user.target
$ xinit
$ ck-list-sessions
Session1:
unix-user = '1000'
realname = '(null)'
seat = 'Seat2'
session-type = ''
active = FALSE
x11-display = ':0'
x11-display-device = '/dev/tty3'
display-device = '/dev/tty1'
remote-host-name = ''
is-local = FALSE
on-since = '2012-06-23T21:32:29.710295Z'
login-session-id = '1'
$ loginctl session-status 1
1 -facade (1000)
Since: Sat, 23 Jun 2012 17:30:22 -0400; 3min 34s ago
Leader: 628 (login)
Seat: seat0; vc1
TTY: /dev/tty1
Service: login; type tty; class user
Active: no
CGroup: name=systemd:/user/facade/1
├ 628 /bin/login --
├ 755 -bash
├ 991 /usr/bin/pulseaudio --start
├ 1074 /usr/lib/pulse/gconf-helper
├ 1653 xinit
├ 1654 X :0
├ 1659 ck-launch-session startxfce4
├ 1670 /bin/sh /etc/xdg/xfce4/xinitrc -- /etc/X11/xinit/xserverrc
├ 1675 xfce4-session
├ 1678 /usr/bin/dbus-launch --sh-syntax --exit-with-session xfce4-session
├ 1679 /usr/bin/dbus-daemon --fork --print-pid 5 --print-address 7 --session
├ 1681 /usr/lib/xfce4/xfconf/xfconfd
├ 1684 gnome-keyring-daemon --start
├ 1687 xfwm4 --display :0.0 --sm-client-id 25f262281-e3e0-45d3-aacd-83aa74521e4b
├ 1695 Thunar --sm-client-id 249b9a9e8-9464-4d04-829b-0c00d0d0d462 --daemon
├ 1697 /usr/lib/gvfs/gvfsd
├ 1699 /usr/lib/gvfs//gvfs-fuse-daemon -f /run/user/facade/gvfs
├ 1704 xfce4-panel --display :0.0 --sm-client-id 255e6c99e-36fc-4418-9aa4-0f821747e16e
├ 1706 xfsettingsd --display :0.0 --sm-client-id 25440d5a2-b56b-4148-ba5a-d7db28366557
├ 1708 xfdesktop --display :0.0 --sm-client-id 2c46d64a6-7013-414a-95d7-e5a1d0abef5d
├ 1709 /usr/lib/xfce4/panel-plugins/xfce4-mixer-plugin 7 16777247 xfce4-mixer-plugin Mixer Volume control for your sound card
├ 1712 xscreensaver -no-splash
├ 1713 /usr/lib/xfce4/panel/wrapper /usr/lib/xfce4/panel-plugins/libdatetime.so 4 16777248 datetime DateTime Date and Time plu...
├ 1715 /usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1
├ 1716 /usr/lib/xfce4/panel-plugins/xfce4-cpufreq-plugin 16 16777249 xfce4-cpufreq-plugin CPU Frequency Monitor Shows the cpu ...
├ 1721 /usr/lib/xfce4/panel/wrapper /usr/lib/xfce4/panel/plugins/libcpugraph.so 17 16777250 cpugraph CPU Graph Graphical repre...
├ 1724 bluetooth-applet
├ 1725 /usr/lib/xfce4/panel-plugins/xfce4-netload-plugin 18 16777251 netload Network Monitor Show network traffic
├ 1726 /usr/lib/xfce4/panel/wrapper /usr/lib/xfce4/panel/plugins/libsystray.so 6 16777252 systray Notification Area Area where...
├ 1727 /usr/lib/xfce4/panel/wrapper /usr/lib/xfce4/panel/plugins/libactions.so 8 16777253 actions Action Buttons Log out, lock...
├ 1740 /usr/lib/gvfs/gvfs-udisks2-volume-monitor
├ 1743 /usr/lib/gvfs/gvfs-gphoto2-volume-monitor
├ 1745 /usr/lib/gvfs/gvfs-afc-volume-monitor
├ 1748 /usr/lib/gvfs/gvfsd-trash --spawner :1.6 /org/gtk/gvfs/exec_spaw/0
├ 1750 /usr/bin/terminal --geometry 112x32
├ 1751 gnome-pty-helper
├ 1752 bash
└ 2273 loginctl session-status 1
Last edited by graysky (2012-06-23 21:36:47)
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
Hmmm... I guess the problem is that your graphical session does not get its own logind session. The session in the listing you have is the one associated with the tty where you did "xinit". However, you are currently on a new tty where X was started. Hence, the first (and only) session is not active.
It might be worth trying to use gdm/kdm as they should do the right thing and set up a proper session for you.
Offline
@tomegun - Thank you for the suggestion. It appears as though the problem lies with lxdm unfortunately. When I login with gdm, the camera is identified just fine without root permissions. I would like to open a bug with lxdm upstream, but am not totally sure what to say. Can you help me with the description?
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
@graysky: without looking at the code, I'm not sure what goes wrong. I'd just file a bug report saying that you don't get a systemd session when logging in with lxdm. You could possibly point to http://www.freedesktop.org/wiki/Softwar … y-managers as a reference to how it should work. I guess the problem should be clear to the lxdm devs.
Offline
Thanks tomegun. I have also confirmed this behavior under lightdm as well. It would be a crying shame to have to switch to gdm just for this.
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
Yeah, it would be awesome if all the dm's supported systemd I think the main issue is to make sure the dm's have pam support, then the rest is almost for free
Offline
Bug reports filed:
Lightdm: https://bugs.launchpad.net/lightdm/+bug/1017126
LXDM: https://sourceforge.net/tracker/?func=d … tid=894869
Last edited by graysky (2012-06-24 12:04:57)
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
Is this solved yet. I have exactly the same setup with lxdm, xfce4 and systemd, and can no longer use gtkam as a user ("Permission denied") though it works as root.
It worked fine pre-systemd.
Last edited by Roken (2012-08-20 23:15:07)
Ryzen 5900X 12 core/24 thread - RTX 3090 FE 24 Gb, Asus B550-F Gaming MB, 128Gb Corsair DDR4, Cooler Master N300 chassis, 5 HD (2 NvME PCI, 4SSD) + 1 x optical.
Linux user #545703
/ is the root of all problems.
Offline
Read the two bug reports by graysky. He posted the fix there.
Offline
My bad. I'd seen the report and missed the comments. Thank you.
Ryzen 5900X 12 core/24 thread - RTX 3090 FE 24 Gb, Asus B550-F Gaming MB, 128Gb Corsair DDR4, Cooler Master N300 chassis, 5 HD (2 NvME PCI, 4SSD) + 1 x optical.
Linux user #545703
/ is the root of all problems.
Offline
Hoping this will not be considered necro-bumping.
I have the same original problem. With the difference that I don't use any DM, and let agetty perform the autologin. I have installed both consolekit both systemd, and they say my session is active, because /etc/pam.d/login sources /etc/pam.d/system-local-login, that sources /etc/pam.d/system-login that contains this statement
-session optional pam_systemd.so
consolekit
ck-list-sessions
Session1:
unix-user = '1000'
realname = ''
seat = 'Seat1'
session-type = ''
active = FALSE
x11-display = ''
x11-display-device = ''
display-device = '/dev/tty1'
remote-host-name = ''
is-local = TRUE
on-since = '2012-10-04T10:07:02.291602Z'
login-session-id = '1'
idle-since-hint = '2012-10-04T10:07:32.761442Z'
Session2:
unix-user = '1000'
realname = ''
seat = 'Seat1'
session-type = ''
active = TRUE
x11-display = ':0'
x11-display-device = '/dev/tty2'
display-device = '/dev/tty1'
remote-host-name = ''
is-local = TRUE
on-since = '2012-10-04T10:07:11.102483Z'
login-session-id = '1'
systemd
loginctl
SESSION UID USER SEAT
1 1000 javier seat0
1 sessions listed.
loginctl session-status 1
1 - javier (1000)
Since: Thu, 04 Oct 2012 12:07:02 +0200; 18min ago
Leader: 297 (login)
Seat: seat0; vc1
TTY: tty1
Service: login; type tty; class user
State: online
CGroup: name=systemd:/user/javier/1
├ 297 login -- javier
├ 376 -bash
├ 392 /bin/sh /usr/bin/startx
├ 416 xinit /home/javier/.xinitrc -- /etc/X11/xinit/xser...
├ 417 /usr/bin/X -nolisten tcp :0 -auth /tmp/serverauth....
├ 496 /bin/sh /home/javier/.xinitrc
├ 500 ck-launch-session dbus-launch openbox-session
├ 521 /usr/bin/openbox --startup /usr/lib/openbox/openbo...
├ 549 /usr/bin/dbus-daemon --fork --print-pid 5 --print-...
├ 573 cairo-compmgr
├ 574 cairo-dock -o
├ 576 tint2
├ 578 thunar --daemon
├ 579 roxterm --separate --profile=Desktop --role=rwterm...
├ 584 /usr/lib/polkit-gnome/polkit-gnome-authentication-...
├ 585 /usr/bin/python2 -O /usr/share/wicd/gtk/wicd-clien...
├ 586 conky -c /home/javier/conky/graph.conf
├ 587 conky -c /home/javier/conky/base.conf
├ 601 /usr/lib/gvfs/gvfsd
├ 603 /usr/lib/gvfs//gvfs-fuse-daemon -f /run/user/1000/...
├ 634 /usr/lib/gvfs/gvfsd-trash --spawner :1.5 /org/gtk/...
├ 635 gnome-pty-helper
├ 636 /bin/bash
├ 652 /usr/lib/notify-osd-customizable/notify-osd
├ 657 /usr/lib/gvfs/gvfs-udisks2-volume-monitor
├ 668 /usr/lib/gvfs/gvfs-gphoto2-volume-monitor
├ 691 su
├ 692 bash
├ 716 firefox
├ 877 /usr/lib/firefox/plugin-container /usr/lib/mozilla...
├ 1350 /usr/lib/xfce4/xfconf/xfconfd
├ 1429 /bin/bash
├ 1704 /bin/bash
└ 1711 loginctl session-status 1
Despite that, I obtain permission problem with gphoto2, this is the interesting part
0.242769 gphoto2-port(2): Opening USB port...
0.242786 libusb(2): gp_port_usb_open()
0.242813 gphoto2-port(0): Could not open USB device (Permission denied).
0.242852 context(0): An error occurred in the io-library ('I/O problem'): Could not open USB device (Permission denied).
*** Error ***
An error occurred in the io-library ('I/O problem'): Could not open USB device (Permission denied).
*** Error (-7: 'I/O problem') ***
0.243248 gp-camera(2): Freeing camera...
0.243264 gphoto2-port(2): Freeing port...
0.243278 gphoto2-port(2): Closing port...
0.243320 gphoto2-filesystem(2): resetting filesystem
0.243335 libgphoto2/gphoto2-filesys.c(2): Clearing fscache LRU list...
0.243348 libgphoto2/gphoto2-filesys.c(2): fscache LRU list already empty
0.243361 gphoto2-filesystem(2): Internally deleting all folders from '/'...
0.243374 gphoto2-filesystem(2): Lookup folder '/'...
0.243387 gphoto2-filesystem(2): Found! / is 0x968f148
0.243402 gphoto2-filesystem(2): Recurse delete folder 0x968f148//
As root user everything works.
Sorry for long post.
Offline
Ok, I found the problem. I thought state "online" was the same as "active", but it's not. An "online" session is considered not "active". Anybody knows how to solve?
Offline
Ok, I found the problem. I thought state "online" was the same as "active", but it's not. An "online" session is considered not "active". Anybody knows how to solve?
If you are booting with systemd and not using a DE, then this is not really ideally implemented at the moment. In order to get it to work, you can follow Dave's advice here: http://blog.falconindy.com/articles/bac … stemd.html.
Offline
Perfect, launching Xserver on the same tty where I log into fixed everything. Thanks a lot.
Offline
Pages: 1