dfu: add DFU_SKIP layout concept
authorJaehoon Chung <jh80.chung@samsung.com>
Fri, 30 Oct 2020 06:45:25 +0000 (15:45 +0900)
committerMarek Szyprowski <m.szyprowski@samsung.com>
Mon, 15 Nov 2021 10:37:12 +0000 (11:37 +0100)
Add DFU_SKIP layout concept.
If layout is "skip", it will be skipped after nothing to do.
- Add information into dfu_alt info
e.g) "u-boot.bin skip 0 0"

Change-Id: I96af2630ffabe87b71e514cad7bcc3513f221159
Signed-off-by: Jaehoon Chung <jh80.chung@samsung.com>
drivers/dfu/dfu.c
drivers/dfu/dfu_mmc.c
include/dfu.h

index a298c2c..f679f1f 100644 (file)
@@ -614,7 +614,7 @@ const char *dfu_get_dev_type(enum dfu_device_type t)
 const char *dfu_get_layout(enum dfu_layout l)
 {
        const char *const dfu_layout[] = {NULL, "RAW_ADDR", "FAT", "EXT2",
-                                         "EXT3", "EXT4", "RAM_ADDR" };
+                                         "EXT3", "EXT4", "RAM_ADDR", "SKIP" };
        return dfu_layout[l];
 }
 
index 691d01c..c7c324b 100644 (file)
@@ -108,6 +108,8 @@ static int mmc_file_op(enum dfu_op op, struct dfu_entity *dfu,
        case DFU_FS_EXT4:
                fstype = FS_TYPE_EXT;
                break;
+       case DFU_SKIP:
+               return 0;
        default:
                printf("%s: Layout (%s) not (yet) supported!\n", __func__,
                       dfu_get_layout(dfu->layout));
@@ -204,6 +206,9 @@ int dfu_write_medium_mmc(struct dfu_entity *dfu,
        case DFU_FS_EXT4:
                ret = mmc_file_buf_write(dfu, offset, buf, len);
                break;
+       case DFU_SKIP:
+               ret = 0;
+               break;
        default:
                printf("%s: Layout (%s) not (yet) supported!\n", __func__,
                       dfu_get_layout(dfu->layout));
@@ -238,6 +243,8 @@ int dfu_get_medium_size_mmc(struct dfu_entity *dfu, u64 *size)
                if (ret < 0)
                        return ret;
                return 0;
+       case DFU_SKIP:
+               return 0;
        default:
                printf("%s: Layout (%s) not (yet) supported!\n", __func__,
                       dfu_get_layout(dfu->layout));
@@ -399,6 +406,8 @@ int dfu_fill_entity_mmc(struct dfu_entity *dfu, char *devstr, char *s)
                dfu->layout = DFU_FS_FAT;
        } else if (!strcmp(entity_type, "ext4")) {
                dfu->layout = DFU_FS_EXT4;
+       } else if (!strcmp(entity_type, "skip")) {
+               dfu->layout = DFU_SKIP;
        } else {
                pr_err("Memory layout (%s) not supported!\n", entity_type);
                return -ENODEV;
index 84abdc7..2e8276c 100644 (file)
@@ -33,6 +33,7 @@ enum dfu_layout {
        DFU_FS_EXT3,
        DFU_FS_EXT4,
        DFU_RAM_ADDR,
+       DFU_SKIP,
 };
 
 enum dfu_op {