|
@@ -1285,6 +1285,8 @@ static int inode_doinit_with_dentry(struct inode *inode, struct dentry *opt_dent
|
|
rc = inode->i_op->getxattr(dentry, XATTR_NAME_SELINUX,
|
|
rc = inode->i_op->getxattr(dentry, XATTR_NAME_SELINUX,
|
|
context, len);
|
|
context, len);
|
|
if (rc == -ERANGE) {
|
|
if (rc == -ERANGE) {
|
|
|
|
+ kfree(context);
|
|
|
|
+
|
|
/* Need a larger buffer. Query for the right size. */
|
|
/* Need a larger buffer. Query for the right size. */
|
|
rc = inode->i_op->getxattr(dentry, XATTR_NAME_SELINUX,
|
|
rc = inode->i_op->getxattr(dentry, XATTR_NAME_SELINUX,
|
|
NULL, 0);
|
|
NULL, 0);
|
|
@@ -1292,7 +1294,6 @@ static int inode_doinit_with_dentry(struct inode *inode, struct dentry *opt_dent
|
|
dput(dentry);
|
|
dput(dentry);
|
|
goto out_unlock;
|
|
goto out_unlock;
|
|
}
|
|
}
|
|
- kfree(context);
|
|
|
|
len = rc;
|
|
len = rc;
|
|
context = kmalloc(len+1, GFP_NOFS);
|
|
context = kmalloc(len+1, GFP_NOFS);
|
|
if (!context) {
|
|
if (!context) {
|