Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp963052pxp; Wed, 16 Mar 2022 22:47:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwKuiVTTnc7ItSnG87N+qbUUcnpYIsmAplJrAVZmvArnY7V/5HXaTuu2pYRTWVNCgctbyK5 X-Received: by 2002:a17:902:b208:b0:14f:14e8:1e49 with SMTP id t8-20020a170902b20800b0014f14e81e49mr3294485plr.35.1647496030820; Wed, 16 Mar 2022 22:47:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1647496030; cv=none; d=google.com; s=arc-20160816; b=LmJGyaR9gTPFHJbGs2hWbkEiNCxM5LvV6sX3fsO/1qtJ3h+Sx0gx3Yij9aZNddv4+R TnjpP9f/EvITAf7h0/NuX5At8mLTnqT61ZHCPTcmFzENH3PfRCPYoHRDRqond7rFua4y +SedacONMSIrpfjEJJwPEpzcfxdV/dLGbcsxri7zoPmdxJU4QcUlWMT2Rf19FZlj9IfA m0Td5jF1E6oBawcr9VN9eJzPb4Su3TNf2rLSbu3OoKfcPRgQmcK4YNUXgYOontSHG6Ms TqP8oSvdyZzA/WBjB/sFi+nmyIqhytqHcTWyRrP8Q/if6HOsHHPABXy8zpZPo6PJU99T EaSg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :mime-version:user-agent:date:message-id:from:references:cc:to :subject; bh=eUZPohyxelPQ3q4ceCrDddi20b0bI3TSER27maraJSI=; b=QSNH6behB7HWAt40Vrfwua6JEp/7CCM6WhPQ0AGVfvUsnogTKXwHg6U3UzSl+e13VG 9WNSGLyBkWwNgIYEg0gwtq05FLJkwxdl8ZyaEvicencJonq95Qgfo0S5j4oNkGqkzjb2 n35YfTsUzBkp3Wkya69o85Dz1nACWvty2C+6qxoUOmy+obi6nzn2Z6BRJFbHjSw4DFMH I2Zc9XeNO1ZhtO0knknO2HM8NOaAzksDKoD4k9Dl31WAWM+NP7ZhaUCV3RJaSYzjSodA W9Uueiytt6ZZbK/K4gPINCHgfmQc1aTL8l6EAIzQaEIOFcfgVNQ9eN6lSRghFLXLZ0UY Zgqg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id n3-20020a170903110300b001534a270decsi4236513plh.436.2022.03.16.22.47.10 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 16 Mar 2022 22:47:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A5EE012D095; Wed, 16 Mar 2022 21:42:28 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1357348AbiCQBaj (ORCPT + 99 others); Wed, 16 Mar 2022 21:30:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43228 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234279AbiCQBai (ORCPT ); Wed, 16 Mar 2022 21:30:38 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2737FB9D; Wed, 16 Mar 2022 18:29:22 -0700 (PDT) Received: from dggpeml500020.china.huawei.com (unknown [172.30.72.53]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4KJqJm1D3pzfYpf; Thu, 17 Mar 2022 09:27:52 +0800 (CST) Received: from [10.174.177.174] (10.174.177.174) by dggpeml500020.china.huawei.com (7.185.36.88) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.21; Thu, 17 Mar 2022 09:29:19 +0800 Subject: Re: [PATCH -next] jffs2: fix use-after-free in jffs2_clear_xattr_subsystem To: Richard Weinberger CC: David Woodhouse , christian brauner , linux-mtd , linux-kernel , yukuai3 , stable , Hulk Robot , Baokun Li References: <20211228125430.1880252-1-libaokun1@huawei.com> <8a175ec6-1555-8575-1f03-0002efac1740@huawei.com> <1891491465.152789.1647468069089.JavaMail.zimbra@nod.at> From: "libaokun (A)" Message-ID: <2eb626fe-3ab2-2830-12b7-0de74ddd9258@huawei.com> Date: Thu, 17 Mar 2022 09:29:11 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.9.0 MIME-Version: 1.0 In-Reply-To: <1891491465.152789.1647468069089.JavaMail.zimbra@nod.at> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 8bit X-Originating-IP: [10.174.177.174] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To dggpeml500020.china.huawei.com (7.185.36.88) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,NICE_REPLY_A, RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 在 2022/3/17 6:01, Richard Weinberger 写道: > ----- Ursprüngliche Mail ----- >> Von: "libaokun" >> An: "richard" , "David Woodhouse" , "christian brauner" >> , "linux-mtd" , "linux-kernel" >> >> CC: "yukuai3" , "stable" , "Hulk Robot" , "libaokun" >> >> Gesendet: Donnerstag, 10. März 2022 09:35:18 >> Betreff: Re: [PATCH -next] jffs2: fix use-after-free in jffs2_clear_xattr_subsystem >> A gentle ping, sorry for the noise. >> >> 在 2021/12/28 20:54, Baokun Li 写道: >>> When we mount a jffs2 image, assume that the first few blocks of >>> the image are normal and contain at least one xattr-related inode, >>> but the next block is abnormal. As a result, an error is returned >>> in jffs2_scan_eraseblock(). jffs2_clear_xattr_subsystem() is then >>> called in jffs2_build_filesystem() and then again in >>> jffs2_do_fill_super(). >>> >>> Finally we can observe the following report: >>> ================================================================== >>> BUG: KASAN: use-after-free in jffs2_clear_xattr_subsystem+0x95/0x6ac >>> Read of size 8 at addr ffff8881243384e0 by task mount/719 >>> >>> Call Trace: >>> dump_stack+0x115/0x16b >>> jffs2_clear_xattr_subsystem+0x95/0x6ac >>> jffs2_do_fill_super+0x84f/0xc30 >>> jffs2_fill_super+0x2ea/0x4c0 >>> mtd_get_sb+0x254/0x400 >>> mtd_get_sb_by_nr+0x4f/0xd0 >>> get_tree_mtd+0x498/0x840 >>> jffs2_get_tree+0x25/0x30 >>> vfs_get_tree+0x8d/0x2e0 >>> path_mount+0x50f/0x1e50 >>> do_mount+0x107/0x130 >>> __se_sys_mount+0x1c5/0x2f0 >>> __x64_sys_mount+0xc7/0x160 >>> do_syscall_64+0x45/0x70 >>> entry_SYSCALL_64_after_hwframe+0x44/0xa9 >>> >>> Allocated by task 719: >>> kasan_save_stack+0x23/0x60 >>> __kasan_kmalloc.constprop.0+0x10b/0x120 >>> kasan_slab_alloc+0x12/0x20 >>> kmem_cache_alloc+0x1c0/0x870 >>> jffs2_alloc_xattr_ref+0x2f/0xa0 >>> jffs2_scan_medium.cold+0x3713/0x4794 >>> jffs2_do_mount_fs.cold+0xa7/0x2253 >>> jffs2_do_fill_super+0x383/0xc30 >>> jffs2_fill_super+0x2ea/0x4c0 >>> [...] >>> >>> Freed by task 719: >>> kmem_cache_free+0xcc/0x7b0 >>> jffs2_free_xattr_ref+0x78/0x98 >>> jffs2_clear_xattr_subsystem+0xa1/0x6ac >>> jffs2_do_mount_fs.cold+0x5e6/0x2253 >>> jffs2_do_fill_super+0x383/0xc30 >>> jffs2_fill_super+0x2ea/0x4c0 >>> [...] >>> >>> The buggy address belongs to the object at ffff8881243384b8 >>> which belongs to the cache jffs2_xattr_ref of size 48 >>> The buggy address is located 40 bytes inside of >>> 48-byte region [ffff8881243384b8, ffff8881243384e8) >>> [...] >>> ================================================================== >>> >>> The triggering of the BUG is shown in the following stack: >>> ----------------------------------------------------------- >>> jffs2_fill_super >>> jffs2_do_fill_super >>> jffs2_do_mount_fs >>> jffs2_build_filesystem >>> jffs2_scan_medium >>> jffs2_scan_eraseblock <--- ERROR >>> jffs2_clear_xattr_subsystem <--- free >>> jffs2_clear_xattr_subsystem <--- free again >>> ----------------------------------------------------------- >>> >>> An error is returned in jffs2_do_mount_fs(). If the error is returned >>> by jffs2_sum_init(), the jffs2_clear_xattr_subsystem() does not need to >>> be executed. If the error is returned by jffs2_build_filesystem(), the >>> jffs2_clear_xattr_subsystem() also does not need to be executed again. >>> So move jffs2_clear_xattr_subsystem() from 'out_inohash' to 'out_root' >>> to fix this UAF problem. >>> >>> Fixes: aa98d7cf59b5 ("[JFFS2][XATTR] XATTR support on JFFS2 (version. 5)") >>> Cc: stable@vger.kernel.org >>> Reported-by: Hulk Robot >>> Signed-off-by: Baokun Li > Applied. Thanks for fixing! > > Thanks, > //richard > . Thank you for your review! -- With Best Regards, Baokun Li