qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Markus Armbruster <armbru@redhat.com>
To: qemu-devel@nongnu.org
Cc: Paolo Bonzini <pbonzini@redhat.com>, Gerd Hoffmann <kraxel@redhat.com>
Subject: [PATCH v3 29/39] usb: Eliminate usb_try_create_simple()
Date: Tue,  9 Jun 2020 18:39:22 +0200	[thread overview]
Message-ID: <20200609163932.1566209-30-armbru@redhat.com> (raw)
In-Reply-To: <20200609163932.1566209-1-armbru@redhat.com>

usb_try_create_simple() is qdev_try_new() and qdev_realize_and_unref()
with more verbose error messages.  Of its two users, one ignores
errors, and the other asserts they are impossible.

Make them use qdev_try_new() and qdev_realize_and_unref() directly,
and eliminate usb_try_create_simple

Cc: Gerd Hoffmann <kraxel@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Gerd Hoffmann <kraxel@redhat.com>
Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
---
 hw/usb/bus.c | 37 ++++++++++++++-----------------------
 1 file changed, 14 insertions(+), 23 deletions(-)

diff --git a/hw/usb/bus.c b/hw/usb/bus.c
index 5c4d31614e..a81aee2051 100644
--- a/hw/usb/bus.c
+++ b/hw/usb/bus.c
@@ -318,35 +318,22 @@ USBDevice *usb_new(const char *name)
     return USB_DEVICE(qdev_new(name));
 }
 
+static USBDevice *usb_try_new(const char *name)
+{
+    return USB_DEVICE(qdev_try_new(name));
+}
+
 bool usb_realize_and_unref(USBDevice *dev, USBBus *bus, Error **errp)
 {
     return qdev_realize_and_unref(&dev->qdev, &bus->qbus, errp);
 }
 
-static USBDevice *usb_try_create_simple(USBBus *bus, const char *name,
-                                        Error **errp)
-{
-    Error *err = NULL;
-    DeviceState *dev;
-
-    dev = qdev_try_new(name);
-    if (!dev) {
-        error_setg(errp, "Failed to create USB device '%s'", name);
-        return NULL;
-    }
-    qdev_realize_and_unref(dev, &bus->qbus, &err);
-    if (err) {
-        error_propagate_prepend(errp, err,
-                                "Failed to initialize USB device '%s': ",
-                                name);
-        return NULL;
-    }
-    return USB_DEVICE(dev);
-}
-
 USBDevice *usb_create_simple(USBBus *bus, const char *name)
 {
-    return usb_try_create_simple(bus, name, &error_abort);
+    USBDevice *dev = usb_new(name);
+
+    usb_realize_and_unref(dev, bus, &error_abort);
+    return dev;
 }
 
 static void usb_fill_port(USBPort *port, void *opaque, int index,
@@ -426,6 +413,7 @@ void usb_claim_port(USBDevice *dev, Error **errp)
 {
     USBBus *bus = usb_bus_from_device(dev);
     USBPort *port;
+    USBDevice *hub;
 
     assert(dev->port == NULL);
 
@@ -443,7 +431,10 @@ void usb_claim_port(USBDevice *dev, Error **errp)
     } else {
         if (bus->nfree == 1 && strcmp(object_get_typename(OBJECT(dev)), "usb-hub") != 0) {
             /* Create a new hub and chain it on */
-            usb_try_create_simple(bus, "usb-hub", NULL);
+            hub = usb_try_new("usb-hub");
+            if (hub) {
+                usb_realize_and_unref(hub, bus, NULL);
+            }
         }
         if (bus->nfree == 0) {
             error_setg(errp, "tried to attach usb device %s to a bus "
-- 
2.26.2



  parent reply	other threads:[~2020-06-09 17:09 UTC|newest]

Thread overview: 41+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-06-09 16:38 [PATCH v3 00/39] qdev: Rework how we plug into the parent bus Markus Armbruster
2020-06-09 16:38 ` [PATCH v3 01/39] qdev: Rename qbus_realize() to qbus_init() Markus Armbruster
2020-06-09 16:38 ` [PATCH v3 02/39] Revert "hw/prep: realize the PCI root bus as part of the prep init" Markus Armbruster
2020-06-09 16:38 ` [PATCH v3 03/39] Revert "hw/versatile: realize the PCI root bus as part of the versatile init" Markus Armbruster
2020-06-09 16:38 ` [PATCH v3 04/39] qdev: New qdev_new(), qdev_realize(), etc Markus Armbruster
2020-06-09 16:38 ` [PATCH v3 05/39] qdev: Put qdev_new() to use with Coccinelle Markus Armbruster
2020-06-09 16:38 ` [PATCH v3 06/39] qdev: Convert to qbus_realize(), qbus_unrealize() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 07/39] qdev: Convert to qdev_unrealize() with Coccinelle Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 08/39] qdev: Convert to qdev_unrealize() manually Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 09/39] qdev: Convert uses of qdev_create() with Coccinelle Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 10/39] qdev: Convert uses of qdev_create() manually Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 11/39] qdev: Convert uses of qdev_set_parent_bus() with Coccinelle Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 12/39] qdev: Convert uses of qdev_set_parent_bus() manually Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 13/39] pci: New pci_new(), pci_realize_and_unref() etc Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 14/39] hw/ppc: Eliminate two superfluous QOM casts Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 15/39] pci: Convert uses of pci_create() etc. with Coccinelle Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 16/39] pci: Convert uses of pci_create() etc. manually Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 17/39] pci: pci_create(), pci_create_multifunction() are now unused, drop Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 18/39] isa: New isa_new(), isa_realize_and_unref() etc Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 19/39] isa: Convert uses of isa_create() with Coccinelle Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 20/39] isa: Convert uses of isa_create(), isa_try_create() manually Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 21/39] isa: isa_create(), isa_try_create() are now unused, drop Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 22/39] ssi: ssi_auto_connect_slaves() never does anything, drop Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 23/39] ssi: Convert uses of ssi_create_slave_no_init() with Coccinelle Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 24/39] ssi: Convert last use of ssi_create_slave_no_init() manually Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 25/39] ssi: ssi_create_slave_no_init() is now unused, drop Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 26/39] usb: New usb_new(), usb_realize_and_unref() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 27/39] usb: Convert uses of usb_create() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 28/39] usb: usb_create() is now unused, drop Markus Armbruster
2020-06-09 16:39 ` Markus Armbruster [this message]
2020-06-09 16:39 ` [PATCH v3 30/39] qdev: qdev_create(), qdev_try_create() are " Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 31/39] auxbus: Rename aux_init_bus() to aux_bus_init() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 32/39] auxbus: New aux_bus_realize(), pairing with aux_bus_init() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 33/39] auxbus: Convert a use of qdev_set_parent_bus() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 34/39] auxbus: Eliminate aux_create_slave() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 35/39] qom: Tidy up a few object_initialize_child() calls Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 36/39] qom: Less verbose object_initialize_child() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 37/39] macio: Convert use of qdev_set_parent_bus() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 38/39] macio: Eliminate macio_init_child_obj() Markus Armbruster
2020-06-09 16:39 ` [PATCH v3 39/39] sysbus: Drop useless OBJECT() in sysbus_init_child_obj() calls Markus Armbruster
2020-06-09 16:40 ` [PATCH v3 00/39] qdev: Rework how we plug into the parent bus Markus Armbruster

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20200609163932.1566209-30-armbru@redhat.com \
    --to=armbru@redhat.com \
    --cc=kraxel@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).