[PATCH] ge: common: vpd_reader: fix errloc array size in verify_bch()

Ian Ray ian.ray at gehealthcare.com
Tue Jun 30 16:29:34 CEST 2026


On Tue, Jun 30, 2026 at 04:39:39PM +0300, Md Shofiqul Islam wrote:
> errloc stores bit positions of errors returned by decode_bch().
> The maximum number of correctable errors is ecc_bits, so errloc
> must have ecc_bits entries.  The array was allocated with data_length
> entries instead, which is the number of EEPROM data bytes -- orders
> of magnitude larger than needed and incorrect.

Good catch, thanks for fixing this.

> 
> Fixes: b418dfe16e62 ("board: ge: make VPD code common")
> Signed-off-by: Md Shofiqul Islam <shofiqtest at gmail.com>

Reviewed-by: Ian Ray <ian.ray at gehealthcare.com>

> ---
>  board/ge/common/vpd_reader.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/board/ge/common/vpd_reader.c b/board/ge/common/vpd_reader.c
> index 2422db38013..b3f9e96615d 100644
> --- a/board/ge/common/vpd_reader.c
> +++ b/board/ge/common/vpd_reader.c
> @@ -66,7 +66,7 @@ static int verify_bch(int ecc_bits, unsigned int prim_poly, u8 *data,
>                 return -1;
>         }
> 
> -       unsigned int *errloc = (unsigned int *)calloc(data_length,
> +       unsigned int *errloc = (unsigned int *)calloc(ecc_bits,
>                                                       sizeof(unsigned int));
>         int errors = decode_bch(bch, data, data_length, ecc, NULL, NULL,
>                                 errloc);
> --
> 2.51.1
> 


More information about the U-Boot mailing list