[openwrt/openwrt] mpc85xx: Drop pci aliases to avoid domain changes

LEDE Commits lede-commits at lists.infradead.org
Wed Feb 8 07:45:08 PST 2023


ansuel pushed a commit to openwrt/openwrt.git, branch openwrt-21.02:
https://git.openwrt.org/0d4a0250df17a9f7b0fff720fa3224b45d5b0841

commit 0d4a0250df17a9f7b0fff720fa3224b45d5b0841
Author: Martin Kennedy <hurricos at gmail.com>
AuthorDate: Mon Aug 29 20:47:24 2022 -0400

    mpc85xx: Drop pci aliases to avoid domain changes
    
    As of upstream Linux commit 0fe1e96fef0a ("powerpc/pci: Prefer PCI
    domain assignment via DT 'linux,pci-domain' and alias"), the PCIe
    domain address is no longer numbered by the lowest 16 bits of the PCI
    register address after a fallthrough. Instead of the fallthrough, the
    enumeration process accepts the alias ID (as determined by
    `of_alias_scan()`). This causes e.g.:
    
    9000:00:00.0 PCI bridge: Freescale Semiconductor Inc P1020E (rev 11)
    9000:01:00.0 Network controller: Qualcomm Atheros AR958x 802.11abgn ...
    
    to become
    
    0000:00:00.0 PCI bridge: Freescale Semiconductor Inc P1020E (rev 11)
    0000:01:00.0 Network controller: Qualcomm Atheros AR958x 802.11abgn ...
    
    ... which then causes the sysfs path of the netdev to change,
    invalidating the `wifi_device.path`s enumerated in
    `/etc/config/wireless`.
    
    One other solution might be to migrate the uci configuration, as was
    done for mvebu in commit 0bd5aa89fcf2 ("mvebu: Migrate uci config to
    new PCIe path"). However, there are concerns that the sysfs path will
    change once again once some upstream patches[^2][^3] are merged and
    backported (and `CONFIG_PPC_PCI_BUS_NUM_DOMAIN_DEPENDENT` is enabled).
    
    Instead, remove the aliases and allow the fallthrough to continue for
    now. We will provide a migration in a later release.
    
    This was first reported as a Github issue[^1].
    
    [^1]: https://github.com/openwrt/openwrt/issues/10530
    [^2]: https://lore.kernel.org/linuxppc-dev/20220706104308.5390-1-pali@kernel.org/t/#u
    [^3]: https://lore.kernel.org/linuxppc-dev/20220706101043.4867-1-pali@kernel.org/
    
    Fixes: #10530
    Tested-by: Martin Kennedy <hurricos at gmail.com>
    [Tested on the Aerohive HiveAP 330 and Extreme Networks WS-AP3825i]
    Signed-off-by: Martin Kennedy <hurricos at gmail.com>
    (cherry picked from commit 7f4b4c29f3489697dca7495216460d0ed5023e02)
    Signed-off-by: Fabian Bläse <fabian at blaese.de>
---
 .../mpc85xx/files/arch/powerpc/boot/dts/hiveap-330.dts     | 13 +++++++++++++
 target/linux/mpc85xx/files/arch/powerpc/boot/dts/panda.dts | 14 ++++++++++++++
 .../mpc85xx/files/arch/powerpc/boot/dts/red-15w-rev1.dts   | 14 ++++++++++++++
 .../mpc85xx/files/arch/powerpc/boot/dts/tl-wdr4900-v1.dts  | 13 +++++++++++++
 .../mpc85xx/files/arch/powerpc/boot/dts/ws-ap3710i.dts     | 13 +++++++++++++
 5 files changed, 67 insertions(+)

diff --git a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/hiveap-330.dts b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/hiveap-330.dts
index 3ca132d0c0..5d08cc7e8d 100644
--- a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/hiveap-330.dts
+++ b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/hiveap-330.dts
@@ -234,3 +234,16 @@
 	};
 };
 /include/ "fsl/p1020si-post.dtsi"
+
+/*
+ * For the OpenWrt 22.03 release, since Linux 5.10.138 now uses
+ * aliases to determine PCI domain numbers, drop aliases so as not to
+ * change the sysfs path of our wireless netdevs.
+ */
+
+/ {
+	aliases {
+		/delete-property/ pci0;
+		/delete-property/ pci1;
+	};
+};
diff --git a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/panda.dts b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/panda.dts
index f0fafa1b57..7e988f128c 100644
--- a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/panda.dts
+++ b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/panda.dts
@@ -262,3 +262,17 @@
 	};
 };
 /include/ "fsl/p1020si-post.dtsi"
+
+/*
+ * For the OpenWrt 22.03 release, since Linux 5.10.138 now uses
+ * aliases to determine PCI domain numbers, drop aliases so as not to
+ * change the sysfs path of our wireless netdevs.
+ */
+
+/ {
+	aliases {
+		/delete-property/ pci0;
+		/delete-property/ pci1;
+	};
+};
+
diff --git a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/red-15w-rev1.dts b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/red-15w-rev1.dts
index 40b8014a53..3b78a21920 100644
--- a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/red-15w-rev1.dts
+++ b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/red-15w-rev1.dts
@@ -212,3 +212,17 @@
 };
 
 /include/ "fsl/p1010si-post.dtsi"
+
+/*
+ * For the OpenWrt 22.03 release, since Linux 5.10.138 now uses
+ * aliases to determine PCI domain numbers, drop aliases so as not to
+ * change the sysfs path of our wireless netdevs.
+ */
+
+/ {
+	aliases {
+		/delete-property/ pci0;
+		/delete-property/ pci1;
+	};
+};
+
diff --git a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/tl-wdr4900-v1.dts b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/tl-wdr4900-v1.dts
index 29b49a9357..d79a034e9d 100644
--- a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/tl-wdr4900-v1.dts
+++ b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/tl-wdr4900-v1.dts
@@ -290,3 +290,16 @@
 		/delete-node/ crypto at 30000; /* Pulled in by p1010si-post */
 	};
 };
+
+/*
+ * For the OpenWrt 22.03 release, since Linux 5.10.138 now uses
+ * aliases to determine PCI domain numbers, drop aliases so as not to
+ * change the sysfs path of our wireless netdevs.
+ */
+
+/ {
+	aliases {
+		/delete-property/ pci0;
+		/delete-property/ pci1;
+	};
+};
diff --git a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/ws-ap3710i.dts b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/ws-ap3710i.dts
index ebaac417eb..5b464869c4 100644
--- a/target/linux/mpc85xx/files/arch/powerpc/boot/dts/ws-ap3710i.dts
+++ b/target/linux/mpc85xx/files/arch/powerpc/boot/dts/ws-ap3710i.dts
@@ -170,3 +170,16 @@
 
 };
 /include/ "fsl/p1020si-post.dtsi"
+
+/*
+ * For the OpenWrt 22.03 release, since Linux 5.10.138 now uses
+ * aliases to determine PCI domain numbers, drop aliases so as not to
+ * change the sysfs path of our wireless netdevs.
+ */
+
+/ {
+	aliases {
+		/delete-property/ pci0;
+		/delete-property/ pci1;
+	};
+};




More information about the lede-commits mailing list