User mounting take 2
Joe Marcus Clarke
marcus at FreeBSD.org
Sat Apr 15 05:05:47 UTC 2006
Based on feedback I received on my initial diff, I took another crack at
user mounting. To address Robert's concerns, I drop the setuid
permissions until needed. Therefore, all permission checks are now done
in the kernel. The same is true for umount(8).
silby asked for wildcard support. To handle that, I added glob support
to both the fs_file and fs_spec fstab components (via fnmatch(3)), and
also added a special %u pattern that can be used to represent the
current user (i.e. the user running mount(8)). This effectively allows
the following in /etc/fstab:
//%u at server/homes /home/%u/smb_home smbfs rw,noauto,user 0 0
Then, a user could just run, for example:
mount /home/marcus/smb_home
And their SMB home directory would get mounted (~/.nsmbrc is also
respected).
Additionally, something like the following is also possible:
/dev/acd0 /home/*/cdrom cd9660 ro,noauto,user 0 0
Same mount command works here:
mount /home/marcus/cdrom
Wildcards can also be mixed and matched.
Finally, in testing this, I found a problem with smbfs, msdosfs, and
ntfs relating to the statfs(2) f_flags field. smbfs always set this to
0, msdosfs didn't set this at all, and ntfs set this to all flags (not
just those visible to statfs(2)). By fixing this, umount(8) works
properly on relative paths to user mount points for those three file
systems.
http://www.marcuscom.com/downloads/usermount.diff
Comments?
Joe
--
Joe Marcus Clarke
FreeBSD GNOME Team :: gnome at FreeBSD.org
FreeNode / #freebsd-gnome
http://www.FreeBSD.org/gnome
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 187 bytes
Desc: This is a digitally signed message part
Url : http://lists.freebsd.org/pipermail/freebsd-hackers/attachments/20060415/a16b98b6/attachment.pgp
More information about the freebsd-hackers
mailing list