Re: fuse and selinux don't seem to work well together

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Jul 26, 2010 at 2:22 PM, David P. Quigley <dpquigl@xxxxxxxxxxxxx> wrote:
> Ok so looking through the code briefly this is what happens with respect
> to the fstype for fuse. In the user space mount programs for fuse it
> handles all of the parsing of the source string to grab the fuse fs type
> out of it. It then crafts an FS type fuse.<subname> which is sent to the
> kernel. The creation of the daemon to handle the requests is done in
> user space and then it calls open on /dev/fuse. This grabs a new file
> descriptor which the kernel uses as its communications channel to the
> user space library and this FD is passed with the mount command.
>
> Now here is where my understanding gets a little foggy but hopefully it
> will help. Looking at the file_system_type structure for the fuse fs
> type it has a flag called FS_HAS_SUBTYPE. Looking closely do_kern_mount
> does two things to the fs_type string. First it will call get_fs_type
> which pulls off the subtype leaving the base type. This is passed into
> vfs_kernel_mount to be processed. After it calls vfs_kern_mount it then
> checks if fs_flags has FS_HAS_SUBTYPE set and if it does calls
> fs_set_subtype. This strips the first part of the name off and sets the
> s_subtype field in the superblock. When the name finally arrives at
> selinux_set_mnt_opts the file system name is fuse. This gets passed into
> security_fs_use at some point to determine the labeling type for the
> file system and grabs the entry in the policy db for fuse and uses that.
> So having the fuse code call security_set_mnt_opts earlier isn't a good
> idea.
>
> Now if you want to attempt to use the subtype in a fsuse statement we
> need to set the subtype before calling vfs_kern_mount. I'm not sure if
> this is allowed so something else might have to be done instead. I hope
> this clears some things up for you.
>
> Dave
>
>

If I understand you're saying that the superblock file_system_type
name needs to be type.subtype when it get to selinux_set_mnt_opts for
security_fs_use to find the policy I've configured?

Ted

--
This message was distributed to subscribers of the selinux mailing list.
If you no longer wish to subscribe, send mail to majordomo@xxxxxxxxxxxxx with
the words "unsubscribe selinux" without quotes as the message.


[Index of Archives]     [Selinux Refpolicy]     [Linux SGX]     [Fedora Users]     [Fedora Desktop]     [Yosemite Photos]     [Yosemite Camping]     [Yosemite Campsites]     [KDE Users]     [Gnome Users]

  Powered by Linux