Received: by 2002:a05:7412:251c:b0:e2:908c:2ebd with SMTP id w28csp1108845rda; Mon, 23 Oct 2023 02:52:20 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGN6vjx8T4Sg6OmIfCVMk2E5EqWnslpXLnBofejmutRtg/cLzUpLA6r+BbC4+h8j+ssSaAF X-Received: by 2002:a05:6358:2c82:b0:168:e637:9dfc with SMTP id l2-20020a0563582c8200b00168e6379dfcmr872003rwm.0.1698054739963; Mon, 23 Oct 2023 02:52:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698054739; cv=none; d=google.com; s=arc-20160816; b=j5K6AYDmnGJNnYCEclhDFfD41gEwGKMNcRawLtbLPRN4lOC7p+SgMBdYdovkbPIyjO 86v8vZ6M7OgE1ZyLQYWCDQhvwfJC/FuZMpcmTsPGoRw/brnJXjAxEoZ5RLxG9aDKS0ml pDuTjWNi1+VARu5kG2xvSoBLl71vBh7sM33bA0M0lqx3lJtaakbr42d00+Ib65JEeaD7 joox68KOs45y5TqOjVs+EdjlrR7hRs2sgYoWSjm9X0o/dd8o8kYSlq02kKQ4QcK25grA C1KN1eJdR3cpLFJkVfiLzYWaeSPhNjUSlh8nXydMGO0o7IEYXo9OyxQ7zu/wCNNgUsmp noZg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:references:cc:to:from:date:subject :message-id; bh=S7d/hIENeFwxd7G1JadzzvJhmwpuH4lpPoWQ3ypuZMA=; fh=8KrKJ6C2KAo7xyBKfLlD1G2iJqPbHS0xsSU09l4z9Nk=; b=Gv53VpgCNWd9m+Gz3Sjtg29aoOP9uipJlU5CB0LLRYdezElu1aeRAAuFO9cqxIotx/ iqBy9weRpklCq6uS72V/qg27zvFuYojbLRqTc0oIZmIYjuHFPRbaWqZddUMIM/e34/Sx BBxnPO+yKKrFVZLgHA7OEeNWmJ+DvHggNTua/Ru4km4kqQKk5I6FvPYkFNv52BCGq3XA b2Z7pOA1AeAcfW7oAAFnNN6g7QZCMnu0WGcP5EspSIfVC4MWUJ4ov1ujm+K15mTJIS+8 MzsgASLHto9f4fuJ2/CNBN0dxBumoJ+BP9mA00jcORKGYHvk8MB/IucpEtKrQuRm3z6V uJ9Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 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 snail.vger.email (snail.vger.email. [2620:137:e000::3:7]) by mx.google.com with ESMTPS id o8-20020a656a48000000b0059d45bf6907si6282007pgu.551.2023.10.23.02.52.19 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 23 Oct 2023 02:52:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) client-ip=2620:137:e000::3:7; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:7 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id 123E18077987; Mon, 23 Oct 2023 02:52:19 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229927AbjJWJwQ (ORCPT + 99 others); Mon, 23 Oct 2023 05:52:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53168 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229575AbjJWJwP (ORCPT ); Mon, 23 Oct 2023 05:52:15 -0400 Received: from out30-133.freemail.mail.aliyun.com (out30-133.freemail.mail.aliyun.com [115.124.30.133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D8390DA; Mon, 23 Oct 2023 02:52:12 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R211e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046049;MF=xuanzhuo@linux.alibaba.com;NM=1;PH=DS;RN=5;SR=0;TI=SMTPD_---0Vujf6Ku_1698054729; Received: from localhost(mailfrom:xuanzhuo@linux.alibaba.com fp:SMTPD_---0Vujf6Ku_1698054729) by smtp.aliyun-inc.com; Mon, 23 Oct 2023 17:52:10 +0800 Message-ID: <1698054722.2894735-1-xuanzhuo@linux.alibaba.com> Subject: Re: [PATCH] virtio_ring: add an error code check in virtqueue_resize Date: Mon, 23 Oct 2023 17:52:02 +0800 From: Xuan Zhuo To: Su Hui Cc: kernel-janitors@vger.kernel.org, linux-kernel@vger.kernel.org, virtualization@lists.linux-foundation.org, "Michael S. Tsirkin" References: <20231020092320.209234-1-suhui@nfschina.com> <20231020053047-mutt-send-email-mst@kernel.org> <1697794601.5857713-2-xuanzhuo@linux.alibaba.com> <20231020054140-mutt-send-email-mst@kernel.org> <1697795422.0986886-1-xuanzhuo@linux.alibaba.com> <20231020055943-mutt-send-email-mst@kernel.org> <1698028017.8052797-1-xuanzhuo@linux.alibaba.com> <1698029596.5404413-3-xuanzhuo@linux.alibaba.com> <46aee820-6c01-ed8a-613b-5c57258d749e@nfschina.com> <1698040004.5365264-4-xuanzhuo@linux.alibaba.com> <6a7d1006-0988-77ea-0991-9c7b422d78e1@nfschina.com> In-Reply-To: <6a7d1006-0988-77ea-0991-9c7b422d78e1@nfschina.com> 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_H2, SPF_HELO_NONE,SPF_PASS,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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Mon, 23 Oct 2023 02:52:19 -0700 (PDT) On Mon, 23 Oct 2023 17:50:46 +0800, Su Hui wrote: > On 2023/10/23 13:46, Xuan Zhuo wrote: > >>>>>>>> Well, what are the cases where it can happen practically? > >>>>>>> Device error. Such as vp_active_vq() > >>>>>>> > >>>>>>> Thanks. > >>>>>> Hmm interesting. OK. But do callers know to recover? > >>>>> No. > >>>>> > >>>>> So I think WARN + broken is suitable. > >>>>> > >>>>> Thanks. > >>>> Sorry for the late, is the following code okay? > >>>> > >>>> @@ -2739,7 +2739,7 @@ int virtqueue_resize(struct virtqueue *_vq, u32 num, > >>>> void (*recycle)(struct virtqueue *vq, void *buf)) > >>>> { > >>>> struct vring_virtqueue *vq = to_vvq(_vq); > >>>> - int err; > >>>> + int err, err_reset; > >>>> > >>>> if (num > vq->vq.num_max) > >>>> return -E2BIG; > >>>> @@ -2759,7 +2759,15 @@ int virtqueue_resize(struct virtqueue *_vq, u32 num, > >>>> else > >>>> err = virtqueue_resize_split(_vq, num); > >>>> > >>>> - return virtqueue_enable_after_reset(_vq); > >>>> + err_reset = virtqueue_enable_after_reset(_vq); > >>>> + > >>>> + if (err) { > >>> No err. > >>> > >>> err is not important. > >>> You can remove that. > >> Emm, I'm a little confused that which code should I remove ? > >> > >> > >> like this: > >> if (vq->packed_ring) > >> virtqueue_resize_packed(_vq, num); > >> else > >> virtqueue_resize_split(_vq, num); > >> > >> And we should set broken and warn inside virtqueue_enable_after_reset()? > > In my opinion, we should return the error code of virtqueue_resize_packed() / virtqueue_resize_split(). > But if this err is not important, this patch makes no sense. > Maybe I misunderstand somewhere... > If you think it's worth sending a patch, you can send it :).(I'm not familiar with this code). OK. Thanks. > > Thanks, > Su Hui >