From: Greg KH on 8 Jul 2010 11:50 On Thu, Jul 08, 2010 at 04:32:42PM +0100, Tvrtko Ursulin wrote: > On Thursday 08 Jul 2010 16:20:59 Greg KH wrote: > > > :) Well I do not know, but, it kind of smelled like a bug in the > > > : vfs/mount > > > > > > handling/securityfs area so I thought to let experts know. I _think_ I > > > did nothing that much wrong. Just used the exposed API > > > (securityfs_remove) and some bind mount shuffling from userspace. > > > > securitfs just uses libfs underneath it, and really doesn't have any > > bindings for module ownerships, so I wouldn't recommend doing what you > > just did. > > Just do double check what you are saying, securityfs is not safe for use from > modules? If so I would then recommend removing the exports otherwise it is an > invitation to shoot yourself into the foot. Hm, did you properly set the module owner of the file_operations that you passed to securityfs? That should protect if you have an open file, but I doubt anyone thought you would do crazy things like bind mounts on top of a ramfs and then think it was safe to unload a lower module :) > Also, in-three TPM driver can be built as a module so how does that > work? You have to be root to unload modules, and if you are that, you can do worse things than this. thanks, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: Tvrtko Ursulin on 8 Jul 2010 12:20 On Thursday 08 Jul 2010 16:46:48 Greg KH wrote: > On Thu, Jul 08, 2010 at 04:32:42PM +0100, Tvrtko Ursulin wrote: > > On Thursday 08 Jul 2010 16:20:59 Greg KH wrote: > > > > :) Well I do not know, but, it kind of smelled like a bug in the > > > > : vfs/mount > > > > > > > > handling/securityfs area so I thought to let experts know. I _think_ > > > > I did nothing that much wrong. Just used the exposed API > > > > (securityfs_remove) and some bind mount shuffling from userspace. > > > > > > securitfs just uses libfs underneath it, and really doesn't have any > > > bindings for module ownerships, so I wouldn't recommend doing what you > > > just did. > > > > Just do double check what you are saying, securityfs is not safe for use > > from modules? If so I would then recommend removing the exports otherwise > > it is an invitation to shoot yourself into the foot. > > Hm, did you properly set the module owner of the file_operations that > you passed to securityfs? That should protect if you have an open file, I do not have it set (did not think it is strictly needed for filesystems (before mention TPM also does not set it)), but I am also pretty sure no one had a file open there at the time. I will try to repeat the test with it set and get back to you. > but I doubt anyone thought you would do crazy things like bind mounts on > top of a ramfs and then think it was safe to unload a lower module :) > > > Also, in-three TPM driver can be built as a module so how does that > > work? > > You have to be root to unload modules, and if you are that, you can do > worse things than this. That is beside the point, but I will let you off hook :) until I test the situation with the owner field set. Thanks for the discussion so far! Tvrtko Sophos Plc, The Pentagon, Abingdon Science Park, Abingdon, OX14 3YP, United Kingdom. Company Reg No 2096520. VAT Reg No GB 348 3873 20. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: Tvrtko Ursulin on 14 Jul 2010 12:30
On Thursday 08 Jul 2010 16:46:48 Greg KH wrote: > On Thu, Jul 08, 2010 at 04:32:42PM +0100, Tvrtko Ursulin wrote: > > On Thursday 08 Jul 2010 16:20:59 Greg KH wrote: > > > > :) Well I do not know, but, it kind of smelled like a bug in the > > > > : vfs/mount > > > > > > > > handling/securityfs area so I thought to let experts know. I _think_ > > > > I did nothing that much wrong. Just used the exposed API > > > > (securityfs_remove) and some bind mount shuffling from userspace. > > > > > > securitfs just uses libfs underneath it, and really doesn't have any > > > bindings for module ownerships, so I wouldn't recommend doing what you > > > just did. > > > > Just do double check what you are saying, securityfs is not safe for use > > from modules? If so I would then recommend removing the exports otherwise > > it is an invitation to shoot yourself into the foot. > > Hm, did you properly set the module owner of the file_operations that > you passed to securityfs? That should protect if you have an open file, > but I doubt anyone thought you would do crazy things like bind mounts on > top of a ramfs and then think it was safe to unload a lower module :) Hi again, Here is the reproducer. Build the attached test module and put test.ko in the cwd. Then run: umount /sys/kernel/security mount none -t securityfs /sys/kernel/security/ insmod test.ko mount file --bind /sys/kernel/security/test/file rmmod test insmod test.ko umount /sys/kernel/security/test/file umount /sys/kernel/security # <-------- BANG: It is a bit different than what I initially said. It looks like reference counting on a dentry gets messed up once securityfs_create_dir() in second insmod of test.ko fails with -EEXIST. HTH, Tvrtko Sophos Plc, The Pentagon, Abingdon Science Park, Abingdon, OX14 3YP, United Kingdom. Company Reg No 2096520. VAT Reg No GB 348 3873 20. |