security, overlayfs: Provide hook to correctly label newly created files
authorVivek Goyal <vgoyal@redhat.com>
Wed, 13 Jul 2016 14:44:52 +0000 (10:44 -0400)
committerPaul Moore <paul@paul-moore.com>
Tue, 9 Aug 2016 00:46:46 +0000 (20:46 -0400)
commit2602625b7e46576b00db619ac788c508ba3bcb2c
treea5e24e683c7a4e7cc0b93bdf4513c7601ced1966
parentc957f6df52c509ccfbb96659fd1a0f7812de333f
security, overlayfs: Provide hook to correctly label newly created files

During a new file creation we need to make sure new file is created with the
right label. New file is created in upper/ so effectively file should get
label as if task had created file in upper/.

We switched to mounter's creds for actual file creation. Also if there is a
whiteout present, then file will be created in work/ dir first and then
renamed in upper. In none of the cases file will be labeled as we want it to
be.

This patch introduces a new hook dentry_create_files_as(), which determines
the label/context dentry will get if it had been created by task in upper
and modify passed set of creds appropriately. Caller makes use of these new
creds for file creation.

Signed-off-by: Vivek Goyal <vgoyal@redhat.com>
Acked-by: Stephen Smalley <sds@tycho.nsa.gov>
[PM: fix whitespace issues found with checkpatch.pl]
[PM: changes to use stat->mode in ovl_create_or_link()]
Signed-off-by: Paul Moore <paul@paul-moore.com>
fs/overlayfs/dir.c
include/linux/lsm_hooks.h
include/linux/security.h
security/security.c