[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v4 4/4] hw/isa/i82378: Propagate error if PC_SPEAKER device c
From: |
Bernhard Beschow |
Subject: |
Re: [PATCH v4 4/4] hw/isa/i82378: Propagate error if PC_SPEAKER device creation failed |
Date: |
Sun, 22 Oct 2023 22:12:41 +0000 |
Am 20. Oktober 2023 17:15:08 UTC schrieb "Philippe Mathieu-Daudé"
<philmd@linaro.org>:
>In commit 40f8214fcd ("hw/audio/pcspk: Inline pcspk_init()")
>we neglected to give a change to the caller to handle failed
>device creation cleanly. Respect the caller API contract and
>propagate the error if creating the PC_SPEAKER device ever
>failed. This avoid yet another bad API use to be taken as
>example and copy / pasted all over the code base.
>
>Reported-by: Bernhard Beschow <shentey@gmail.com>
>Suggested-by: Markus Armbruster <armbru@redhat.com>
>Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Bernhard Beschow <shentey@gmail.com>
>---
> hw/isa/i82378.c | 4 +++-
> 1 file changed, 3 insertions(+), 1 deletion(-)
>
>diff --git a/hw/isa/i82378.c b/hw/isa/i82378.c
>index 79ffbb52a0..203b92c264 100644
>--- a/hw/isa/i82378.c
>+++ b/hw/isa/i82378.c
>@@ -105,7 +105,9 @@ static void i82378_realize(PCIDevice *pci, Error **errp)
> /* speaker */
> pcspk = isa_new(TYPE_PC_SPEAKER);
> object_property_set_link(OBJECT(pcspk), "pit", OBJECT(pit), &error_fatal);
>- isa_realize_and_unref(pcspk, isabus, &error_fatal);
>+ if (!isa_realize_and_unref(pcspk, isabus, errp)) {
>+ return;
>+ }
>
> /* 2 82C37 (dma) */
> isa_create_simple(isabus, "i82374");
- [PATCH v4 0/4] hw/audio/pcspk: Inline pcspk_init(), Philippe Mathieu-Daudé, 2023/10/20
- [PATCH v4 1/4] hw/i386/pc: Pass Error** argument to pc_basic_device_init(), Philippe Mathieu-Daudé, 2023/10/20
- [PATCH v4 2/4] hw/i386/pc: Propagate error if HPET device creation failed, Philippe Mathieu-Daudé, 2023/10/20
- [PATCH v4 3/4] hw/i386/pc: Propagate error if PC_SPEAKER device creation failed, Philippe Mathieu-Daudé, 2023/10/20
- [PATCH v4 4/4] hw/isa/i82378: Propagate error if PC_SPEAKER device creation failed, Philippe Mathieu-Daudé, 2023/10/20
- Re: [PATCH v4 0/4] hw/audio/pcspk: Inline pcspk_init(), Bernhard Beschow, 2023/10/22