Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp1968156rwd; Wed, 17 May 2023 04:06:13 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4K9FJZTsD53X6fa5p9Oo+sMCHXvwkQviMl2xNn1mrR1CWlC3VWm2D4HZip5K4l4K/24Mxl X-Received: by 2002:a05:6a20:12cb:b0:104:1ab7:8242 with SMTP id v11-20020a056a2012cb00b001041ab78242mr25318363pzg.43.1684321572703; Wed, 17 May 2023 04:06:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684321572; cv=none; d=google.com; s=arc-20160816; b=DAwzLK9eR3lTfB9mD91i15A8ZeUl6dSOIDh26Er+URnD2FoCtMv5tDzEnH1GnOM/Bo DLdUmZhqudzmLh8LYuO9QkDA1tCloySpQP51XpgGmjqZGQ/KJ+sKnrc0CKQu4vgu2ol2 waCjIeCxbdMqmkZXt83chNT8zH8BAbFjmBKLgRLCfqkrhn01672q+hNwhait6TuUBo0A kon8JYhIbwNY5mX3hZ6hDVIF7kWk+0ONV/rshmqiZOembBKX+g/2XYQkYNMILvfa4ZI9 GSqt/dIuG+xgjZp0cmIhuQKu2ZrFA0pe+W7E82K1TGTVdW2r5W2slrzXUB8dRFu6B67N fwGA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=R6XoseOWdzIU0KeNYEzt8GFOAsVR4w4kUmH50/FeGk0=; b=EDsG4/9k3i1Ei6HHNvC4V5PCfag0xcNGIs1KnsGd9wkzdAN2W4gYnhz1vI/2+cTse1 rcEIQkjCGI1ZhNYO2zsXV+EugY/X80ehl+yncbv1gpOYKNXVDvgIJb+ewiYvTo6Ni+0+ +vpCz9JxaHYtfGKvesy7vB19xA4SlwWCVa8GI46++S8l+mHHF3yzj2lP+lnR95hlIlRm rah+zvUdCrT7c8VKUjKYMeW7ZdF6Fd6dHUGh/RfRcEaNgW6CWGp45fIOAz8cfsqlirjc GGSxc5+PPHbfvLfKixstQ+39EHlMnb6hfprpA0flr1IwtJQrCa3WglT7M3OBeAYAKcm2 2cgA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="niDEj/YY"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i11-20020a17090a64cb00b0024b55721075si1467718pjm.176.2023.05.17.04.05.57; Wed, 17 May 2023 04:06:12 -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; dkim=pass header.i=@intel.com header.s=Intel header.b="niDEj/YY"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231152AbjEQK44 (ORCPT + 99 others); Wed, 17 May 2023 06:56:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39992 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230519AbjEQK4k (ORCPT ); Wed, 17 May 2023 06:56:40 -0400 Received: from mga05.intel.com (mga05.intel.com [192.55.52.43]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B355D2D7B; Wed, 17 May 2023 03:56:11 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1684320971; x=1715856971; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=7umx+GxEypVIOLX+1oZG2a7eY4JTaLow3U/ElJE5Scs=; b=niDEj/YYNempx1xaXbrtHaX6FWsj/jm3KgnNMFSUXS2N79t8B2YHlMIB EVDDUIAM9/8YKDaMGnwnIBoQG+J99VcMD1oHNKL1PX0d7qEODV/bo1+qw ByqRHuaYV+8HpX4GewpSWcpYz0RKI6QBfoRuDd+Fmaw/dF2d1cYHdvzE4 D/szKuaospH7t3GF3QgY2LtZA4ug1PNKNeaoS3RsDZW5nFKd5tb/hgE5f Yla782y6inPwhM1YsgLZxj6kqyyh3z08rBfAzCtrZC9XPHtvYtu/WX9mK b4hZ0a953EZVxMUloRcSorvDbM1NDGKtSPI3HjZ9Y1lh7zQrrVLVmxtLx w==; X-IronPort-AV: E=McAfee;i="6600,9927,10712"; a="438071703" X-IronPort-AV: E=Sophos;i="5.99,281,1677571200"; d="scan'208";a="438071703" Received: from orsmga001.jf.intel.com ([10.7.209.18]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 May 2023 03:53:35 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10712"; a="734651067" X-IronPort-AV: E=Sophos;i="5.99,281,1677571200"; d="scan'208";a="734651067" Received: from lnstern-mobl1.amr.corp.intel.com (HELO ijarvine-MOBL2.ger.corp.intel.com) ([10.251.221.185]) by orsmga001-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 May 2023 03:53:29 -0700 From: =?UTF-8?q?Ilpo=20J=C3=A4rvinen?= To: linux-pci@vger.kernel.org, Bjorn Helgaas , Lorenzo Pieralisi , Rob Herring , =?UTF-8?q?Krzysztof=20Wilczy=C5=84ski?= , Emmanuel Grumbach , "Rafael J . Wysocki" , Heiner Kallweit , Lukas Wunner , Saeed Mahameed , Leon Romanovsky , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Moshe Shemesh , netdev@vger.kernel.org, linux-rdma@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Dean Luick , Andy Shevchenko , =?UTF-8?q?Ilpo=20J=C3=A4rvinen?= , stable@vger.kernel.org Subject: [PATCH v2 6/9] net/mlx5: Use RMW accessors for changing LNKCTL Date: Wed, 17 May 2023 13:52:32 +0300 Message-Id: <20230517105235.29176-7-ilpo.jarvinen@linux.intel.com> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20230517105235.29176-1-ilpo.jarvinen@linux.intel.com> References: <20230517105235.29176-1-ilpo.jarvinen@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_NONE,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED 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 Don't assume that only the driver would be accessing LNKCTL of the upstream bridge. ASPM policy changes can trigger write to LNKCTL outside of driver's control. Use RMW capability accessors which do proper locking to avoid losing concurrent updates to the register value. Fixes: eabe8e5e88f5 ("net/mlx5: Handle sync reset now event") Suggested-by: Lukas Wunner Signed-off-by: Ilpo Järvinen Cc: stable@vger.kernel.org --- drivers/net/ethernet/mellanox/mlx5/core/fw_reset.c | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/drivers/net/ethernet/mellanox/mlx5/core/fw_reset.c b/drivers/net/ethernet/mellanox/mlx5/core/fw_reset.c index 50022e7565f1..f202150a5093 100644 --- a/drivers/net/ethernet/mellanox/mlx5/core/fw_reset.c +++ b/drivers/net/ethernet/mellanox/mlx5/core/fw_reset.c @@ -332,16 +332,11 @@ static int mlx5_pci_link_toggle(struct mlx5_core_dev *dev) pci_cfg_access_lock(sdev); } /* PCI link toggle */ - err = pci_read_config_word(bridge, cap + PCI_EXP_LNKCTL, ®16); - if (err) - return err; - reg16 |= PCI_EXP_LNKCTL_LD; - err = pci_write_config_word(bridge, cap + PCI_EXP_LNKCTL, reg16); + err = pcie_capability_set_word(bridge, PCI_EXP_LNKCTL, PCI_EXP_LNKCTL_LD); if (err) return err; msleep(500); - reg16 &= ~PCI_EXP_LNKCTL_LD; - err = pci_write_config_word(bridge, cap + PCI_EXP_LNKCTL, reg16); + err = pcie_capability_clear_word(bridge, PCI_EXP_LNKCTL, PCI_EXP_LNKCTL_LD); if (err) return err; -- 2.30.2