On Wed, Jun 24, 2020 at 1:44 AM Markus Armbruster <arm...@redhat.com> wrote: > > The Error ** argument must be NULL, &error_abort, &error_fatal, or a > pointer to a variable containing NULL. Passing an argument of the > latter kind twice without clearing it in between is wrong: if the > first call sets an error, it no longer points to NULL for the second > call. > > stm32f205_soc_realize() and stm32f405_soc_realize() are wrong that > way: they pass &err to object_property_set_int() without checking it, > and then to qdev_realize(). Harmless, because the former can't > actually fail here. > > Fix by passing &error_abort instead. > > Cc: Alistair Francis <alist...@alistair23.me> > Cc: Peter Maydell <peter.mayd...@linaro.org> > Cc: qemu-...@nongnu.org > Signed-off-by: Markus Armbruster <arm...@redhat.com>
Reviewed-by: Alistair Francis <alistair.fran...@wdc.com> Alistair > --- > hw/arm/stm32f205_soc.c | 2 +- > hw/arm/stm32f405_soc.c | 2 +- > 2 files changed, 2 insertions(+), 2 deletions(-) > > diff --git a/hw/arm/stm32f205_soc.c b/hw/arm/stm32f205_soc.c > index 19487544f0..56aef686c9 100644 > --- a/hw/arm/stm32f205_soc.c > +++ b/hw/arm/stm32f205_soc.c > @@ -154,7 +154,7 @@ static void stm32f205_soc_realize(DeviceState *dev_soc, > Error **errp) > > /* ADC 1 to 3 */ > object_property_set_int(OBJECT(s->adc_irqs), STM_NUM_ADCS, > - "num-lines", &err); > + "num-lines", &error_abort); > qdev_realize(DEVICE(s->adc_irqs), NULL, &err); > if (err != NULL) { > error_propagate(errp, err); > diff --git a/hw/arm/stm32f405_soc.c b/hw/arm/stm32f405_soc.c > index c12d9f999d..cf9228d8e7 100644 > --- a/hw/arm/stm32f405_soc.c > +++ b/hw/arm/stm32f405_soc.c > @@ -172,7 +172,7 @@ static void stm32f405_soc_realize(DeviceState *dev_soc, > Error **errp) > return; > } > object_property_set_int(OBJECT(&s->adc_irqs), STM_NUM_ADCS, > - "num-lines", &err); > + "num-lines", &error_abort); > qdev_realize(DEVICE(&s->adc_irqs), NULL, &err); > if (err != NULL) { > error_propagate(errp, err); > -- > 2.26.2 > >