mirror of
https://github.com/cjdelisle/openwrt.git
synced 2025-08-28 22:43:22 +00:00
The following upstreamed / superseded patches were dropped: 060-01-clk-mediatek-mt7629-fix-parent-clock-of-some-top-clo.patch 060-02-arm-dts-mt7629-fix-sgmii-clock-selection-for-etherne.patch 060-03-net-mediatek-use-correct-register-field-for-SGMII-sp.patch 060-04-net-mediatek-correct-register-name-of-ethsys-syscfg1.patch 060-05-net-mediatek-fix-sgmii-selection-for-mt7622.patch 060-06-net-mediatek-fix-gmac2-usability-for-mt7629.patch 060-07-net-mediatek-add-support-for-10GBASE-R.patch 060-08-net-mediatek-make-sgmii-usxgmii-optional.patch 060-09-net-mediatek-don-t-enable-GDMA-cpu-bridge-unconditio.patch 060-10-net-mediatek-fix-usability-with-wget-command.patch 061-01-net-mediatek-split-ethernet-switch-code-from-mtk_eth.patch 061-02-net-mediatek-add-support-for-MediaTek-MT7987-SoC.patch 061-03-net-mediatek-add-support-for-Airoha-AN8855-ethernet-.patch 070-01-board-mediatek-mt7622-remove-board_late_init.patch 070-02-clk-mediatek-fix-uninitialized-fields-issue-in-INFRA.patch 070-03-configs-mt7629-move-image-load-address-to-0x42000000.patch 070-04-configs-mt7988-move-image-load-address-to-0x44000000.patch 070-05-spi-mtk_spim-add-support-to-use-DT-live-tree.patch 070-06-spi-mtk_spim-check-slave-device-mode-in-spi-mem-s-su.patch 070-07-arm-dts-mediatek-add-quad-mode-capabilities-for-SPI-.patch 070-08-pwm-mediatek-add-pwm3-support-for-mt7981.patch 070-09-pci-mediatek-add-support-for-multiple-ports-in-media.patch 070-10-arm-dts-mediatek-add-pcie-support-for-mt7988.patch 070-11-arm-dts-medaitek-fix-internal-switch-link-speed-of-m.patch 070-12-arm-dts-mediatek-add-support-for-all-three-GMACs-for.patch 070-13-arm-dts-medaitek-add-flash-interface-driving-setting.patch 070-14-arm-dts-mediatek-update-mt7981-mmc-node.patch 070-15-MAINTAINERS-update-file-list-for-MediaTek-ARM-platfo.patch 071-01-pinctrl-mediatek-update-mt7981-pinctrl-driver-based-.patch 100-18-board-mt7629-add-support-for-booting-from-SPI-NAND.patch 290-mt7981-add-USB-nodes.patch Refreshed all the patches needing it. Run-tested: GatoNetworks GDSP, Arcadyan Mozart (ynezz), Zbt WG3526 (dangowrt) Signed-off-by: Enrico Mioso <mrkiko.rs@gmail.com> Signed-off-by: Petr Štetiar <ynezz@true.cz> [patch refresh, Mozart testing] Signed-off-by: Daniel Golle <daniel@makrotopia.org> [rebased, tested on MT7621]
81 lines
2.4 KiB
Diff
81 lines
2.4 KiB
Diff
From 6dbbc8affb6ab22f940d13d0e928d5e881127ca4 Mon Sep 17 00:00:00 2001
|
|
From: Weijie Gao <weijie.gao@mediatek.com>
|
|
Date: Mon, 25 Jul 2022 11:22:57 +0800
|
|
Subject: [PATCH 44/71] cmd: mtd: add markbad subcommand for NMBM testing
|
|
|
|
This patch adds:
|
|
* Mark bad block on lower mtd device and erase on upper mtd
|
|
device, which will trigger remapping:
|
|
$ mtd markbad spi-nand0 0x20000 (mark block1 as bad)
|
|
$ mtd erase nmbm0 0x20000 0x20000 (let nmbm detect the bad block and remap it)
|
|
|
|
* Clear bad block mark through:
|
|
$ mtd erase.dontskipbad spi-nand0 0x20000 0x20000
|
|
(After cleaning bad block mark, we need to rebuild nmbm manage table.)
|
|
|
|
Signed-off-by: SkyLake.Huang <skylake.huang@mediatek.com>
|
|
---
|
|
cmd/mtd.c | 39 +++++++++++++++++++++++++++++++++++++++
|
|
1 file changed, 39 insertions(+)
|
|
|
|
--- a/cmd/mtd.c
|
|
+++ b/cmd/mtd.c
|
|
@@ -728,6 +728,42 @@ out_put_mtd:
|
|
return CMD_RET_SUCCESS;
|
|
}
|
|
|
|
+static int do_mtd_markbad(struct cmd_tbl *cmdtp, int flag, int argc,
|
|
+ char * const argv[])
|
|
+{
|
|
+ struct mtd_info *mtd;
|
|
+ loff_t off;
|
|
+ int ret;
|
|
+
|
|
+ if (argc < 3)
|
|
+ return CMD_RET_USAGE;
|
|
+
|
|
+ mtd = get_mtd_by_name(argv[1]);
|
|
+ if (IS_ERR(mtd) || !mtd)
|
|
+ return CMD_RET_FAILURE;
|
|
+
|
|
+ if (!mtd_can_have_bb(mtd)) {
|
|
+ printf("Only NAND-based devices can have mark blocks\n");
|
|
+ goto out_put_mtd;
|
|
+ }
|
|
+
|
|
+ off = simple_strtoull(argv[2], NULL, 0);
|
|
+
|
|
+ ret = mtd_block_markbad(mtd, off);
|
|
+ if (!ret) {
|
|
+ printf("MTD device %s block at 0x%08llx marked bad\n",
|
|
+ mtd->name, off);
|
|
+ } else {
|
|
+ printf("MTD device %s block at 0x%08llx mark bad failed\n",
|
|
+ mtd->name, off);
|
|
+ }
|
|
+
|
|
+out_put_mtd:
|
|
+ put_mtd_device(mtd);
|
|
+
|
|
+ return CMD_RET_SUCCESS;
|
|
+}
|
|
+
|
|
#ifdef CONFIG_AUTO_COMPLETE
|
|
static int mtd_name_complete(int argc, char *const argv[], char last_char,
|
|
int maxv, char *cmdv[])
|
|
@@ -775,6 +811,7 @@ U_BOOT_LONGHELP(mtd,
|
|
"\n"
|
|
"Specific functions:\n"
|
|
"mtd bad <name>\n"
|
|
+ "mtd markbad <name> <off>\n"
|
|
#if CONFIG_IS_ENABLED(CMD_MTD_OTP)
|
|
"mtd otpread <name> [u|f] <off> <size>\n"
|
|
"mtd otpwrite <name> <off> <hex string>\n"
|
|
@@ -815,4 +852,6 @@ U_BOOT_CMD_WITH_SUBCMDS(mtd, "MTD utils"
|
|
U_BOOT_SUBCMD_MKENT_COMPLETE(erase, 4, 0, do_mtd_erase,
|
|
mtd_name_complete),
|
|
U_BOOT_SUBCMD_MKENT_COMPLETE(bad, 2, 1, do_mtd_bad,
|
|
+ mtd_name_complete),
|
|
+ U_BOOT_SUBCMD_MKENT_COMPLETE(markbad, 3, 1, do_mtd_markbad,
|
|
mtd_name_complete));
|