.. SPDX-License-Identifier: GPL-2.0+ .. Copyright (C) 2023 Johan Jonker RKMTD ===== Info ---- The command rkmtd creates a virtual block device to transfer Rockchip boot block data to and from NAND with block orientated tools like "ums" and "rockusb". It uses the Rockchip MTD driver to scan for boot blocks and copies data from the first block in a GPT formatted virtual disk. Data must be written in U-boot "idbloader.img" format and start at partition "loader1" offset 64. The data header is parsed for length and offset. When the last sector is received it erases up to 5 erase blocks on NAND and writes boot blocks in a pattern depending on the NAND ID. Data is then verified. When a block turns out bad the block header is discarded. Limitations ----------- - Support with CONFIG_ROCKCHIP_NAND MTD driver only. - Support for Rockchip boot block header type 1 only. - Pattern for listed NAND IDs only. (Logic still not disclosed by Rockchip) - The MTD framework driver data and NAND ID must be extracted at a lower level. Available rkmtd commands ------------------------ .. code-block:: bash rkmtd bind