[PATCH v2] mtd: Fix partition alignment check on multi-erasesize devices
Boris Brezillon
boris.brezillon at free-electrons.com
Thu Sep 28 02:46:44 PDT 2017
On Mon, 25 Sep 2017 10:19:57 +0200
Boris Brezillon <boris.brezillon at free-electrons.com> wrote:
> Commit 1eeef2d7483a ("mtd: handle partitioning on devices with 0
> erasesize") introduced a regression on heterogeneous erase region
> devices. Alignment of the partition was tested against the master
> eraseblock size which can be bigger than the slave one, thus leading
> to some partitions being marked as read-only.
>
> Update wr_alignment to match this slave erasesize after this erasesize
> has been determined by picking the biggest erasesize of all the regions
> embedded in the MTD partition.
>
> Reported-by: Mathias Thore <Mathias.Thore at infinera.com>
> Fixes: 1eeef2d7483a ("mtd: handle partitioning on devices with 0 erasesize")
> Cc: <stable at vger.kernel.org>
> Signed-off-by: Boris Brezillon <boris.brezillon at free-electrons.com>
Applied.
> ---
> Changes in v2:
> - Fix build error reported by Mathias
> ---
> drivers/mtd/mtdpart.c | 8 ++++++++
> 1 file changed, 8 insertions(+)
>
> diff --git a/drivers/mtd/mtdpart.c b/drivers/mtd/mtdpart.c
> index 5736b0c90b33..a308e707392d 100644
> --- a/drivers/mtd/mtdpart.c
> +++ b/drivers/mtd/mtdpart.c
> @@ -581,6 +581,14 @@ static struct mtd_part *allocate_partition(struct mtd_info *parent,
> slave->mtd.erasesize = parent->erasesize;
> }
>
> + /*
> + * Slave erasesize might differ from the master one if the master
> + * exposes several regions with different erasesize. Adjust
> + * wr_alignment accordingly.
> + */
> + if (!(slave->mtd.flags & MTD_NO_ERASE))
> + wr_alignment = slave->mtd.erasesize;
> +
> tmp = slave->offset;
> remainder = do_div(tmp, wr_alignment);
> if ((slave->mtd.flags & MTD_WRITEABLE) && remainder) {
More information about the linux-mtd
mailing list