Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp3259804rwb; Mon, 15 Aug 2022 22:33:49 -0700 (PDT) X-Google-Smtp-Source: AA6agR5/8ZkZq4xnWhAwX5OIPLPwfMn1hQdsokXjZz3JQeaZjmmR8dcya4JQXfx3lnCpEwQ5TlQj X-Received: by 2002:aa7:8c5a:0:b0:532:8f18:cf7e with SMTP id e26-20020aa78c5a000000b005328f18cf7emr15978650pfd.7.1660628029009; Mon, 15 Aug 2022 22:33:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660628029; cv=none; d=google.com; s=arc-20160816; b=eOd235+uMd9xgwaH4FBFJyLs3qu4NS85H7/nOF+RKxj5HOR/xqQZD30o7VHnIPiLiC 6vVJYKvbAPgEVswr0iFuQ4Y3/8+l1MZW8xgVBJ+4IT+6aVBNYMjtLSoY0JabtU4uCPqb RqxODLEEm2yIINmET1aajF4flFoWH6/1ZGwbbnK+5T3IZBbJjN7PJ9uZwpG8/2M4Wk53 zbVjM5GjSAUorOpedQBNB/8OboEh/WkL9+iGmF4k4KzcQgHxmDiGDRN5XLiyCdtd0n27 qzRa9AOodI07TQPH95G7kaZqmkjJHlMzotTp8CjH0P0aMR5szirJVBauftHIx4TI/huW RzQw== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=nvfIsebtIhFKpcTQ2/rsvmhyzpxKc2onlCWGVU9JXH4=; b=Im3Vm9HftHE1fDAq9x0pU9iTugfeeEWuBPneoIbQyE6nv4npbYxrdn1J3kwkfm1faP vEfdEBmfaTotqwMoBPmVmRZlwk9XnpnsCAsHmt5Ugc6Zu5lG6LmiFWblG9ojvX22kBxg jXiWvIislGh8NdANVbsHCQNDrVRj0FeYLVRAmK5EyZa6BDokvLO0N/+R0oCcJ6FDWxM/ Fc7ANEu3veSkosctQPXnqKPQBggB9uocQxhziTbKbYOXP8qiO32H+w1cG5fhMniUxoB1 xjKGVkTHD6/6Vf3V9nadDLt6Wd6jZWJ8lHsp+4TSKqu1KfDGcQ9kQl3JOfDh0thi7NKl 64FA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=QqQiaaGz; 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=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s38-20020a056a0017a600b0052b1e2f86ccsi12865072pfg.321.2022.08.15.22.33.38; Mon, 15 Aug 2022 22:33:48 -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=@linuxfoundation.org header.s=korg header.b=QqQiaaGz; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232145AbiHPEpL (ORCPT + 99 others); Tue, 16 Aug 2022 00:45:11 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43148 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232677AbiHPElc (ORCPT ); Tue, 16 Aug 2022 00:41:32 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C95235580; Mon, 15 Aug 2022 13:32:39 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 4F63261135; Mon, 15 Aug 2022 20:32:39 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 1AB0CC433C1; Mon, 15 Aug 2022 20:32:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660595558; bh=TSsNCgelctt+58xqKftZUVvkb58cH3/mqhqsM63/6wk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=QqQiaaGzA0hvEz8sAkGtY9+GTqhQiKsafxx/o7tFyH+uiggUOMuaMg/EdvuEiehNx 2w5ncM7282X9hUe+J3JHFnt+e//Zy1G6Y0gZd1Ouzc7+6eMw9wynHGtQZdE890VQ+j BduSPWAs9RNZjZZDFKTB80UjhXvt6sjGbT4xyglc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Stefan Roese , Bjorn Helgaas , =?UTF-8?q?Pali=20Roh=C3=A1r?= , "Rafael J. Wysocki" , Bharat Kumar Gogada , Michal Simek , Yao Hongbo , Naveen Naidu , Sasha Levin Subject: [PATCH 5.19 0803/1157] PCI/portdrv: Dont disable AER reporting in get_port_device_capability() Date: Mon, 15 Aug 2022 20:02:39 +0200 Message-Id: <20220815180511.616572327@linuxfoundation.org> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220815180439.416659447@linuxfoundation.org> References: <20220815180439.416659447@linuxfoundation.org> User-Agent: quilt/0.67 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 From: Stefan Roese [ Upstream commit 8795e182b02dc87e343c79e73af6b8b7f9c5e635 ] AER reporting is currently disabled in the DevCtl registers of all non Root Port PCIe devices on systems using pcie_ports_native || host->native_aer, disabling AER completely in such systems. This is because 2bd50dd800b5 ("PCI: PCIe: Disable PCIe port services during port initialization"), added a call to pci_disable_pcie_error_reporting() *after* the AER setup was completed for the PCIe device tree. Here a longer analysis about the current status of AER enabling / disabling upon bootup provided by Bjorn: pcie_portdrv_probe pcie_port_device_register get_port_device_capability pci_disable_pcie_error_reporting clear CERE NFERE FERE URRE # <-- disable for RP USP DSP pcie_device_init device_register # new AER service device aer_probe aer_enable_rootport # RP only set_downstream_devices_error_reporting set_device_error_reporting # self (RP) if (RP || USP || DSP) pci_enable_pcie_error_reporting set CERE NFERE FERE URRE # <-- enable for RP pci_walk_bus set_device_error_reporting if (RP || USP || DSP) pci_enable_pcie_error_reporting set CERE NFERE FERE URRE # <-- enable for USP DSP In a typical Root Port -> Endpoint hierarchy, the above: - Disables Error Reporting for the Root Port, - Enables Error Reporting for the Root Port, - Does NOT enable Error Reporting for the Endpoint because it is not a Root Port or Switch Port. In a deeper Root Port -> Upstream Switch Port -> Downstream Switch Port -> Endpoint hierarchy: - Disables Error Reporting for the Root Port, - Enables Error Reporting for the Root Port, - Enables Error Reporting for both Switch Ports, - Does NOT enable Error Reporting for the Endpoint because it is not a Root Port or Switch Port, - Disables Error Reporting for the Switch Ports when pcie_portdrv_probe() claims them. AER does not re-enable it because these are not Root Ports. Remove this call to pci_disable_pcie_error_reporting() from get_port_device_capability(), leaving the already enabled AER configuration intact. With this change, AER is enabled in the Root Port and the PCIe switch upstream and downstream ports. Only the PCIe Endpoints don't have AER enabled yet. A follow-up patch will take care of this Endpoint enabling. Fixes: 2bd50dd800b5 ("PCI: PCIe: Disable PCIe port services during port initialization") Link: https://lore.kernel.org/r/20220125071820.2247260-3-sr@denx.de Signed-off-by: Stefan Roese Signed-off-by: Bjorn Helgaas Reviewed-by: Pali Rohár Cc: Rafael J. Wysocki Cc: Bharat Kumar Gogada Cc: Michal Simek Cc: Yao Hongbo Cc: Naveen Naidu Signed-off-by: Sasha Levin --- drivers/pci/pcie/portdrv_core.c | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/drivers/pci/pcie/portdrv_core.c b/drivers/pci/pcie/portdrv_core.c index 604feeb84ee4..1ac7fec47d6f 100644 --- a/drivers/pci/pcie/portdrv_core.c +++ b/drivers/pci/pcie/portdrv_core.c @@ -222,15 +222,8 @@ static int get_port_device_capability(struct pci_dev *dev) #ifdef CONFIG_PCIEAER if (dev->aer_cap && pci_aer_available() && - (pcie_ports_native || host->native_aer)) { + (pcie_ports_native || host->native_aer)) services |= PCIE_PORT_SERVICE_AER; - - /* - * Disable AER on this port in case it's been enabled by the - * BIOS (the AER service driver will enable it when necessary). - */ - pci_disable_pcie_error_reporting(dev); - } #endif /* Root Ports and Root Complex Event Collectors may generate PMEs */ -- 2.35.1