Received: by 2002:a05:6358:1087:b0:cb:c9d3:cd90 with SMTP id j7csp5573312rwi; Tue, 18 Oct 2022 00:38:46 -0700 (PDT) X-Google-Smtp-Source: AMsMyM73nG9ijqx8kMjubzaHdur5S3KCFhmeX9+V8O/5mj6PcnE8Plfjd0W54bwDy2+1xIkQWN4O X-Received: by 2002:a17:907:6d27:b0:78d:46f6:c59e with SMTP id sa39-20020a1709076d2700b0078d46f6c59emr1337769ejc.30.1666078726532; Tue, 18 Oct 2022 00:38:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1666078726; cv=none; d=google.com; s=arc-20160816; b=A4CaJ3rowxTyIITlNzYGqS1e3dvx+OrV8T4MYzM9Z8kptCjM8DBPpgC9dNPjR4FTQB U4IkcWh8Hv2vFgXJu7g2St4+2I28WD8hCYnT0q/k/ZX8fGzCEKk9Gft4NVNQftfHkFrf dlQJYrUInuE6XQ6Mq6WnnuT0236LlKhcxVdDSxUwMdQDfbG5Elce235NOv7aeot90ee6 00Rd3qxgvzAhZwd0wshkSXv/QN61J0qutlRzM7XjjwjEgHHco7vlAYOZgndv0gtOE5Ou NG77+rNf/4/zcl0G5Xspgsfqznbi+WPIy3ktI5CNwtqFo4l8R8mAAbT87FiMGNpifLXD ksuQ== 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=1Xt3bXydohu2yH6CxkdxBGeHc18qyxjbVR1ibNZTomE=; b=RmfsYdCZhgvcnLj245KIL/3mRe83AvJKbo1HNbRHJrwqi+ACT8tlLfayAHc4cepjiB PG+Ma0prLbj268hXcbb3xCwIURNi7PjUky8XKirvQHFsmAkQT/bPX1pc0DKKEPxvi/gQ JACmeQq3Z5z7oh268uU0JgQOAkq6yWdliCGZnoxXX1y9aSPiZ1YDSjQRabSenlZPym5z bdPAPHuOi3sL2Rxs6Qk72X8mFitjIvXY3LD6u2gxyd2Ld44FOLfSdryQLzDVeYzglZxl QdaVM53aXdd7tCA3hdGh9a7hUXuu0G4Xa2gTecT6eC3ZVYVdITEGJukFqwMweU3u4qBn VxjQ== 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hb30-20020a170907161e00b0077077ded253si12664133ejc.924.2022.10.18.00.38.21; Tue, 18 Oct 2022 00:38:46 -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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229914AbiJRHGu (ORCPT + 99 others); Tue, 18 Oct 2022 03:06:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52764 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229732AbiJRHGr (ORCPT ); Tue, 18 Oct 2022 03:06:47 -0400 Received: from szxga03-in.huawei.com (szxga03-in.huawei.com [45.249.212.189]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6F18FA8CFD for ; Tue, 18 Oct 2022 00:06:46 -0700 (PDT) Received: from dggemv703-chm.china.huawei.com (unknown [172.30.72.55]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4Ms4bV3bPdzJn7H; Tue, 18 Oct 2022 15:04:06 +0800 (CST) Received: from kwepemm600005.china.huawei.com (7.193.23.191) by dggemv703-chm.china.huawei.com (10.3.19.46) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Tue, 18 Oct 2022 15:06:44 +0800 Received: from [10.67.103.158] (10.67.103.158) by kwepemm600005.china.huawei.com (7.193.23.191) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Tue, 18 Oct 2022 15:06:43 +0800 Subject: Re: [Linuxarm] [PATCH 1/2] hisi_acc_vfio_pci: Add debugfs to migration driver To: Jason Gunthorpe CC: John Garry , , , , , References: <20221014025757.39415-1-liulongfang@huawei.com> <20221014025757.39415-2-liulongfang@huawei.com> <42d12308-4777-47a7-a1ae-50dfada050cf@huawei.com> <7c041671-71bf-d558-d47a-70296fe5c30e@huawei.com> From: liulongfang Message-ID: <9826a418-4a14-aa4a-9eb8-6faf3e43c8e3@huawei.com> Date: Tue, 18 Oct 2022 15:06:43 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 8bit X-Originating-IP: [10.67.103.158] X-ClientProxiedBy: dggems706-chm.china.huawei.com (10.3.19.183) To kwepemm600005.china.huawei.com (7.193.23.191) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS 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 On 2022/10/17 20:11, Jason Gunthorpe Wrote: > On Mon, Oct 17, 2022 at 05:20:34PM +0800, liulongfang wrote: >> On 2022/10/14 17:20, John Garry wrote: >>> On 14/10/2022 03:57, Longfang Liu wrote: >>>> +static void hisi_acc_vf_debugfs_init(struct hisi_acc_vf_core_device *hisi_acc_vdev) >>>> +{ >>>> +    struct pci_dev *vf_pdev = hisi_acc_vdev->vf_dev; >>>> +    struct device *dev = &vf_pdev->dev; >>>> +    int ret; >>>> + >>>> +    if (!atomic_read(&hisi_acc_root_ref)) >>>> +        hisi_acc_debugfs_root = debugfs_create_dir("hisi_vfio_acc", NULL); >>>> +    atomic_inc(&hisi_acc_root_ref); >>>> + >>> >>> This looks totally racy, such that I wonder why even bother using an atomic for hisi_acc_root_ref. >> >> >> When enabling VF, it is possible for multiple VMs to enable VF at the same time. The atomic variable >> is used to ensure that only one "hisi_vfio_acc" is created. When other VFs are enabled, >> it will not be created again, but will be used directly. > > It is still completely racy. Use a lock > Do you have any suggested solutions? > Jason > . > Thanks, Longfang