On Monday, December 19, 2016 9:43:06 AM EST Stephen Smalley wrote:
 On Sat, 2016-12-17 at 20:48 +0000, Gary Tierney wrote:
 > Adds error and warning messages to the codepaths which can fail when
 > loading a new policy.  If a policy fails to load, an error message
 > will
 > be printed to dmesg with a description of what failed.  Previously if
 > there was an error during policy loading there would be no indication
 > that it failed.
 > 
 > Signed-off-by: Gary Tierney <gary.tierney(a)gmx.com>
 > ---
 >  security/selinux/selinuxfs.c | 26 +++++++++++++++++++++-----
 >  1 file changed, 21 insertions(+), 5 deletions(-)
 > 
 > diff --git a/security/selinux/selinuxfs.c
 > b/security/selinux/selinuxfs.c
 > index 0aac402..2139cc7 100644
 > --- a/security/selinux/selinuxfs.c
 > +++ b/security/selinux/selinuxfs.c
 > @@ -522,20 +522,32 @@ static ssize_t sel_write_load(struct file
 > *file, const char __user *buf,
 >  		goto out;
 >  
 >  	length = security_load_policy(data, count);
 > -	if (length)
 > +	if (length) {
 > +		pr_err("SELinux: %s: failed to load policy\n",
 > +		      __func__);
 
 Not sure about your usage of pr_err() vs pr_warn();
 security_load_policy() may simply fail due to invalid policy from
 userspace, not a kernel-internal error per se.
 
 I would tend to omit the function name; I don't think it is especially
 helpful.
 
 There was an earlier discussion about augmenting the audit logging from
 this function, so this might overlap with that.  I don't know where
 that stands. 
I have a new patch that I'm going to send soon that addresses this. But I also 
have a second patch that fixes the setboolean auditing as well, but it 
deadlocks the system. I talked about it with Paul and I have an idea on how to 
fix the deadlock but I haven't sent the updated patches yet. I plan to get to 
them later this week.
-Steve
 >  		goto out;
 > +	}
 >  
 >  	length = sel_make_bools();
 > -	if (length)
 > +	if (length) {
 > +		pr_warn("SELinux: %s: failed to load policy
 > booleans\n",
 > +		       __func__);
 >  		goto out1;
 > +	}
 >  
 >  	length = sel_make_classes();
 > -	if (length)
 > +	if (length) {
 > +		pr_warn("SELinux: %s: failed to load policy
 > classes\n",
 > +		       __func__);
 >  		goto out1;
 > +	}
 >  
 >  	length = sel_make_policycap();
 > -	if (length)
 > +	if (length) {
 > +		pr_warn("SELinux: %s: failed to load policy
 > capabilities\n",
 > +		       __func__);
 >  		goto out1;
 > +	}
 >  
 >  	length = count;
 >  
 > @@ -1299,9 +1311,13 @@ static int sel_make_bools(void)
 >  
 >  		isec = (struct inode_security_struct *)inode-
 > 
 > >i_security;
 > 
 >  		ret = security_genfs_sid("selinuxfs", page,
 > SECCLASS_FILE, &sid);
 > -		if (ret)
 > +		if (ret) {
 > +			pr_warn_ratelimited("SELinux: %s: failed to
 > lookup sid for %s\n",
 > +					   __func__, page);
 >  			goto out;
 >  
 > +		}
 > +
 >  		isec->sid = sid;
 >  		isec->initialized = LABEL_INITIALIZED;
 >  		inode->i_fop = &sel_bool_ops;