Date: Wed, 28 Apr 2010 13:22:10 -0600 (MDT) From: Warren Block <wblock@wonkity.com> To: Marco Beishuizen <mbeis@xs4all.nl> Cc: Roland Smith <rsmith@xs4all.nl>, freebsd-questions@freebsd.org Subject: Re: Using a scanner (USB) as user and not as root Message-ID: <alpine.BSF.2.00.1004281310520.23838@wonkity.com> In-Reply-To: <alpine.BSF.2.00.1004282057490.3115@yokozuna.lan> References: <alpine.BSF.2.00.1004281939070.3115@yokozuna.lan> <20100428182223.GA34355@slackbox.erewhon.net> <alpine.BSF.2.00.1004282057490.3115@yokozuna.lan>
next in thread | previous in thread | raw e-mail | index | archive | help
On Wed, 28 Apr 2010, Marco Beishuizen wrote:
> On Wed, 28 Apr 2010, Roland Smith wrote:
>
>> Are the permissions correct? Check with 'ls -l /dev/usb/ /dev/ugen*'.
>> Is your user-id in the usb group? Check by running 'id' as the normal user.
>>
>> If all that is in order, remove all lines except the three above from
>> /etc/devfs.rules, and try again.
>
> Running id as user looks ok:
>
> uid=1001(marco) gid=0(wheel) groups=0(wheel),5(operator),1001(usb)
>
> But the permissions are not:
>
> ls -l /dev/usb/ /dev/ugen*
> lrw-rw-r-- 1 root usb 9 Apr 28 19:05 /dev/ugen0.1 -> usb/0.1.0
> lrw-rw-r-- 1 root usb 9 Apr 28 19:05 /dev/ugen1.1 -> usb/1.1.0
> lrw-rw-r-- 1 root usb 9 Apr 28 21:05 /dev/ugen1.2 -> usb/1.2.0
> lrw-rw-r-- 1 root usb 9 Apr 28 21:05 /dev/ugen1.3 -> usb/1.3.0
> lrw-rw-r-- 1 root usb 9 Apr 28 19:05 /dev/ugen2.1 -> usb/2.1.0
>
> /dev/usb/:
> total 0
> crw------- 1 root operator 0, 87 Apr 28 19:05 0.1.0
> crw------- 1 root operator 0, 93 Apr 28 19:05 0.1.1
> crw------- 1 root operator 0, 89 Apr 28 19:05 1.1.0
> crw------- 1 root operator 0, 94 Apr 28 19:05 1.1.1
> crw------- 1 root operator 0, 104 Apr 28 21:05 1.2.0
> crw------- 1 root operator 0, 105 Apr 28 21:05 1.2.1
> crw------- 1 root operator 0, 117 Apr 28 21:05 1.3.0
> crw------- 1 root operator 0, 119 Apr 28 21:05 1.3.1
> crw------- 1 root operator 0, 91 Apr 28 19:05 2.1.0
> crw------- 1 root operator 0, 95 Apr 28 19:05 2.1.1
You can use devd.conf for this:
attach 100 {
device-name "ugen[0-9].[0-9]";
match "vendor" "0x04b8";
match "product" "0x010a";
action "usb_devaddr=`echo $device-name | sed 's#^ugen##'` && \
chown root:saned /dev/usb/${usb_devaddr}.* && \
chmod 0660 /dev/usb/${usb_devaddr}.*
Copied from a post on -current or similar; apologies to the author, who
I've forgotten. I thought this was in the default devd.conf as an
example, but it appears not.
devfs.rules don't apply to devices that are created dynamically after
boot-up. Or I guess they might be if you reload the ruleset with
applyset after the device is created, but devd is a lot more capable.
-Warren Block * Rapid City, South Dakota USA
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?alpine.BSF.2.00.1004281310520.23838>
