Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3615393pxb; Mon, 24 Jan 2022 13:34:37 -0800 (PST) X-Google-Smtp-Source: ABdhPJxSPh1uw7jn0Rm27ak1PwXaqnTA+YU0rbzj8YxHq8bhenrUupYwK9uY8q5RJ9DCR6jjvvZE X-Received: by 2002:a17:90b:380f:: with SMTP id mq15mr297408pjb.16.1643060077061; Mon, 24 Jan 2022 13:34:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643060077; cv=none; d=google.com; s=arc-20160816; b=LEawTpxJnmz1bR4I+2kiwSIA2R5y6itbkcEzuQ3pe9CK4oTquRn6sd6cEh5Kyrxtk8 RPmRyhez5sYftPgEt6BeWPAEsQjkaMUmvQRV45MryKlwH+AfEZ1GBORQDgfsJM3csDT4 cE44NPSDuAJ1juHTa49U4AaUZ/XPkKiFcFAZHAjbAEw44uAhda5qYiu6N+jV6PyNUoRG EOfOcdhibGuCGr2VO3Nl9TmqolfFqukIxuWa8hlW0PCDdQeoHpEaatfTD3XBophwm6Ib nMtnH7C30H6RxGQlLGfraX6/+9Y4XnWL4ISR+yRgsEya9oJJF7nTsDjzz/TzrKt3XZ+4 IlUQ== 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=GyMOxf5k51MpFBxEss7qSFilS3+MyHOZOhJ8bULieDY=; b=ocjmNbCYgGEbyY8uDDVoDUKodvJbDjlW5z1+AdE16uSVJCZbG7hUs93A+dP5IoubEK C41sES60ukNLB8UxUCHwJegbWL6lov0ijYUpiS4hbQ56GITzsgbbNLoNZ2kwGHcQStcd Me+iITyqneuUZi056bvuBU0Kc4jiSFpgh7BRX1xQbRpgqfF778ePJdYyCfl23v57pQyn dlnpV7XuzcY6pZEtZxkJJKK0sczubgDV/DU9BE0xGmXi2oYpWZSAv6QEAGSMtdui2Gk7 J2Kwp7xZXd/Uxq67WTpU7tKm7Pgwe8pyXWmcDuG4MKqqXPIzf3UwAOORdjqXJfJl/zR0 Jp5Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=MpkrIAft; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r11si12486421plo.45.2022.01.24.13.34.25; Mon, 24 Jan 2022 13:34:37 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=MpkrIAft; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1448108AbiAXVMB (ORCPT + 99 others); Mon, 24 Jan 2022 16:12:01 -0500 Received: from dfw.source.kernel.org ([139.178.84.217]:40588 "EHLO dfw.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1390379AbiAXUpQ (ORCPT ); Mon, 24 Jan 2022 15:45:16 -0500 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 1D07A6090B; Mon, 24 Jan 2022 20:45:15 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id E6BF1C340E5; Mon, 24 Jan 2022 20:45:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643057114; bh=VjVNFNZYLdWE1D2e2Jn90kZ2pJELTAUL5P54vETBVJg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=MpkrIAfteKgvTmwOZnLZPZaQssV8V/IzqbhqA3dFmJWdQvKU2xFwjkbdMY5r/FaUd Tw40mQc6cnakpvpnZ9gCc18JujUIDWvHUvSNW2hOoZppewnSffICJoi689mtkAN729 2x79vUDzD5gfF+7KMOV9iUaAsQwjkDaJgRjnnaO4= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?Pali=20Roh=C3=A1r?= , Lorenzo Pieralisi Subject: [PATCH 5.15 706/846] PCI: pci-bridge-emul: Correctly set PCIe capabilities Date: Mon, 24 Jan 2022 19:43:43 +0100 Message-Id: <20220124184125.401171629@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124184100.867127425@linuxfoundation.org> References: <20220124184100.867127425@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Pali Rohár commit 1f1050c5e1fefb34ac90a506b43e9da803b5f8f7 upstream. Older mvebu hardware provides PCIe Capability structure only in version 1. New mvebu and aardvark hardware provides it in version 2. So do not force version to 2 in pci_bridge_emul_init() and rather allow drivers to set correct version. Drivers need to set version in pcie_conf.cap field without overwriting PCI_CAP_LIST_ID register. Both drivers (mvebu and aardvark) do not provide slot support yet, so do not set PCI_EXP_FLAGS_SLOT flag. Link: https://lore.kernel.org/r/20211124155944.1290-6-pali@kernel.org Fixes: 23a5fba4d941 ("PCI: Introduce PCI bridge emulated config space common logic") Signed-off-by: Pali Rohár Signed-off-by: Lorenzo Pieralisi Cc: stable@vger.kernel.org Signed-off-by: Greg Kroah-Hartman --- drivers/pci/controller/pci-aardvark.c | 4 +++- drivers/pci/controller/pci-mvebu.c | 8 ++++++++ drivers/pci/pci-bridge-emul.c | 5 +---- 3 files changed, 12 insertions(+), 5 deletions(-) --- a/drivers/pci/controller/pci-aardvark.c +++ b/drivers/pci/controller/pci-aardvark.c @@ -872,7 +872,6 @@ advk_pci_bridge_emul_pcie_conf_read(stru return PCI_BRIDGE_EMUL_HANDLED; } - case PCI_CAP_LIST_ID: case PCI_EXP_DEVCAP: case PCI_EXP_DEVCTL: *value = advk_readl(pcie, PCIE_CORE_PCIEXP_CAP + reg); @@ -953,6 +952,9 @@ static int advk_sw_pci_bridge_init(struc /* Support interrupt A for MSI feature */ bridge->conf.intpin = PCIE_CORE_INT_A_ASSERT_ENABLE; + /* Aardvark HW provides PCIe Capability structure in version 2 */ + bridge->pcie_conf.cap = cpu_to_le16(2); + /* Indicates supports for Completion Retry Status */ bridge->pcie_conf.rootcap = cpu_to_le16(PCI_EXP_RTCAP_CRSVIS); --- a/drivers/pci/controller/pci-mvebu.c +++ b/drivers/pci/controller/pci-mvebu.c @@ -573,6 +573,8 @@ static struct pci_bridge_emul_ops mvebu_ static void mvebu_pci_bridge_emul_init(struct mvebu_pcie_port *port) { struct pci_bridge_emul *bridge = &port->bridge; + u32 pcie_cap = mvebu_readl(port, PCIE_CAP_PCIEXP); + u8 pcie_cap_ver = ((pcie_cap >> 16) & PCI_EXP_FLAGS_VERS); bridge->conf.vendor = PCI_VENDOR_ID_MARVELL; bridge->conf.device = mvebu_readl(port, PCIE_DEV_ID_OFF) >> 16; @@ -585,6 +587,12 @@ static void mvebu_pci_bridge_emul_init(s bridge->conf.iolimit = PCI_IO_RANGE_TYPE_32; } + /* + * Older mvebu hardware provides PCIe Capability structure only in + * version 1. New hardware provides it in version 2. + */ + bridge->pcie_conf.cap = cpu_to_le16(pcie_cap_ver); + bridge->has_pcie = true; bridge->data = port; bridge->ops = &mvebu_pci_bridge_emul_ops; --- a/drivers/pci/pci-bridge-emul.c +++ b/drivers/pci/pci-bridge-emul.c @@ -297,10 +297,7 @@ int pci_bridge_emul_init(struct pci_brid if (bridge->has_pcie) { bridge->conf.capabilities_pointer = PCI_CAP_PCIE_START; bridge->pcie_conf.cap_id = PCI_CAP_ID_EXP; - /* Set PCIe v2, root port, slot support */ - bridge->pcie_conf.cap = - cpu_to_le16(PCI_EXP_TYPE_ROOT_PORT << 4 | 2 | - PCI_EXP_FLAGS_SLOT); + bridge->pcie_conf.cap |= cpu_to_le16(PCI_EXP_TYPE_ROOT_PORT << 4); bridge->pcie_cap_regs_behavior = kmemdup(pcie_cap_regs_behavior, sizeof(pcie_cap_regs_behavior),