SELinux: better printk when file with invalid label found

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Linux Kernel Mailing List
Date: Thursday, March 26, 2009 - 12:01 pm

Gitweb:     http://git.kernel.org/linus/4ba0a8ad63e12a03ae01c039482967cc496b9174
Commit:     4ba0a8ad63e12a03ae01c039482967cc496b9174
Parent:     200ac532a4bc3134147ca06686c56a6420e66c46
Author:     Eric Paris <eparis@redhat.com>
AuthorDate: Thu Feb 12 15:01:10 2009 -0500
Committer:  James Morris <jmorris@namei.org>
CommitDate: Sat Feb 14 09:22:27 2009 +1100

    SELinux: better printk when file with invalid label found
    
    Currently when an inode is read into the kernel with an invalid label
    string (can often happen with removable media) we output a string like:
    
    SELinux: inode_doinit_with_dentry:  context_to_sid([SOME INVALID LABEL])
    returned -22 dor dev=[blah] ino=[blah]
    
    Which is all but incomprehensible to all but a couple of us.  Instead, on
    EINVAL only, I plan to output a much more user friendly string and I plan to
    ratelimit the printk since many of these could be generated very rapidly.
    
    Signed-off-by: Eric Paris <eparis@redhat.com>
    Acked-by:  Stephen Smalley <sds@tycho.nsa.gov>
    Signed-off-by: James Morris <jmorris@namei.org>
---
 security/selinux/hooks.c |   17 +++++++++++++----
 1 files changed, 13 insertions(+), 4 deletions(-)

diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c
index e9011e5..aebcfad 100644
--- a/security/selinux/hooks.c
+++ b/security/selinux/hooks.c
@@ -1315,10 +1315,19 @@ static int inode_doinit_with_dentry(struct inode *inode, struct dentry *opt_dent
 							     sbsec->def_sid,
 							     GFP_NOFS);
 			if (rc) {
-				printk(KERN_WARNING "SELinux: %s:  context_to_sid(%s) "
-				       "returned %d for dev=%s ino=%ld\n",
-				       __func__, context, -rc,
-				       inode->i_sb->s_id, inode->i_ino);
+				char *dev = inode->i_sb->s_id;
+				unsigned long ino = inode->i_ino;
+
+				if (rc == -EINVAL) {
+					if (printk_ratelimit())
+						printk(KERN_NOTICE "SELinux: inode=%lu on dev=%s was found to have an invalid "
+							"context=%s.  This indicates you may need to relabel the inode or the "
+							"filesystem in question.\n", ino, dev, context);
+				} else {
+					printk(KERN_WARNING "SELinux: %s:  context_to_sid(%s) "
+					       "returned %d for dev=%s ino=%ld\n",
+					       __func__, context, -rc, dev, ino);
+				}
 				kfree(context);
 				/* Leave with the unlabeled SID */
 				rc = 0;
--
To unsubscribe from this list: send the line "unsubscribe git-commits-head" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
SELinux: better printk when file with invalid label found, Linux Kernel Mailing ..., (Thu Mar 26, 12:01 pm)