Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3982478pxb; Tue, 25 Jan 2022 00:37:33 -0800 (PST) X-Google-Smtp-Source: ABdhPJw9xOFLnzWpfKmmyIGu+cGpxgC0MXgu+uBWwJZWQiVCKoRYDq+44pvMVrLjYN2NJQSsGmpb X-Received: by 2002:a17:906:36d8:: with SMTP id b24mr14925655ejc.342.1643099853000; Tue, 25 Jan 2022 00:37:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643099852; cv=none; d=google.com; s=arc-20160816; b=msr90YlhqeLYFXb3QmWWCIjcJuyOBQVmWbqccTFx5cDMOohH01uilm30aQnwf+xUHG 0K5ZAQO8hEEDJeA/vVRY9oT5kLcyVEJBViW+5ytWn0c3QhXzG1L/+gY1Wszopg/Acq/u z/q+tI9SNPZhi2R42VjZoPkbFycN2Av2cHKzda9s0PtwNV4WYejzqhf7mpZfai0wZknT 3CTh+M4xbagUHrdrj8BWvfSvvJR45Hu3E3A10GyPvwR6NWotY8cvLLRgRIeGN8InvMd5 t40qeG2gJEdmk0ia6cXc/H3WeT+ZeQ5jxIsRM+Tcs7Lkl4DTPnXIYt043CRQK7jFz+ym FxZA== 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=LRXP6rLQH7OysN7IlKauQkB6H0BIkLIP80frJ5h3aPg=; b=melvsGm+sDnKHMg/a589nyeLWZrGLy8vMznipOWYVwdPaCbaRyW11d11xdnujNfFh+ aKqgDVYw4bzEmhWcW9BHbh0wq1FCITuRRQK0gSvVuEWoAHlMW5NXyf6KtcW2Mfialoam xob4uchsnBdamIs6JKN/+b9CLSbVZH3K7UFzCsB2EyrWmLboebky4Q4VlgeX6CYV1McK kwzXfCvI8G+sey30F69PUnQM8eQWJfpPzLNaXjQUMKkkYRLayYePG1ak4gqzcEcLLcN3 hthYKJeSAqMj5lddxl798ny92VNUmuG1DJvp/olalGgoLX+pA8xrCBBPGek22xJXeK6Z fbRw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=rY9NJH9q; 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 en5si5964288edb.335.2022.01.25.00.37.08; Tue, 25 Jan 2022 00:37:32 -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=rY9NJH9q; 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 S1314942AbiAYCwG (ORCPT + 99 others); Mon, 24 Jan 2022 21:52:06 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46764 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1353048AbiAXVFl (ORCPT ); Mon, 24 Jan 2022 16:05:41 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 15913C06176C; Mon, 24 Jan 2022 12:06:17 -0800 (PST) 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 ams.source.kernel.org (Postfix) with ESMTPS id 87613B8122F; Mon, 24 Jan 2022 20:06:15 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id AC94CC340E5; Mon, 24 Jan 2022 20:06:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643054774; bh=AaF7euI3kYHd/11AknQCQrpr2iggUpjasga3Y3juYgM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=rY9NJH9q3AgnYvZolDffUSAKiC2S6rhogsgQiBohOQWXdZ0zGAJHg6J2vkZCwPbXY oIbNU73lzT7O6GCuUnQL1rSHNMY6FDgrTk9wkVOfTpgr58/bYFvU5Syvdlil44+UTb sZmnlqvvow5sWdX5DlQMcEDjMJdUQw+irFf0ctm8= 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.10 465/563] PCI: pci-bridge-emul: Fix definitions of reserved bits Date: Mon, 24 Jan 2022 19:43:50 +0100 Message-Id: <20220124184040.541717331@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124184024.407936072@linuxfoundation.org> References: <20220124184024.407936072@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 12998087d9f48b66965b97412069c7826502cd7e upstream. Some bits in PCI_EXP registers are reserved for non-root ports. Driver pci-bridge-emul.c implements PCIe Root Port device therefore it should not allow setting reserved bits of registers. Properly define non-reserved bits for all PCI_EXP registers. Link: https://lore.kernel.org/r/20211124155944.1290-5-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/pci-bridge-emul.c | 36 +++++++++++++++++++++++++----------- 1 file changed, 25 insertions(+), 11 deletions(-) --- a/drivers/pci/pci-bridge-emul.c +++ b/drivers/pci/pci-bridge-emul.c @@ -176,41 +176,55 @@ struct pci_bridge_reg_behavior pcie_cap_ [PCI_CAP_LIST_ID / 4] = { /* * Capability ID, Next Capability Pointer and - * Capabilities register are all read-only. + * bits [14:0] of Capabilities register are all read-only. + * Bit 15 of Capabilities register is reserved. */ - .ro = ~0, + .ro = GENMASK(30, 0), }, [PCI_EXP_DEVCAP / 4] = { - .ro = ~0, + /* + * Bits [31:29] and [17:16] are reserved. + * Bits [27:18] are reserved for non-upstream ports. + * Bits 28 and [14:6] are reserved for non-endpoint devices. + * Other bits are read-only. + */ + .ro = BIT(15) | GENMASK(5, 0), }, [PCI_EXP_DEVCTL / 4] = { - /* Device control register is RW */ - .rw = GENMASK(15, 0), + /* + * Device control register is RW, except bit 15 which is + * reserved for non-endpoints or non-PCIe-to-PCI/X bridges. + */ + .rw = GENMASK(14, 0), /* * Device status register has bits 6 and [3:0] W1C, [5:4] RO, - * the rest is reserved + * the rest is reserved. Also bit 6 is reserved for non-upstream + * ports. */ - .w1c = (BIT(6) | GENMASK(3, 0)) << 16, + .w1c = GENMASK(3, 0) << 16, .ro = GENMASK(5, 4) << 16, }, [PCI_EXP_LNKCAP / 4] = { - /* All bits are RO, except bit 23 which is reserved */ - .ro = lower_32_bits(~BIT(23)), + /* + * All bits are RO, except bit 23 which is reserved and + * bit 18 which is reserved for non-upstream ports. + */ + .ro = lower_32_bits(~(BIT(23) | PCI_EXP_LNKCAP_CLKPM)), }, [PCI_EXP_LNKCTL / 4] = { /* * Link control has bits [15:14], [11:3] and [1:0] RW, the - * rest is reserved. + * rest is reserved. Bit 8 is reserved for non-upstream ports. * * Link status has bits [13:0] RO, and bits [15:14] * W1C. */ - .rw = GENMASK(15, 14) | GENMASK(11, 3) | GENMASK(1, 0), + .rw = GENMASK(15, 14) | GENMASK(11, 9) | GENMASK(7, 3) | GENMASK(1, 0), .ro = GENMASK(13, 0) << 16, .w1c = GENMASK(15, 14) << 16, },