[PATCH 12/18] stm32mp: stm32prog: add support for delete option in flashlayout

Patrice CHOTARD patrice.chotard at st.com
Tue Apr 14 15:08:28 CEST 2020


Hi

On 3/18/20 9:24 AM, Patrick Delaunay wrote:
> Add support for delete option 'D' in flashlayout for
> full device or for partitions
>
> Signed-off-by: Patrick Delaunay <patrick.delaunay at st.com>
> ---
>
>  .../mach-stm32mp/cmd_stm32prog/stm32prog.c    | 105 ++++++++++++++++++
>  1 file changed, 105 insertions(+)
>
> diff --git a/arch/arm/mach-stm32mp/cmd_stm32prog/stm32prog.c b/arch/arm/mach-stm32mp/cmd_stm32prog/stm32prog.c
> index 3e521d42f2..3573c04d16 100644
> --- a/arch/arm/mach-stm32mp/cmd_stm32prog/stm32prog.c
> +++ b/arch/arm/mach-stm32mp/cmd_stm32prog/stm32prog.c
> @@ -23,9 +23,11 @@
>  
>  #define OPT_SELECT	BIT(0)
>  #define OPT_EMPTY	BIT(1)
> +#define OPT_DELETE	BIT(2)
>  
>  #define IS_SELECT(part)	((part)->option & OPT_SELECT)
>  #define IS_EMPTY(part)	((part)->option & OPT_EMPTY)
> +#define IS_DELETE(part)	((part)->option & OPT_DELETE)
>  
>  #define ALT_BUF_LEN			SZ_1K
>  
> @@ -158,6 +160,9 @@ static int parse_option(struct stm32prog_data *data,
>  		case 'E':
>  			part->option |= OPT_EMPTY;
>  			break;
> +		case 'D':
> +			part->option |= OPT_DELETE;
> +			break;
>  		default:
>  			result = -EINVAL;
>  			stm32prog_err("Layout line %d: invalid option '%c' in %s)",
> @@ -1293,10 +1298,80 @@ void stm32prog_next_phase(struct stm32prog_data *data)
>  		puts("Phase=END\n");
>  }
>  
> +static int part_delete(struct stm32prog_data *data,
> +		       struct stm32prog_part_t *part)
> +{
> +	int ret = 0;
> +#ifdef CONFIG_MMC
> +	unsigned long blks, blks_offset, blks_size;
> +	struct blk_desc *block_dev = NULL;
> + #endif
> +#ifdef CONFIG_MTD
> +	char cmdbuf[40];
> +	char devstr[10];
> +#endif
> +
> +	printf("Erasing %s ", part->name);
> +	switch (part->target) {
> +#ifdef CONFIG_MMC
> +	case STM32PROG_MMC:
> +		printf("on mmc %d: ", part->dev->dev_id);
> +		block_dev = mmc_get_blk_desc(part->dev->mmc);
> +		blks_offset = lldiv(part->addr, part->dev->mmc->read_bl_len);
> +		blks_size = lldiv(part->size, part->dev->mmc->read_bl_len);
> +		/* -1 or -2 : delete boot partition of MMC
> +		 * need to switch to associated hwpart 1 or 2
> +		 */
> +		if (part->part_id < 0)
> +			if (blk_select_hwpart_devnum(IF_TYPE_MMC,
> +						     part->dev->dev_id,
> +						     -part->part_id))
> +				return -1;
> +
> +		blks = blk_derase(block_dev, blks_offset, blks_size);
> +
> +		/* return to user partition */
> +		if (part->part_id < 0)
> +			blk_select_hwpart_devnum(IF_TYPE_MMC,
> +						 part->dev->dev_id, 0);
> +		if (blks != blks_size) {
> +			ret = -1;
> +			stm32prog_err("%s (0x%x): MMC erase failed",
> +				      part->name, part->id);
> +		}
> +		break;
> +#endif
> +#ifdef CONFIG_MTD
> +	case STM32PROG_NOR:
> +	case STM32PROG_NAND:
> +	case STM32PROG_SPI_NAND:
> +		get_mtd_by_target(devstr, part->target, part->dev->dev_id);
> +		printf("on %s: ", devstr);
> +		sprintf(cmdbuf, "mtd erase %s 0x%llx 0x%llx",
> +			devstr, part->addr, part->size);
> +		if (run_command(cmdbuf, 0)) {
> +			ret = -1;
> +			stm32prog_err("%s (0x%x): MTD erase commands failed (%s)",
> +				      part->name, part->id, cmdbuf);
> +		}
> +		break;
> +#endif
> +	default:
> +		ret = -1;
> +		stm32prog_err("%s (0x%x): erase invalid", part->name, part->id);
> +		break;
> +	}
> +	if (!ret)
> +		printf("done\n");
> +
> +	return ret;
> +}
> +
>  static void stm32prog_devices_init(struct stm32prog_data *data)
>  {
>  	int i;
>  	int ret;
> +	struct stm32prog_part_t *part;
>  
>  	ret = treat_partition_list(data);
>  	if (ret)
> @@ -1309,10 +1384,40 @@ static void stm32prog_devices_init(struct stm32prog_data *data)
>  			goto error;
>  	}
>  
> +	/* delete RAW partition before create partition */
> +	for (i = 0; i < data->part_nb; i++) {
> +		part = &data->part_array[i];
> +
> +		if (part->part_type != RAW_IMAGE)
> +			continue;
> +
> +		if (!IS_SELECT(part) || !IS_DELETE(part))
> +			continue;
> +
> +		ret = part_delete(data, part);
> +		if (ret)
> +			goto error;
> +	}
> +
>  	ret = create_partitions(data);
>  	if (ret)
>  		goto error;
>  
> +	/* delete partition GPT or MTD */
> +	for (i = 0; i < data->part_nb; i++) {
> +		part = &data->part_array[i];
> +
> +		if (part->part_type == RAW_IMAGE)
> +			continue;
> +
> +		if (!IS_SELECT(part) || !IS_DELETE(part))
> +			continue;
> +
> +		ret = part_delete(data, part);
> +		if (ret)
> +			goto error;
> +	}
> +
>  	return;
>  
>  error:

Reviewed-by: Patrice Chotard <patrice.chotard at st.com>

Thanks

Patrice


More information about the U-Boot mailing list