Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp2477665ybl; Mon, 20 Jan 2020 03:46:12 -0800 (PST) X-Google-Smtp-Source: APXvYqyMSkAaVNeUC7MOI3Nhk2O/hLmq72EKC7uX/cCjDmFZbI0S1WdWBboUQj5UyMtNFBVJ/hbQ X-Received: by 2002:a05:6830:158:: with SMTP id j24mr16003619otp.316.1579520772131; Mon, 20 Jan 2020 03:46:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579520772; cv=none; d=google.com; s=arc-20160816; b=sSlx0OCfPThi0AqNOkPynQWtNvCPqPaT6sxOKNxgxC3viy8Rk0uik9K0IPGuHSBUdm 51hGRgFSbAPUnQ6S4gg4hpE+YTKUBGtqVsJq4XX9iiZpsMgAJmN5Wuf3aYPKQKJ6UqrC B3uuHwKjDVDdPujDh/UQBYwfLsTfEiQStfBvPS31yb1f+dQ9xdxTRYWFLtqvyUGwUFtm DpeKv/Qt7p19vcg4FyoW+31xiweR4cfl5rw+lqrBuWND6R4bjl7I58V0TDjpOpc9vDn2 Q7CllsFr+ODjIEYVHs02fVEhhHlQX8nk0XgBu/znyJSOaCt3hs76h4tm3Qm2b7S4/DQV MCNw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=8buaCObZv4ivSETF7hjsiej6Y9u9q9cbe8uhn6+YX2g=; b=1FvX7u+oOjLEcobY2kUQXDzdjKPwuSJvHDq49zVzf2R1nTTSZJXYgTPKCpC4c0pxFl 1h5Se0VS8/tteLiTo3d7Ndl0KjBvSRqt8FA88QSJkShlJM0rAmD+Nm6t17BYZ8vPHs5Q X5aYPwZ1Tilg3UTTN8HfvMEcHMAcI4k9rMJsHJjg1gUaP5Gjbp2U8W8gEHcI8L+oxRk2 K28LBdxE5ofAnhsjjzrpEKNEtgl9Ps2MGE9+Vxhy/WNeVc4HZLvrmk3g0v6blNpgXDpk Dzpxz0xjgdI+KJKn0JvIG5eNKWC3G2nCZESh5TkWr9cnwX+8uPH/2e4vDf7nQj9QtTZs UJfA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m20si20409193otk.279.2020.01.20.03.45.59; Mon, 20 Jan 2020 03:46:12 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726890AbgATLpD (ORCPT + 99 others); Mon, 20 Jan 2020 06:45:03 -0500 Received: from szxga06-in.huawei.com ([45.249.212.32]:49716 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726589AbgATLpC (ORCPT ); Mon, 20 Jan 2020 06:45:02 -0500 Received: from DGGEMS412-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id 5F8E6EBFB9287DB8B0BD; Mon, 20 Jan 2020 19:45:01 +0800 (CST) Received: from [127.0.0.1] (10.173.220.179) by DGGEMS412-HUB.china.huawei.com (10.3.19.212) with Microsoft SMTP Server id 14.3.439.0; Mon, 20 Jan 2020 19:44:52 +0800 Subject: Re: [PATCH] jffs2: move jffs2_init_inode_info() just after allocating inode To: CC: , , , , , , , References: <20200106080411.41394-1-yi.zhang@huawei.com> From: "zhangyi (F)" Message-ID: <1559fa23-525b-5dad-220e-2ab2821d33eb@huawei.com> Date: Mon, 20 Jan 2020 19:44:51 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.3.0 MIME-Version: 1.0 In-Reply-To: <20200106080411.41394-1-yi.zhang@huawei.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.173.220.179] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ping. On 2020/1/6 16:04, zhangyi (F) wrote: > After commit 4fdcfab5b553 ("jffs2: fix use-after-free on symlink > traversal"), it expose a freeing uninitialized memory problem due to > this commit move the operaion of freeing f->target to > jffs2_i_callback(), which may not be initialized in some error path of > allocating jffs2 inode (eg: jffs2_iget()->iget_locked()-> > destroy_inode()->..->jffs2_i_callback()->kfree(f->target)). > > Fix this by initialize the jffs2_inode_info just after allocating it. > > Reported-by: Guohua Zhong > Reported-by: Huaijie Yi > Signed-off-by: zhangyi (F) > Cc: stable@vger.kernel.org > --- > fs/jffs2/fs.c | 2 -- > fs/jffs2/super.c | 2 ++ > 2 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/fs/jffs2/fs.c b/fs/jffs2/fs.c > index ab8cdd9e9325..50a9df7d43a5 100644 > --- a/fs/jffs2/fs.c > +++ b/fs/jffs2/fs.c > @@ -270,7 +270,6 @@ struct inode *jffs2_iget(struct super_block *sb, unsigned long ino) > f = JFFS2_INODE_INFO(inode); > c = JFFS2_SB_INFO(inode->i_sb); > > - jffs2_init_inode_info(f); > mutex_lock(&f->sem); > > ret = jffs2_do_read_inode(c, f, inode->i_ino, &latest_node); > @@ -438,7 +437,6 @@ struct inode *jffs2_new_inode (struct inode *dir_i, umode_t mode, struct jffs2_r > return ERR_PTR(-ENOMEM); > > f = JFFS2_INODE_INFO(inode); > - jffs2_init_inode_info(f); > mutex_lock(&f->sem); > > memset(ri, 0, sizeof(*ri)); > diff --git a/fs/jffs2/super.c b/fs/jffs2/super.c > index 0e6406c4f362..90373898587f 100644 > --- a/fs/jffs2/super.c > +++ b/fs/jffs2/super.c > @@ -42,6 +42,8 @@ static struct inode *jffs2_alloc_inode(struct super_block *sb) > f = kmem_cache_alloc(jffs2_inode_cachep, GFP_KERNEL); > if (!f) > return NULL; > + > + jffs2_init_inode_info(f); > return &f->vfs_inode; > } > >