[AppArmor 18/41] call lsm hook before unhashing dentry in vfs_rmdir()

Previous thread: [AppArmor 17/41] Pass struct vfsmount to the inode_rmdir LSM hook by jjohansen on Thursday, April 12, 2007 - 2:08 am. (1 message)

Next thread: [AppArmor 01/41] Pass struct vfsmount to the inode_create LSM hook by jjohansen on Thursday, April 12, 2007 - 2:08 am. (19 messages)
From: jjohansen
Date: Thursday, April 12, 2007 - 2:08 am

If we unhash the dentry before calling the security_inode_rmdir hook,
we cannot compute the file's pathname in the hook anymore. AppArmor
needs to know the filename in order to decide whether a file may be
deleted, though.

Signed-off-by: John Johansen <jjohansen@suse.de>
Signed-off-by: Andreas Gruenbacher <agruen@suse.de>

---
 fs/namei.c |   13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)

--- a/fs/namei.c
+++ b/fs/namei.c
@@ -2016,6 +2016,10 @@ int vfs_rmdir(struct inode *dir, struct 
 	if (!dir->i_op || !dir->i_op->rmdir)
 		return -EPERM;
 
+	error = security_inode_rmdir(dir, dentry, mnt);
+	if (error)
+		return error;
+
 	DQUOT_INIT(dir);
 
 	mutex_lock(&dentry->d_inode->i_mutex);
@@ -2023,12 +2027,9 @@ int vfs_rmdir(struct inode *dir, struct 
 	if (d_mountpoint(dentry))
 		error = -EBUSY;
 	else {
-		error = security_inode_rmdir(dir, dentry, mnt);
-		if (!error) {
-			error = dir->i_op->rmdir(dir, dentry);
-			if (!error)
-				dentry->d_inode->i_flags |= S_DEAD;
-		}
+		error = dir->i_op->rmdir(dir, dentry);
+		if (!error)
+			dentry->d_inode->i_flags |= S_DEAD;
 	}
 	mutex_unlock(&dentry->d_inode->i_mutex);
 	if (!error) {

-- 
-

Previous thread: [AppArmor 17/41] Pass struct vfsmount to the inode_rmdir LSM hook by jjohansen on Thursday, April 12, 2007 - 2:08 am. (1 message)

Next thread: [AppArmor 01/41] Pass struct vfsmount to the inode_create LSM hook by jjohansen on Thursday, April 12, 2007 - 2:08 am. (19 messages)