linux-nfs.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Dave Quigley <dpquigl@davequigley.com>
To: "J. Bruce Fields" <bfields@fieldses.org>
Cc: trond.myklebust@netapp.com, sds@tycho.nsa.gov,
	linux-nfs@vger.kernel.org, selinux@tycho.nsa.gov,
	linux-security-module@vger.kernel.org,
	"Matthew N. Dodd" <Matthew.Dodd@sparta.com>,
	Miguel Rodel Felipe <Rodel_FM@dsi.a-star.edu.sg>,
	Phua Eu Gene <PHUA_Eu_Gene@dsi.a-star.edu.sg>,
	Khin Mi Mi Aung <Mi_Mi_AUNG@dsi.a-star.edu.sg>
Subject: Re: [PATCH 01/13] Security: Add hook to calculate context based on a negative dentry.
Date: Mon, 12 Nov 2012 09:52:58 -0500	[thread overview]
Message-ID: <50A10D4A.2030001@davequigley.com> (raw)
In-Reply-To: <20121112121356.GC30713@fieldses.org>

On 11/12/2012 7:13 AM, J. Bruce Fields wrote:
> On Mon, Nov 12, 2012 at 01:15:35AM -0500, David Quigley wrote:
>> From: David Quigley <dpquigl@davequigley.com>
>>
>> There is a time where we need to calculate a context without the
>> inode having been created yet. To do this we take the negative dentry and
>> calculate a context based on the process and the parent directory contexts.
>>
>> Signed-off-by: Matthew N. Dodd <Matthew.Dodd@sparta.com>
>> Signed-off-by: Miguel Rodel Felipe <Rodel_FM@dsi.a-star.edu.sg>
>> Signed-off-by: Phua Eu Gene <PHUA_Eu_Gene@dsi.a-star.edu.sg>
>> Signed-off-by: Khin Mi Mi Aung <Mi_Mi_AUNG@dsi.a-star.edu.sg>
>> Signed-off-by: David Quigley <dpquigl@davequigley.com>
>> ---
>>   include/linux/security.h | 27 +++++++++++++++++++++++++++
>>   security/capability.c    |  8 ++++++++
>>   security/security.c      | 10 ++++++++++
>>   security/selinux/hooks.c | 35 +++++++++++++++++++++++++++++++++++
>>   4 files changed, 80 insertions(+)
>>
>> diff --git a/include/linux/security.h b/include/linux/security.h
>> index 05e88bd..c9f5eec 100644
>> --- a/include/linux/security.h
>> +++ b/include/linux/security.h
>> @@ -26,6 +26,7 @@
>>   #include <linux/capability.h>
>>   #include <linux/slab.h>
>>   #include <linux/err.h>
>> +#include <linux/string.h>
>>
>>   struct linux_binprm;
>>   struct cred;
>> @@ -306,6 +307,15 @@ static inline void security_free_mnt_opts(struct security_mnt_opts *opts)
>>    *	Parse a string of security data filling in the opts structure
>>    *	@options string containing all mount options known by the LSM
>>    *	@opts binary data structure usable by the LSM
>> + * @dentry_init_security:
>> + *	Compute a context for a dentry as the inode is not yet available
>> + *	since NFSv4 has no label backed by an EA anyway.
>
> I don't understand this comment.  Why exactly is NFSv4 the first user
> that needs this?
>
> --b.
>

Normally the calculation of a label for an inode is based on the inode 
and the parent directory. We unfortunately don't have all of that 
information available in NFSv4 where we need it so instead we base the 
calculation off of the dentry instead. That is the best I can remember 
for why we do it. Unfortunately that decision was made so long ago its 
hard to remember the fine details.

>> + *	@dentry dentry to use in calculating the context.
>> + *	@mode mode used to determine resource type.
>> + *	@name name of the last path component used to create file
>> + *	@ctx pointer to place the pointer to the resulting context in.
>> + *	@ctxlen point to place the length of the resulting context.
>> + *
>>    *
>>    * Security hooks for inode operations.
>>    *
>> @@ -1421,6 +1431,10 @@ struct security_operations {
>>   	void (*sb_clone_mnt_opts) (const struct super_block *oldsb,
>>   				   struct super_block *newsb);
>>   	int (*sb_parse_opts_str) (char *options, struct security_mnt_opts *opts);
>> +	int (*dentry_init_security) (struct dentry *dentry, int mode,
>> +					struct qstr *name, void **ctx,
>> +					u32 *ctxlen);
>> +
>>
>>   #ifdef CONFIG_SECURITY_PATH
>>   	int (*path_unlink) (struct path *dir, struct dentry *dentry);
>> @@ -1702,6 +1716,9 @@ int security_sb_set_mnt_opts(struct super_block *sb, struct security_mnt_opts *o
>>   void security_sb_clone_mnt_opts(const struct super_block *oldsb,
>>   				struct super_block *newsb);
>>   int security_sb_parse_opts_str(char *options, struct security_mnt_opts *opts);
>> +int security_dentry_init_security(struct dentry *dentry, int mode,
>> +					struct qstr *name, void **ctx,
>> +					u32 *ctxlen);
>>
>>   int security_inode_alloc(struct inode *inode);
>>   void security_inode_free(struct inode *inode);
>> @@ -2005,6 +2022,16 @@ static inline int security_inode_alloc(struct inode *inode)
>>   static inline void security_inode_free(struct inode *inode)
>>   { }
>>
>> +static inline int security_dentry_init_security(struct dentry *dentry,
>> +						 int mode,
>> +						 struct qstr *name,
>> +						 void **ctx,
>> +						 u32 *ctxlen)
>> +{
>> +	return -EOPNOTSUPP;
>> +}
>> +
>> +
>>   static inline int security_inode_init_security(struct inode *inode,
>>   						struct inode *dir,
>>   						const struct qstr *qstr,
>> diff --git a/security/capability.c b/security/capability.c
>> index b14a30c..f1eb284 100644
>> --- a/security/capability.c
>> +++ b/security/capability.c
>> @@ -108,6 +108,13 @@ static int cap_sb_parse_opts_str(char *options, struct security_mnt_opts *opts)
>>   	return 0;
>>   }
>>
>> +static int cap_dentry_init_security(struct dentry *dentry, int mode,
>> +					struct qstr *name, void **ctx,
>> +					u32 *ctxlen)
>> +{
>> +	return 0;
>> +}
>> +
>>   static int cap_inode_alloc_security(struct inode *inode)
>>   {
>>   	return 0;
>> @@ -905,6 +912,7 @@ void __init security_fixup_ops(struct security_operations *ops)
>>   	set_to_cap_if_null(ops, sb_set_mnt_opts);
>>   	set_to_cap_if_null(ops, sb_clone_mnt_opts);
>>   	set_to_cap_if_null(ops, sb_parse_opts_str);
>> +	set_to_cap_if_null(ops, dentry_init_security);
>>   	set_to_cap_if_null(ops, inode_alloc_security);
>>   	set_to_cap_if_null(ops, inode_free_security);
>>   	set_to_cap_if_null(ops, inode_init_security);
>> diff --git a/security/security.c b/security/security.c
>> index 8dcd4ae..b4b2017 100644
>> --- a/security/security.c
>> +++ b/security/security.c
>> @@ -12,6 +12,7 @@
>>    */
>>
>>   #include <linux/capability.h>
>> +#include <linux/dcache.h>
>>   #include <linux/module.h>
>>   #include <linux/init.h>
>>   #include <linux/kernel.h>
>> @@ -324,6 +325,15 @@ void security_inode_free(struct inode *inode)
>>   	security_ops->inode_free_security(inode);
>>   }
>>
>> +int security_dentry_init_security(struct dentry *dentry, int mode,
>> +					struct qstr *name, void **ctx,
>> +					u32 *ctxlen)
>> +{
>> +	return security_ops->dentry_init_security(dentry, mode, name,
>> +							ctx, ctxlen);
>> +}
>> +EXPORT_SYMBOL(security_dentry_init_security);
>> +
>>   int security_inode_init_security(struct inode *inode, struct inode *dir,
>>   				 const struct qstr *qstr,
>>   				 const initxattrs initxattrs, void *fs_data)
>> diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c
>> index 61a5336..22d9adf 100644
>> --- a/security/selinux/hooks.c
>> +++ b/security/selinux/hooks.c
>> @@ -2483,6 +2483,40 @@ static void selinux_inode_free_security(struct inode *inode)
>>   	inode_free_security(inode);
>>   }
>>
>> +static int selinux_dentry_init_security(struct dentry *dentry, int mode,
>> +					struct qstr *name, void **ctx,
>> +					u32 *ctxlen)
>> +{
>> +	struct cred *cred = current_cred();
>> +	struct task_security_struct *tsec;
>> +	struct inode_security_struct *dsec;
>> +	struct superblock_security_struct *sbsec;
>> +	struct inode *dir = dentry->d_parent->d_inode;
>> +	u32 newsid;
>> +	int rc;
>> +
>> +	tsec = cred->security;
>> +	dsec = dir->i_security;
>> +	sbsec = dir->i_sb->s_security;
>> +
>> +	if (tsec->create_sid && sbsec->behavior != SECURITY_FS_USE_MNTPOINT) {
>> +		newsid = tsec->create_sid;
>> +	} else {
>> +		rc = security_transition_sid(tsec->sid, dsec->sid,
>> +					     inode_mode_to_security_class(mode),
>> +					     name,
>> +					     &newsid);
>> +		if (rc) {
>> +			printk(KERN_WARNING
>> +				"%s: security_transition_sid failed, rc=%d\n",
>> +			       __func__, -rc);
>> +			return rc;
>> +		}
>> +	}
>> +
>> +	return security_sid_to_context(newsid, (char **)ctx, ctxlen);
>> +}
>> +
>>   static int selinux_inode_init_security(struct inode *inode, struct inode *dir,
>>   				       const struct qstr *qstr, char **name,
>>   				       void **value, size_t *len)
>> @@ -5509,6 +5543,7 @@ static struct security_operations selinux_ops = {
>>   	.sb_clone_mnt_opts =		selinux_sb_clone_mnt_opts,
>>   	.sb_parse_opts_str = 		selinux_parse_opts_str,
>>
>> +	.dentry_init_security =		selinux_dentry_init_security,
>>
>>   	.inode_alloc_security =		selinux_inode_alloc_security,
>>   	.inode_free_security =		selinux_inode_free_security,
>> --
>> 1.7.11.7
>>
>


  reply	other threads:[~2012-11-12 14:59 UTC|newest]

Thread overview: 93+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-11-12  6:15 Labeled NFS [v5] David Quigley
2012-11-12  6:15 ` [PATCH 01/13] Security: Add hook to calculate context based on a negative dentry David Quigley
2012-11-12 12:13   ` J. Bruce Fields
2012-11-12 14:52     ` Dave Quigley [this message]
2012-11-12  6:15 ` [PATCH 02/13] Security: Add Hook to test if the particular xattr is part of a MAC model David Quigley
2012-11-12 12:15   ` J. Bruce Fields
2012-11-12 14:56     ` Dave Quigley
2012-11-12 16:36       ` J. Bruce Fields
2012-11-12 19:36         ` David P. Quigley
2012-11-12 21:43           ` J. Bruce Fields
2012-11-13  0:12             ` Dave Quigley
2012-11-12  6:15 ` [PATCH 03/13] LSM: Add flags field to security_sb_set_mnt_opts for in kernel mount data David Quigley
2012-11-12  6:15 ` [PATCH 04/13] SELinux: Add new labeling type native labels David Quigley
2012-11-12  6:15 ` [PATCH 05/13] KConfig: Add KConfig entries for Labeled NFS David Quigley
2012-11-12 14:45   ` J. Bruce Fields
2012-11-12 14:57     ` Dave Quigley
2012-11-12  6:15 ` [PATCH 06/13] NFSv4: Add label recommended attribute and NFSv4 flags David Quigley
2012-11-12  6:15 ` [PATCH 07/13] NFSv4: Introduce new label structure David Quigley
2012-11-12 15:13   ` J. Bruce Fields
2012-11-12 15:32     ` David P. Quigley
2012-11-12 16:05       ` J. Bruce Fields
2012-11-12 16:53         ` David P. Quigley
2012-11-12 17:50           ` J. Bruce Fields
2012-11-12  6:15 ` [PATCH 08/13] NFSv4: Extend fattr bitmaps to support all 3 words David Quigley
2012-11-12  6:15 ` [PATCH 09/13] NFS:Add labels to client function prototypes David Quigley
2012-11-12  6:15 ` [PATCH 10/13] NFS: Add label lifecycle management David Quigley
2012-11-12 15:33   ` J. Bruce Fields
2012-11-12 15:36     ` David P. Quigley
2012-11-12  6:15 ` [PATCH 11/13] NFS: Client implementation of Labeled-NFS David Quigley
2012-11-12  6:15 ` [PATCH 12/13] NFS: Extend NFS xattr handlers to accept the security namespace David Quigley
2012-11-12  6:15 ` [PATCH 13/13] NFSD: Server implementation of MAC Labeling David Quigley
2012-11-12 16:31   ` J. Bruce Fields
2012-11-12 15:23 ` Labeled NFS [v5] J. Bruce Fields
2012-11-12 15:34   ` David P. Quigley
2012-11-12 16:09     ` J. Bruce Fields
2012-11-12 20:56       ` Steve Dickson
2012-11-13  1:39         ` Dave Quigley
2012-11-13 12:55           ` Steve Dickson
2012-11-14  4:32             ` Dave Quigley
2012-11-14 13:45               ` J. Bruce Fields
2012-11-14 13:50                 ` David Quigley
2012-11-14 13:59                   ` J. Bruce Fields
2012-11-14 14:01                     ` David Quigley
2012-11-14 14:04                     ` David Quigley
2012-11-14 14:24                       ` J. Bruce Fields
2012-11-14 14:30                         ` David Quigley
2012-11-15 16:00                           ` Casey Schaufler
2012-11-15 20:28                             ` David Quigley
2012-11-16  3:34                               ` Casey Schaufler
2012-11-16  3:43                                 ` David Quigley
2012-11-16  4:58                                   ` Dave Quigley
2012-11-16  4:59                                   ` Dave Quigley
2012-11-14 13:56               ` David Quigley
2012-11-12 16:33 ` J. Bruce Fields
2012-11-12 20:44   ` Dave Quigley
2012-11-12 22:23 ` Casey Schaufler
2012-11-13  3:16   ` Dave Quigley
2012-11-20 21:09 ` Casey Schaufler
2012-11-21  0:04   ` Dave Quigley
2012-11-21  0:29     ` Dave Quigley
2012-11-21  0:32     ` Casey Schaufler
2012-11-21  0:37       ` Dave Quigley
2012-11-21  2:52         ` Casey Schaufler
2012-11-21  3:28           ` Dave Quigley
2012-11-28 18:57             ` Casey Schaufler
2012-11-29  1:14               ` Dave Quigley
2012-11-29  2:08                 ` Casey Schaufler
2012-11-29 22:28                   ` Casey Schaufler
2012-11-29 22:49                     ` David Quigley
2012-11-30  0:02                       ` David Quigley
2012-11-30  0:07                     ` David Quigley
2012-11-30  0:34                       ` Casey Schaufler
2012-11-30  0:46                         ` David Quigley
2012-11-30  1:50                           ` Casey Schaufler
2012-11-30  2:02                             ` David Quigley
2012-11-30 12:14                               ` J. Bruce Fields
2012-11-30 12:57                                 ` David Quigley
2012-11-30 13:17                                   ` David Quigley
2012-11-30 13:28                                     ` Stephen Smalley
2012-11-30 13:35                                       ` David Quigley
2012-11-30 13:50                                         ` Stephen Smalley
2012-11-30 14:02                                           ` David Quigley
2012-11-30 16:21                                             ` Casey Schaufler
2012-11-30 16:28                                               ` David Quigley
2012-12-03 18:27                                             ` Casey Schaufler
2012-11-30 16:55                                           ` J. Bruce Fields
2012-11-30 16:59                                             ` David Quigley
2012-11-30 13:20                                 ` David Quigley
  -- strict thread matches above, loose matches on Subject: below --
2012-12-17 15:42 [PATCH 00/13] NFSv4: Label NFS Patches Steve Dickson
2012-12-17 15:42 ` [PATCH 01/13] Security: Add hook to calculate context based on a negative dentry Steve Dickson
2013-05-13 19:11 [PATCH 00/13] lnfs: linux-3.10-rc1 release Steve Dickson
2013-05-13 19:11 ` [PATCH 01/13] Security: Add hook to calculate context based on a negative dentry Steve Dickson
2013-05-16 15:56 Froe e71bf1d708e1294b3bae64d04f03228b3625f2a3 Mon Sep 17 00:00:00 2001 Steve Dickson
2013-05-16 15:56 ` [PATCH 01/13] Security: Add hook to calculate context based on a negative dentry Steve Dickson
2013-05-20 21:14   ` Eric Paris
2013-05-22 16:50 [PATCH 00/13] lnfs: 3.10-rc2 release Steve Dickson
2013-05-22 16:50 ` [PATCH 01/13] Security: Add hook to calculate context based on a negative dentry Steve Dickson

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=50A10D4A.2030001@davequigley.com \
    --to=dpquigl@davequigley.com \
    --cc=Matthew.Dodd@sparta.com \
    --cc=Mi_Mi_AUNG@dsi.a-star.edu.sg \
    --cc=PHUA_Eu_Gene@dsi.a-star.edu.sg \
    --cc=Rodel_FM@dsi.a-star.edu.sg \
    --cc=bfields@fieldses.org \
    --cc=linux-nfs@vger.kernel.org \
    --cc=linux-security-module@vger.kernel.org \
    --cc=sds@tycho.nsa.gov \
    --cc=selinux@tycho.nsa.gov \
    --cc=trond.myklebust@netapp.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).