Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp76841pxp; Wed, 16 Mar 2022 00:20:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwhVLdnhndgxVJh8R+BxIhBor7x46NmeoBUBWQ+Oy0K58IL0TFn19ZPTmICqQgZvVB/ocNq X-Received: by 2002:aa7:d648:0:b0:416:4b85:da68 with SMTP id v8-20020aa7d648000000b004164b85da68mr27718453edr.253.1647415252765; Wed, 16 Mar 2022 00:20:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1647415252; cv=none; d=google.com; s=arc-20160816; b=q4gb/hdB6+36NA6OD5StXLAkxYewxj9m21kreIsNjey4XJLpdQh3TSlogQb5a1Vs+B Uy/W4jATLrTEd5F1KSVxh777h0fRjNyOkFf9Mh4Y91h9AZGIdXiMuE5RBOi2PzvprsfP BqBj2i1O2SRO2rOILzF3aOQmYsWJ6mIVcYZhhMGqngacVmI1Q8n+YLhmAZ3n/vXWHvwy j3zqqoKHlEbngJH/5Jxh1i/ng0kLoZbjLXOvJ1zrfgL+nbHlg6f94+1bdFUmN61NjKh7 M3PBx5sD/FzPIfW69VrRdwed+8yjZhpkTkeg4ozYgqDU7BpP9PTuMpHxsZ+0ofaFGXUD 9TyA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=9tmkZAlRnB9PtHDbpw4MkqdYeo2jjNUGpXYhrh+01Gs=; b=abWjXhfxkHzbPtoIxGqrfTEmXKNd5/4rlYVV+Cu2YK6NNOmH7MNZaIQsI2HicCRQh+ g3Y/Elp8dQL+QnNzufNln8WF8kytgAZsdxU4M82p3J9FWJTkNcjhRJV5pm1vFhIMfyd9 f11JifPme4dGZEv+v2hSWgdiKkVtj24xeHNAQGo3w8XtIkjd5ubwSDyIMlmajZhUGgB0 9ZKm6YkGjg4Ize2tG3AcJopz9qJOZSo4Bqkzv+oTho6fb5bQJrQ8FN0fvpymWlHNwXUZ ws9lc9nfijSP46ISVnZOXuQ79PLi1/79Fmj3UAiJn00AZwMmovsV9T7Ilh7RNDPiIbBO uGew== 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:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b9-20020a50e389000000b0041357f15eecsi875460edm.66.2022.03.16.00.20.27; Wed, 16 Mar 2022 00:20:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1348241AbiCOM1I (ORCPT + 99 others); Tue, 15 Mar 2022 08:27:08 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53878 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1348238AbiCOM1H (ORCPT ); Tue, 15 Mar 2022 08:27:07 -0400 Received: from out30-54.freemail.mail.aliyun.com (out30-54.freemail.mail.aliyun.com [115.124.30.54]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C8F05532E0 for ; Tue, 15 Mar 2022 05:25:55 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R201e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04394;MF=hsiangkao@linux.alibaba.com;NM=1;PH=DS;RN=8;SR=0;TI=SMTPD_---0V7I11eB_1647347151; Received: from B-P7TQMD6M-0146.local(mailfrom:hsiangkao@linux.alibaba.com fp:SMTPD_---0V7I11eB_1647347151) by smtp.aliyun-inc.com(127.0.0.1); Tue, 15 Mar 2022 20:25:53 +0800 Date: Tue, 15 Mar 2022 20:25:51 +0800 From: Gao Xiang To: Dongliang Mu Cc: Huang Jianan , Dongliang Mu , Gao Xiang , Chao Yu , syzkaller , linux-erofs@lists.ozlabs.org, linux-kernel Subject: Re: [PATCH] fs: erofs: remember if kobject_init_and_add was done Message-ID: References: <20220315075152.63789-1-dzm91@hust.edu.cn> <8d832e7a-c8da-d2fa-571a-ea150b8deb1b@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Spam-Status: No, score=-9.9 required=5.0 tests=BAYES_00, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H5, RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE, UNPARSEABLE_RELAY,USER_IN_DEF_SPF_WL autolearn=ham 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 Hi Dongliang, On Tue, Mar 15, 2022 at 07:59:26PM +0800, Dongliang Mu wrote: > On Tue, Mar 15, 2022 at 7:05 PM Huang Jianan wrote: > > > > 在 2022/3/15 18:55, Gao Xiang 写道: > > > On Tue, Mar 15, 2022 at 06:43:01PM +0800, Huang Jianan wrote: > > >> 在 2022/3/15 15:51, Dongliang Mu 写道: > > >>> From: Dongliang Mu > > >>> > > >>> Syzkaller hit 'WARNING: kobject bug in erofs_unregister_sysfs'. This bug > > >>> is triggered by injecting fault in kobject_init_and_add of > > >>> erofs_unregister_sysfs. > > >>> > > >>> Fix this by remembering if kobject_init_and_add is successful. > > >>> > > >>> Note that I've tested the patch and the crash does not occur any more. > > >>> > > >>> Reported-by: syzkaller > > >>> Signed-off-by: Dongliang Mu > > >>> --- > > >>> fs/erofs/internal.h | 1 + > > >>> fs/erofs/sysfs.c | 9 ++++++--- > > >>> 2 files changed, 7 insertions(+), 3 deletions(-) > > >>> > > >>> diff --git a/fs/erofs/internal.h b/fs/erofs/internal.h > > >>> index 5aa2cf2c2f80..9e20665e3f68 100644 > > >>> --- a/fs/erofs/internal.h > > >>> +++ b/fs/erofs/internal.h > > >>> @@ -144,6 +144,7 @@ struct erofs_sb_info { > > >>> u32 feature_incompat; > > >>> /* sysfs support */ > > >>> + bool s_sysfs_inited; > > >> Hi Dongliang, > > >> > > >> How about using sbi->s_kobj.state_in_sysfs to avoid adding a extra member in > > >> sbi ? > > > Ok, I have no tendency of these (I'm fine with either ways). > > > I've seen some usage like: > > > > > > static inline int device_is_registered(struct device *dev) > > > { > > > return dev->kobj.state_in_sysfs; > > > } > > > > > > But I'm still not sure if we need to rely on such internal > > > interface.. More thoughts? > > > > Yeah... It seems that it is better to use some of the interfaces > > provided by kobject, > > otherwise we should still maintain this state in sbi. > > > > I am fine with either way. Let me know if you reach to an agreement. If you have time, would you mind sending another patch by using state_in_sysfs? I'd like to know Chao's perference later, and apply one of them... Thanks, Gao Xiang