kernel: Fix off-by-one error in FIT mtd partition search.
authorOldřich Jedlička <oldium.pro@gmail.com>
Wed, 25 Sep 2019 19:45:42 +0000 (21:45 +0200)
committerRISCi_ATOM <bob@bobcall.me>
Thu, 10 Oct 2019 15:55:00 +0000 (11:55 -0400)
commit7b0c93d8d2877c64963d70ca6d4c54c576d812f7
tree46c09f62254beff3a3075f4a794f5182d1d837a8
parentf3e4bd0577709b16c66f6e272556058e310bec60
kernel: Fix off-by-one error in FIT mtd partition search.

This fixes off-by-one error introduced in commit dc76900021b8
("kernel: Correctly search for the FIT image in mtd partition.")

Function `mtd_read` starts reading at `offset` and
needs `hdr_len` number of bytes to be available. Suppose
the easiest case when `offset` is `0` and `hdr_len` equals
to `mtd->size` - the `for` loop will not be entered even
when enough bytes are available to be read.

Same happens for any non-zero `offset`, when `hdr_len` is
just enough bytes to be read until `mtd->size` is reached.
Imagine that for example `mtd->size=5`, `offset=4` and
`hdr_len=1`. Then `offset+hdr_len=5` and the check has to
be `offset+hdr_len <= mtd->size`, i.e. `5 <= 5`. The
check for `offset + hdr_len` value needs to be inclusive,
therefore use `<=`.

Fixes: dc76900021b8 ("kernel: Correctly search for the FIT image in mtd partition.")
Signed-off-by: Oldřich Jedlička <oldium.pro@gmail.com>
[adjusted commit ref, fixes tag]
Signed-off-by: Petr Štetiar <ynezz@true.cz>
(cherry picked from commit e0ce80d42ace6feba509da16795ab0eb81cf5bf4)
target/linux/generic/files/drivers/mtd/mtdsplit/mtdsplit_fit.c