On Tue, Nov 19, 2019 at 09:21:24AM +0300, Dan Carpenter wrote: > This probe function is passing the wrong size to devm_iio_device_alloc(). > It is supposed to be the size of the private data. Fortunately, > sizeof(*indio_dev) is larger than sizeof(struct mrfld_adc) so it doesn't > cause a runtime problem. > Ah, indeed, thanks for fixing this! Reviewed-by: Andy Shevchenko <andriy.shevchenko@xxxxxxxxxxxxxxx> > Fixes: a7118662734a ("iio: adc: intel_mrfld_adc: Add Basin Cove ADC driver") > Signed-off-by: Dan Carpenter <dan.carpenter@xxxxxxxxxx> > --- > drivers/iio/adc/intel_mrfld_adc.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/iio/adc/intel_mrfld_adc.c b/drivers/iio/adc/intel_mrfld_adc.c > index 67d096f8180d..c35a1beb817c 100644 > --- a/drivers/iio/adc/intel_mrfld_adc.c > +++ b/drivers/iio/adc/intel_mrfld_adc.c > @@ -185,7 +185,7 @@ static int mrfld_adc_probe(struct platform_device *pdev) > int irq; > int ret; > > - indio_dev = devm_iio_device_alloc(dev, sizeof(*indio_dev)); > + indio_dev = devm_iio_device_alloc(dev, sizeof(struct mrfld_adc)); Many drivers use sizeof(*adc) form, but I'm okay with either. > if (!indio_dev) > return -ENOMEM; > > -- > 2.11.0 > -- With Best Regards, Andy Shevchenko