From: Rafał Miłecki <ra...@milecki.pl>

By default nand_do_upgrade() can only deal with raw and gzipped firmware
files. Vendors often use custom firmware containers. Allow passing
custom extraction command to allow using nand_do_upgrade() with vendor
firmwares.

Signed-off-by: Rafał Miłecki <ra...@milecki.pl>
---
 package/base-files/files/lib/upgrade/nand.sh | 13 ++++++++++---
 1 file changed, 10 insertions(+), 3 deletions(-)

diff --git a/package/base-files/files/lib/upgrade/nand.sh 
b/package/base-files/files/lib/upgrade/nand.sh
index 0b76486ee7..f821a82c60 100644
--- a/package/base-files/files/lib/upgrade/nand.sh
+++ b/package/base-files/files/lib/upgrade/nand.sh
@@ -387,9 +387,11 @@ nand_verify_tar_file() {
 
 nand_do_flash_file() {
        local file="$1"
+       local cmd="$2"
+       local file_type
 
-       local cmd="$(identify_if_gzip "$file")cat"
-       local file_type="$(identify "$file" "$cmd" "")"
+       [ -z "$cmd" ] && cmd="$(identify_if_gzip "$file")cat"
+       file_type="$(identify "$file" "$cmd" "")"
 
        [ ! "$(find_mtd_index "$CI_UBIPART")" ] && CI_UBIPART=rootfs
 
@@ -423,17 +425,22 @@ nand_do_restore_config() {
 # Supported firmware containers:
 # 1. Raw file
 # 2. Gzip
+# 3. Custom (requires passing extracting command)
 #
 # Supported data formats:
 # 1. Tar with kernel/rootfs
 # 2. UBI image (built using "ubinized")
 # 3. UBIFS image (to update UBI volume with)
 # 4. FIT image (to update UBI volume with)
+#
+# $(1): firmware file path
+# $(2): (optional) pipe command to extract firmware
 nand_do_upgrade() {
        local file="$1"
+       local cmd="$2"
 
        sync
-       nand_do_flash_file "$file" && nand_do_upgrade_success
+       nand_do_flash_file "$file" "$cmd" && nand_do_upgrade_success
        nand_do_upgrade_failed
 }
 
-- 
2.35.3


_______________________________________________
openwrt-devel mailing list
openwrt-devel@lists.openwrt.org
https://lists.openwrt.org/mailman/listinfo/openwrt-devel

Reply via email to