Received: by 2002:a05:7412:251c:b0:e2:908c:2ebd with SMTP id w28csp1800303rda; Tue, 24 Oct 2023 03:54:07 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGHRgyQuRmG2fiUwfBfSU2UW4ex4XcqPuHb2n/wiB3rT0N8m1lYmFH35LW4ohTttq1co5UK X-Received: by 2002:a17:902:f685:b0:1c7:7c2c:f828 with SMTP id l5-20020a170902f68500b001c77c2cf828mr16139061plg.8.1698144846916; Tue, 24 Oct 2023 03:54:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698144846; cv=none; d=google.com; s=arc-20160816; b=rD/1KFQrNnHCMMybviEnh3ogdLFWwBMr74/9USSSewj4NSJl+xl2gWAka+Kvpl9Mj3 8k32uRTUvGeUb21LR+NF6QyCWAuelWhonFnmiw2UoZEuvdmXPX/M1uzCziSL9/olP3Ll zfHpyhiu672eJv3VPRefNnCs2GjyyPUVMB6VfonvQ1Ivcj8XZIbA8CYBmNfm+oUEsrtd iwiPdLeMTkk1uzpEOEeP62RY0ZjDT/nyXHjRSnamtQSO5P3Bl6/kYBM3c0bUAJg+jMVU +Xyw/SOhxUH2CtOAHZ6PYUXFvVRaNMVJ/py33sZMaT7F2q7Jbq9O+9x+6SIjr2O45PPC CwnA== 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=ou+4zVIMeBL1N9+h2T5UyqdPVvvFq9kyK76R2rKH5oU=; fh=BXMGSVlN6OlngdBx06lETCkN0bY0XpuphERSe8Z8350=; b=KybfEwH9gxBMms2rUvXl+F+TreDRXhbZtWayIfkyK3SWHenevlERjk00RUi7NqWRYX lYNHaIBv0KL9kQHaix3ba1a+3LInyHf0P8VPFrj/ofDJe4PS3LZItjQ7VWzRbTz5uxdD Va8TIXEb78aqAScDZvVFNR1X03xElPPgoHVgua2mHNLSUxEGIUx/v/Yxt9lr5hfvYmit qK0gMt2FRDB/NQ5C45sdtb3AAyGPyIBtFcRmtupjldfvg60m7/LSJY4yVi4HO81qAURM KSp9a2asz4ZvBfptm1rrlWU4tzZd9nWWs+s0/5z3Iawoio9M876NM0HQMv5Xf6ecr0pt +5JA== 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:2 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 agentk.vger.email (agentk.vger.email. [2620:137:e000::3:2]) by mx.google.com with ESMTPS id b9-20020a170902d50900b001c88fc3c593si8323816plg.560.2023.10.24.03.54.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 24 Oct 2023 03:54:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) client-ip=2620:137:e000::3:2; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 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 agentk.vger.email (Postfix) with ESMTP id 785708041FDE; Tue, 24 Oct 2023 03:54:04 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229761AbjJXKx4 (ORCPT + 99 others); Tue, 24 Oct 2023 06:53:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33392 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234432AbjJXKxz (ORCPT ); Tue, 24 Oct 2023 06:53:55 -0400 Received: from out30-119.freemail.mail.aliyun.com (out30-119.freemail.mail.aliyun.com [115.124.30.119]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3E0EBD7B for ; Tue, 24 Oct 2023 03:53:49 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R101e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046059;MF=xuanzhuo@linux.alibaba.com;NM=1;PH=DS;RN=7;SR=0;TI=SMTPD_---0VuqAa21_1698144824; Received: from localhost(mailfrom:xuanzhuo@linux.alibaba.com fp:SMTPD_---0VuqAa21_1698144824) by smtp.aliyun-inc.com; Tue, 24 Oct 2023 18:53:45 +0800 Message-ID: <1698144808.8577316-1-xuanzhuo@linux.alibaba.com> Subject: Re: [PATCH 1/2] virtio_pci: Don't make an extra copy of cpu affinity mask Date: Tue, 24 Oct 2023 18:53:28 +0800 From: Xuan Zhuo To: Jakub Sitnicki Cc: "Michael S. Tsirkin" , Jason Wang , linux-kernel@vger.kernel.org, kernel-team@cloudflare.com, Caleb Raitto , virtualization@lists.linux-foundation.org References: <20231019101625.412936-1-jakub@cloudflare.com> <1697720122.49851-2-xuanzhuo@linux.alibaba.com> <87il6x2rj6.fsf@cloudflare.com> <1698114697.434748-1-xuanzhuo@linux.alibaba.com> <87edhk2z03.fsf@cloudflare.com> In-Reply-To: <87edhk2z03.fsf@cloudflare.com> X-Spam-Status: No, score=-0.7 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,UNPARSEABLE_RELAY autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.vger.email 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 (agentk.vger.email [0.0.0.0]); Tue, 24 Oct 2023 03:54:04 -0700 (PDT) On Tue, 24 Oct 2023 10:17:19 +0200, Jakub Sitnicki wrote: > On Tue, Oct 24, 2023 at 10:31 AM +08, Xuan Zhuo wrote: > > On Mon, 23 Oct 2023 18:52:45 +0200, Jakub Sitnicki wrote: > >> On Thu, Oct 19, 2023 at 08:55 PM +08, Xuan Zhuo wrote: > >> > On Thu, 19 Oct 2023 12:16:24 +0200, Jakub Sitnicki wrote: > >> >> Since commit 19e226e8cc5d ("virtio: Make vp_set_vq_affinity() take a > >> >> mask.") it is actually not needed to have a local copy of the cpu mask. > >> > > >> > > >> > Could you give more info to prove this? > > > > > > Actually, my question is that can we pass a val on the stack(or temp value) to > > the irq_set_affinity_hint()? > > > > Such as the virtio-net uses zalloc_cpumask_var to alloc a cpu_mask, and > > that will be released. > > > > > > > > int __irq_apply_affinity_hint(unsigned int irq, const struct cpumask *m, > > bool setaffinity) > > { > > unsigned long flags; > > struct irq_desc *desc = irq_get_desc_lock(irq, &flags, IRQ_GET_DESC_CHECK_GLOBAL); > > > > if (!desc) > > return -EINVAL; > > -> desc->affinity_hint = m; > > irq_put_desc_unlock(desc, flags); > > if (m && setaffinity) > > __irq_set_affinity(irq, m, false); > > return 0; > > } > > EXPORT_SYMBOL_GPL(__irq_apply_affinity_hint); > > > > The above code directly refers the mask pointer. If the mask is a temp value, I > > think that is a bug. > > You are completely right. irq_set_affinity_hint stores the mask pointer. > irq_affinity_hint_proc_show later dereferences it when user reads out > /proc/irq/*/affinity_hint. > > I have failed to notice that. That's why we need cpumask_copy to stay. > > My patch is buggy. Please disregard. > > I will send a v2 to only migrate from deprecated irq_set_affinity_hint. > > > And I notice that many places directly pass the temp value to this API. > > And I am a little confused. ^_^ Or I missed something. > > There seem two be two gropus of callers: > > 1. Those that use get_cpu_mask/cpumask_of/cpumask_of_node to produce a > cpumask pointer which is a preallocated constant. > > $ weggli 'irq_set_affinity_hint(_, $func(_));' ~/src/linux > > 2. Those that pass a pointer to memory somewhere. > > $ weggli 'irq_set_affinity_hint(_, $mask);' ~/src/linux > > (weggli tool can be found at https://github.com/weggli-rs/weggli) > > I've looked over the callers from group #2 but I couldn't find any > passing a pointer memory on stack :-) Pls check stmmac_request_irq_multi_msi() Thanks. > > Thanks for pointing this out. > > [...]