Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp4137700pxb; Mon, 27 Sep 2021 10:09:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwrjcXfwgyt6ihyuVobLBOLax9RF4CjUZx94ewHZwAGj84dIKlqFtNKKW0zbhO9ZTFC/iuN X-Received: by 2002:a63:5c63:: with SMTP id n35mr615096pgm.311.1632762544605; Mon, 27 Sep 2021 10:09:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632762544; cv=none; d=google.com; s=arc-20160816; b=q94ERwK0xJPYviCZFgE15g3MI+HqE7II+zk1c7t1neSxvi7/hnfReGrWL1s95PZX5v oCD26qHpxyPE6NpyAZFiNzUvDN2OJowFCBH1ihCA+D5Z+o6QSHd94jEkezsPBmSG4iJb 5JARNkEizaRIH3E0l6gE/CYJbkUShPmPtm9OonRDdDujHmzyrZ/cT5ehFjVf8Yey646w pK+AKJmiLEwYyOP04KiHyZ/RApT/344wHXlHVyMtlUa1P6lnGaNxcTZ96M4USvx/455L 6/pV5Z9uPPaaWBOOdkGI31yjuos6DvANzpfcG6CNC2m3YRM1hOE0dSwk1Vkukh75Viem ZiyA== 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=1fWwqHYtUPp8TrmnVnuKexERgzffFkPsTSG+sEY6/9M=; b=Lu+Bc4JgoXr0A0DDVXNWYdNXnpCmVltpIqJ1Px2kSd0M2FMVj6lgsaK0sR1490QhYk GnbOeDycvEPh6datLBhqasvLGdczb9+nueSaXP4qDowRnlB0o5WMUhkTrCbC4HveOkoC WJ8EyEkCOiZxPenFbv++Vpf3PVQ78yzUgBJtP0LCQDIHcmMflE6YwCCJbJIYpIpCACZ1 i8mSnL4B3VT+XMnTNNzYDYdOw465MAyKXq8JhuEZvdv4cW0lGIYbe5MynPZ5aQzn+HBr 9PsrrZbDwOaTzGADX4EpK7G0Ty2sSHI7dpry/YuedOPluMufz5RxnO/HtMikDjnmpy+H Z50A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=czFziBkB; 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 a24si12646461pfk.86.2021.09.27.10.08.51; Mon, 27 Sep 2021 10:09:04 -0700 (PDT) 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=czFziBkB; 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 S236522AbhI0RJq (ORCPT + 99 others); Mon, 27 Sep 2021 13:09:46 -0400 Received: from mail.kernel.org ([198.145.29.99]:45506 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235976AbhI0RIV (ORCPT ); Mon, 27 Sep 2021 13:08:21 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 71A37611C2; Mon, 27 Sep 2021 17:06:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1632762398; bh=bWeGOFH1TT9qVUQ2fyKRbHZGMuSfUV+55RAUAoFc/f4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=czFziBkBHkxtX79mCycaGa9dkg0BA/7kZ9acjy+2w7WmZoXj8tiNykBgq2V5FjnsQ zTjTwAExmSaIvYbkew2AsW93Rlrc50h3VuEzT+icsMR2w3qJFbxkBivazdPFNpX3H9 axEPRhKienEaYeajwFkgBAj1BMG5gSHGzZ+te/OE= 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?= , Gregory CLEMENT Subject: [PATCH 5.4 66/68] arm64: dts: marvell: armada-37xx: Extend PCIe MEM space Date: Mon, 27 Sep 2021 19:03:02 +0200 Message-Id: <20210927170222.251271204@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210927170219.901812470@linuxfoundation.org> References: <20210927170219.901812470@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 514ef1e62d6521c2199d192b1c71b79d2aa21d5a upstream. Current PCIe MEM space of size 16 MB is not enough for some combination of PCIe cards (e.g. NVMe disk together with ath11k wifi card). ARM Trusted Firmware for Armada 3700 platform already assigns 128 MB for PCIe window, so extend PCIe MEM space to the end of 128 MB PCIe window which allows to allocate more PCIe BARs for more PCIe cards. Without this change some combination of PCIe cards cannot be used and kernel show error messages in dmesg during initialization: pci 0000:00:00.0: BAR 8: no space for [mem size 0x01800000] pci 0000:00:00.0: BAR 8: failed to assign [mem size 0x01800000] pci 0000:00:00.0: BAR 6: assigned [mem 0xe8000000-0xe80007ff pref] pci 0000:01:00.0: BAR 8: no space for [mem size 0x01800000] pci 0000:01:00.0: BAR 8: failed to assign [mem size 0x01800000] pci 0000:02:03.0: BAR 8: no space for [mem size 0x01000000] pci 0000:02:03.0: BAR 8: failed to assign [mem size 0x01000000] pci 0000:02:07.0: BAR 8: no space for [mem size 0x00100000] pci 0000:02:07.0: BAR 8: failed to assign [mem size 0x00100000] pci 0000:03:00.0: BAR 0: no space for [mem size 0x01000000 64bit] pci 0000:03:00.0: BAR 0: failed to assign [mem size 0x01000000 64bit] Due to bugs in U-Boot port for Turris Mox, the second range in Turris Mox kernel DTS file for PCIe must start at 16 MB offset. Otherwise U-Boot crashes during loading of kernel DTB file. This bug is present only in U-Boot code for Turris Mox and therefore other Armada 3700 devices are not affected by this bug. Bug is fixed in U-Boot version 2021.07. To not break booting new kernels on existing versions of U-Boot on Turris Mox, use first 16 MB range for IO and second range with rest of PCIe window for MEM. Signed-off-by: Pali Rohár Fixes: 76f6386b25cc ("arm64: dts: marvell: Add Aardvark PCIe support for Armada 3700") Signed-off-by: Gregory CLEMENT Signed-off-by: Greg Kroah-Hartman --- arch/arm64/boot/dts/marvell/armada-3720-turris-mox.dts | 17 +++++++++++++++++ arch/arm64/boot/dts/marvell/armada-37xx.dtsi | 11 +++++++++-- 2 files changed, 26 insertions(+), 2 deletions(-) --- a/arch/arm64/boot/dts/marvell/armada-3720-turris-mox.dts +++ b/arch/arm64/boot/dts/marvell/armada-3720-turris-mox.dts @@ -138,6 +138,23 @@ max-link-speed = <2>; reset-gpios = <&gpiosb 3 GPIO_ACTIVE_LOW>; phys = <&comphy1 0>; + /* + * U-Boot port for Turris Mox has a bug which always expects that "ranges" DT property + * contains exactly 2 ranges with 3 (child) address cells, 2 (parent) address cells and + * 2 size cells and also expects that the second range starts at 16 MB offset. If these + * conditions are not met then U-Boot crashes during loading kernel DTB file. PCIe address + * space is 128 MB long, so the best split between MEM and IO is to use fixed 16 MB window + * for IO and the rest 112 MB (64+32+16) for MEM, despite that maximal IO size is just 64 kB. + * This bug is not present in U-Boot ports for other Armada 3700 devices and is fixed in + * U-Boot version 2021.07. See relevant U-Boot commits (the last one contains fix): + * https://source.denx.de/u-boot/u-boot/-/commit/cb2ddb291ee6fcbddd6d8f4ff49089dfe580f5d7 + * https://source.denx.de/u-boot/u-boot/-/commit/c64ac3b3185aeb3846297ad7391fc6df8ecd73bf + * https://source.denx.de/u-boot/u-boot/-/commit/4a82fca8e330157081fc132a591ebd99ba02ee33 + */ + #address-cells = <3>; + #size-cells = <2>; + ranges = <0x81000000 0 0xe8000000 0 0xe8000000 0 0x01000000 /* Port 0 IO */ + 0x82000000 0 0xe9000000 0 0xe9000000 0 0x07000000>; /* Port 0 MEM */ /* enabled by U-Boot if PCIe module is present */ status = "disabled"; --- a/arch/arm64/boot/dts/marvell/armada-37xx.dtsi +++ b/arch/arm64/boot/dts/marvell/armada-37xx.dtsi @@ -487,8 +487,15 @@ #interrupt-cells = <1>; msi-parent = <&pcie0>; msi-controller; - ranges = <0x82000000 0 0xe8000000 0 0xe8000000 0 0x1000000 /* Port 0 MEM */ - 0x81000000 0 0xe9000000 0 0xe9000000 0 0x10000>; /* Port 0 IO*/ + /* + * The 128 MiB address range [0xe8000000-0xf0000000] is + * dedicated for PCIe and can be assigned to 8 windows + * with size a power of two. Use one 64 KiB window for + * IO at the end and the remaining seven windows + * (totaling 127 MiB) for MEM. + */ + ranges = <0x82000000 0 0xe8000000 0 0xe8000000 0 0x07f00000 /* Port 0 MEM */ + 0x81000000 0 0xefff0000 0 0xefff0000 0 0x00010000>; /* Port 0 IO */ interrupt-map-mask = <0 0 0 7>; interrupt-map = <0 0 0 1 &pcie_intc 0>, <0 0 0 2 &pcie_intc 1>,