[U-Boot] [PATCH 1/2] dfu: mmc: check if mmc device exists in mmc_block_op()
Lukasz Majewski
l.majewski at samsung.com
Fri Dec 12 09:38:17 CET 2014
Hi Przemyslaw,
> The function mmc_block_op() is the last function before
> the physicall data write, but the mmc device pointer is not
> checked. If mmc device not exists, then data abort will occur.
> To avoid this, first the mmc device pointer is checked.
>
> Signed-off-by: Przemyslaw Marczak <p.marczak at samsung.com>
> ---
> drivers/dfu/dfu_mmc.c | 8 +++++++-
> 1 file changed, 7 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/dfu/dfu_mmc.c b/drivers/dfu/dfu_mmc.c
> index 72fa03e..41ac188 100644
> --- a/drivers/dfu/dfu_mmc.c
> +++ b/drivers/dfu/dfu_mmc.c
> @@ -40,10 +40,16 @@ static int mmc_access_part(struct dfu_entity
> *dfu, struct mmc *mmc, int part) static int mmc_block_op(enum dfu_op
> op, struct dfu_entity *dfu, u64 offset, void *buf, long *len)
> {
> - struct mmc *mmc = find_mmc_device(dfu->data.mmc.dev_num);
> + struct mmc *mmc;
> u32 blk_start, blk_count, n = 0;
> int ret, part_num_bkp = 0;
>
> + mmc = find_mmc_device(dfu->data.mmc.dev_num);
> + if (!mmc) {
> + printf("Device MMC %d - not found!",
> dfu->data.mmc.dev_num);
Please change printf() -> error();
> + return -ENODEV;
> + }
> +
> /*
> * We must ensure that we work in lba_blk_size chunks, so
> ALIGN
> * this value.
--
Best regards,
Lukasz Majewski
Samsung R&D Institute Poland (SRPOL) | Linux Platform Group
More information about the U-Boot
mailing list