aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJan Hoffmann <jan@3e8.eu>2023-01-28 00:01:18 +0100
committerHauke Mehrtens <hauke@hauke-m.de>2023-02-03 13:47:04 +0100
commitc46584ab302f0dd9b472aef77c2af163f9719379 (patch)
tree49878c5665b67675ff60e08a78eff3a3720d8d9b
parentb91d7d9d78ea12097de4c518c8cd2215ff286f7a (diff)
downloadupstream-c46584ab302f0dd9b472aef77c2af163f9719379.tar.gz
upstream-c46584ab302f0dd9b472aef77c2af163f9719379.tar.bz2
upstream-c46584ab302f0dd9b472aef77c2af163f9719379.zip
ramips: use on-flash partition table for Sercomm BZV/CHJ
These devices have a partition table stored in flash, which compensates for any pre-existing bad blocks by enlarging the respective partition. This means that the current static partition table is only correct for devices without any bad blocks. Typical results of this mismatch are degraded wireless performance and wrong MAC addresses, when the factory partition is shifted due to a bad block somewhere before it. If there is a bad block already before the ubi partition, then OpenWrt may not run at all because the kernel can't find the rootfs. Use the on-flash partition table to fix these issues. Replace the two reserved partitions by the full partition list, as the driver does not allow merging them. Signed-off-by: Jan Hoffmann <jan@3e8.eu>
-rw-r--r--target/linux/ramips/dts/mt7621_netgear_sercomm_bzv.dtsi169
-rw-r--r--target/linux/ramips/dts/mt7621_netgear_sercomm_chj.dtsi169
2 files changed, 330 insertions, 8 deletions
diff --git a/target/linux/ramips/dts/mt7621_netgear_sercomm_bzv.dtsi b/target/linux/ramips/dts/mt7621_netgear_sercomm_bzv.dtsi
index 9fa4af8fd6..ab96b8fdd1 100644
--- a/target/linux/ramips/dts/mt7621_netgear_sercomm_bzv.dtsi
+++ b/target/linux/ramips/dts/mt7621_netgear_sercomm_bzv.dtsi
@@ -223,47 +223,208 @@
status = "okay";
partitions {
- compatible = "fixed-partitions";
+ compatible = "sercomm,sc-partitions", "fixed-partitions";
#address-cells = <1>;
#size-cells = <1>;
partition@0 {
label = "u-boot";
reg = <0x0 0x100000>;
+ sercomm,scpart-id = <0>;
read-only;
};
partition@100000 {
label = "SC PART_MAP";
reg = <0x100000 0x100000>;
+ sercomm,scpart-id = <1>;
read-only;
};
partition@200000 {
label = "kernel";
reg = <0x200000 0x400000>;
+ sercomm,scpart-id = <2>;
};
partition@600000 {
label = "ubi";
reg = <0x600000 0x2800000>;
+ sercomm,scpart-id = <3>;
};
partition@2e00000 {
- label = "reserved0";
- reg = <0x2e00000 0x1800000>;
+ label = "English UI";
+ reg = <0x2e00000 0x200000>;
+ sercomm,scpart-id = <4>;
+ read-only;
+ };
+
+ partition@3000000 {
+ label = "ML1";
+ reg = <0x3000000 0x200000>;
+ sercomm,scpart-id = <5>;
+ read-only;
+ };
+
+ partition@3200000 {
+ label = "ML2";
+ reg = <0x3200000 0x200000>;
+ sercomm,scpart-id = <6>;
+ read-only;
+ };
+
+ partition@3400000 {
+ label = "ML3";
+ reg = <0x3400000 0x200000>;
+ sercomm,scpart-id = <7>;
+ read-only;
+ };
+
+ partition@3600000 {
+ label = "ML4";
+ reg = <0x3600000 0x200000>;
+ sercomm,scpart-id = <8>;
+ read-only;
+ };
+
+ partition@3800000 {
+ label = "ML5";
+ reg = <0x3800000 0x200000>;
+ sercomm,scpart-id = <9>;
+ read-only;
+ };
+
+ partition@3a00000 {
+ label = "ML6";
+ reg = <0x3a00000 0x200000>;
+ sercomm,scpart-id = <10>;
+ read-only;
+ };
+
+ partition@3c00000 {
+ label = "ML7";
+ reg = <0x3c00000 0x200000>;
+ sercomm,scpart-id = <11>;
+ read-only;
+ };
+
+ partition@3e00000 {
+ label = "ML8";
+ reg = <0x3e00000 0x200000>;
+ sercomm,scpart-id = <12>;
+ read-only;
+ };
+
+ partition@4000000 {
+ label = "ML9";
+ reg = <0x4000000 0x200000>;
+ sercomm,scpart-id = <13>;
+ read-only;
+ };
+
+ partition@4200000 {
+ label = "ML10";
+ reg = <0x4200000 0x200000>;
+ sercomm,scpart-id = <14>;
+ read-only;
+ };
+
+ partition@4400000 {
+ label = "ML11";
+ reg = <0x4400000 0x200000>;
+ sercomm,scpart-id = <15>;
read-only;
};
factory: partition@4600000 {
label = "factory";
reg = <0x4600000 0x200000>;
+ sercomm,scpart-id = <16>;
read-only;
};
partition@4800000 {
+ label = "SC Private Data";
+ reg = <0x4800000 0x200000>;
+ sercomm,scpart-id = <17>;
+ read-only;
+ };
+
+ partition@4a00000 {
+ label = "POT";
+ reg = <0x4a00000 0x200000>;
+ sercomm,scpart-id = <18>;
+ read-only;
+ };
+
+ partition@4c00000 {
+ label = "Traffic Meter";
+ reg = <0x4c00000 0x200000>;
+ sercomm,scpart-id = <19>;
+ read-only;
+ };
+
+ partition@4e00000 {
+ label = "SC PID";
+ reg = <0x4e00000 0x200000>;
+ sercomm,scpart-id = <20>;
+ read-only;
+ };
+
+ partition@5000000 {
+ label = "SC Nvram";
+ reg = <0x5000000 0x200000>;
+ sercomm,scpart-id = <21>;
+ read-only;
+ };
+
+ partition@5200000 {
+ label = "Ralink Nvram";
+ reg = <0x5200000 0x200000>;
+ sercomm,scpart-id = <22>;
+ read-only;
+ };
+
+ partition@5400000 {
+ label = "reserved0";
+ reg = <0x5400000 0x200000>;
+ sercomm,scpart-id = <23>;
+ read-only;
+ };
+
+ partition@5600000 {
label = "reserved1";
- reg = <0x4800000 0x3800000>;
+ reg = <0x5600000 0x200000>;
+ sercomm,scpart-id = <24>;
+ read-only;
+ };
+
+ partition@5800000 {
+ label = "reserved2";
+ reg = <0x5800000 0x200000>;
+ sercomm,scpart-id = <25>;
+ read-only;
+ };
+
+ partition@5a00000 {
+ label = "reserved3";
+ reg = <0x5a00000 0x200000>;
+ sercomm,scpart-id = <26>;
+ read-only;
+ };
+
+ partition@5c00000 {
+ label = "reserved4";
+ reg = <0x5c00000 0x200000>;
+ sercomm,scpart-id = <27>;
+ read-only;
+ };
+
+ partition@5e00000 {
+ label = "reserved5";
+ reg = <0x5e00000 0x2180000>;
+ sercomm,scpart-id = <28>;
read-only;
};
};
diff --git a/target/linux/ramips/dts/mt7621_netgear_sercomm_chj.dtsi b/target/linux/ramips/dts/mt7621_netgear_sercomm_chj.dtsi
index eaf12a891e..cd9582e541 100644
--- a/target/linux/ramips/dts/mt7621_netgear_sercomm_chj.dtsi
+++ b/target/linux/ramips/dts/mt7621_netgear_sercomm_chj.dtsi
@@ -151,47 +151,208 @@
status = "okay";
partitions {
- compatible = "fixed-partitions";
+ compatible = "sercomm,sc-partitions", "fixed-partitions";
#address-cells = <1>;
#size-cells = <1>;
partition@0 {
label = "u-boot";
reg = <0x0 0x100000>;
+ sercomm,scpart-id = <0>;
read-only;
};
partition@100000 {
label = "SC PART_MAP";
reg = <0x100000 0x100000>;
+ sercomm,scpart-id = <1>;
read-only;
};
partition@200000 {
label = "kernel";
reg = <0x200000 0x400000>;
+ sercomm,scpart-id = <2>;
};
partition@600000 {
label = "ubi";
reg = <0x600000 0x2800000>;
+ sercomm,scpart-id = <3>;
};
partition@2e00000 {
- label = "reserved0";
- reg = <0x2e00000 0x1800000>;
+ label = "English UI";
+ reg = <0x2e00000 0x200000>;
+ sercomm,scpart-id = <4>;
+ read-only;
+ };
+
+ partition@3000000 {
+ label = "ML1";
+ reg = <0x3000000 0x200000>;
+ sercomm,scpart-id = <5>;
+ read-only;
+ };
+
+ partition@3200000 {
+ label = "ML2";
+ reg = <0x3200000 0x200000>;
+ sercomm,scpart-id = <6>;
+ read-only;
+ };
+
+ partition@3400000 {
+ label = "ML3";
+ reg = <0x3400000 0x200000>;
+ sercomm,scpart-id = <7>;
+ read-only;
+ };
+
+ partition@3600000 {
+ label = "ML4";
+ reg = <0x3600000 0x200000>;
+ sercomm,scpart-id = <8>;
+ read-only;
+ };
+
+ partition@3800000 {
+ label = "ML5";
+ reg = <0x3800000 0x200000>;
+ sercomm,scpart-id = <9>;
+ read-only;
+ };
+
+ partition@3a00000 {
+ label = "ML6";
+ reg = <0x3a00000 0x200000>;
+ sercomm,scpart-id = <10>;
+ read-only;
+ };
+
+ partition@3c00000 {
+ label = "ML7";
+ reg = <0x3c00000 0x200000>;
+ sercomm,scpart-id = <11>;
+ read-only;
+ };
+
+ partition@3e00000 {
+ label = "ML8";
+ reg = <0x3e00000 0x200000>;
+ sercomm,scpart-id = <12>;
+ read-only;
+ };
+
+ partition@4000000 {
+ label = "ML9";
+ reg = <0x4000000 0x200000>;
+ sercomm,scpart-id = <13>;
+ read-only;
+ };
+
+ partition@4200000 {
+ label = "ML10";
+ reg = <0x4200000 0x200000>;
+ sercomm,scpart-id = <14>;
+ read-only;
+ };
+
+ partition@4400000 {
+ label = "ML11";
+ reg = <0x4400000 0x200000>;
+ sercomm,scpart-id = <15>;
read-only;
};
factory: partition@4600000 {
label = "factory";
reg = <0x4600000 0x200000>;
+ sercomm,scpart-id = <16>;
read-only;
};
partition@4800000 {
+ label = "SC Private Data";
+ reg = <0x4800000 0x200000>;
+ sercomm,scpart-id = <17>;
+ read-only;
+ };
+
+ partition@4a00000 {
+ label = "POT";
+ reg = <0x4a00000 0x200000>;
+ sercomm,scpart-id = <18>;
+ read-only;
+ };
+
+ partition@4c00000 {
+ label = "Traffic Meter";
+ reg = <0x4c00000 0x200000>;
+ sercomm,scpart-id = <19>;
+ read-only;
+ };
+
+ partition@4e00000 {
+ label = "SC PID";
+ reg = <0x4e00000 0x200000>;
+ sercomm,scpart-id = <20>;
+ read-only;
+ };
+
+ partition@5000000 {
+ label = "SC Nvram";
+ reg = <0x5000000 0x200000>;
+ sercomm,scpart-id = <21>;
+ read-only;
+ };
+
+ partition@5200000 {
+ label = "Ralink Nvram";
+ reg = <0x5200000 0x200000>;
+ sercomm,scpart-id = <22>;
+ read-only;
+ };
+
+ partition@5400000 {
+ label = "reserved0";
+ reg = <0x5400000 0x200000>;
+ sercomm,scpart-id = <23>;
+ read-only;
+ };
+
+ partition@5600000 {
label = "reserved1";
- reg = <0x4800000 0x3800000>;
+ reg = <0x5600000 0x200000>;
+ sercomm,scpart-id = <24>;
+ read-only;
+ };
+
+ partition@5800000 {
+ label = "reserved2";
+ reg = <0x5800000 0x200000>;
+ sercomm,scpart-id = <25>;
+ read-only;
+ };
+
+ partition@5a00000 {
+ label = "reserved3";
+ reg = <0x5a00000 0x200000>;
+ sercomm,scpart-id = <26>;
+ read-only;
+ };
+
+ partition@5c00000 {
+ label = "reserved4";
+ reg = <0x5c00000 0x200000>;
+ sercomm,scpart-id = <27>;
+ read-only;
+ };
+
+ partition@5e00000 {
+ label = "reserved5";
+ reg = <0x5e00000 0x2180000>;
+ sercomm,scpart-id = <28>;
read-only;
};
};