]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/blame - releases/4.4.170/ext4-fix-possible-use-after-free-in-ext4_quota_enable.patch
fixes for 4.19
[thirdparty/kernel/stable-queue.git] / releases / 4.4.170 / ext4-fix-possible-use-after-free-in-ext4_quota_enable.patch
CommitLineData
326a9cc7
GKH
1From 61157b24e60fb3cd1f85f2c76a7b1d628f970144 Mon Sep 17 00:00:00 2001
2From: Pan Bian <bianpan2016@163.com>
3Date: Mon, 3 Dec 2018 23:28:02 -0500
4Subject: ext4: fix possible use after free in ext4_quota_enable
5
6From: Pan Bian <bianpan2016@163.com>
7
8commit 61157b24e60fb3cd1f85f2c76a7b1d628f970144 upstream.
9
10The function frees qf_inode via iput but then pass qf_inode to
11lockdep_set_quota_inode on the failure path. This may result in a
12use-after-free bug. The patch frees df_inode only when it is never used.
13
14Fixes: daf647d2dd5 ("ext4: add lockdep annotations for i_data_sem")
15Cc: stable@kernel.org # 4.6
16Reviewed-by: Jan Kara <jack@suse.cz>
17Signed-off-by: Pan Bian <bianpan2016@163.com>
18Signed-off-by: Theodore Ts'o <tytso@mit.edu>
19Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
20
21---
22 fs/ext4/super.c | 2 +-
23 1 file changed, 1 insertion(+), 1 deletion(-)
24
25--- a/fs/ext4/super.c
26+++ b/fs/ext4/super.c
27@@ -5184,9 +5184,9 @@ static int ext4_quota_enable(struct supe
28 qf_inode->i_flags |= S_NOQUOTA;
29 lockdep_set_quota_inode(qf_inode, I_DATA_SEM_QUOTA);
30 err = dquot_enable(qf_inode, type, format_id, flags);
31- iput(qf_inode);
32 if (err)
33 lockdep_set_quota_inode(qf_inode, I_DATA_SEM_NORMAL);
34+ iput(qf_inode);
35
36 return err;
37 }