[Spice-devel] [PATCH spice-gtk 3/3] usb-device-manager: Use SpiceUsbBackendDevice directly instead of SpiceUsbDevice

Victor Toso victortoso at redhat.com
Mon Sep 2 10:26:29 UTC 2019


Hi,

On Thu, Jul 25, 2019 at 02:43:53PM +0100, Frediano Ziglio wrote:
> They were the same structure.

Right, the changes in the design made this happen.

Patch seems fine but you might need to rebase, I couldn't apply
it cleanly. Really sorry for the delay.

> Signed-off-by: Frediano Ziglio <fziglio at redhat.com>
> ---
>  src/usb-backend.c        |  6 +++---
>  src/usb-backend.h        |  6 +++---
>  src/usb-device-manager.c | 42 +++++++++++-----------------------------
>  3 files changed, 17 insertions(+), 37 deletions(-)
> 
> diff --git a/src/usb-backend.c b/src/usb-backend.c
> index 7e0e4a8a..26bda8b9 100644
> --- a/src/usb-backend.c
> +++ b/src/usb-backend.c
> @@ -44,7 +44,7 @@
>  
>  #define LOUD_DEBUG(x, ...)
>  
> -struct _SpiceUsbBackendDevice
> +struct _SpiceUsbDevice
>  {
>      libusb_device *libusb_device;
>      gint ref_count;
> @@ -512,12 +512,12 @@ void spice_usb_backend_delete(SpiceUsbBackend *be)
>      SPICE_DEBUG("%s <<", __FUNCTION__);
>  }
>  
> -const UsbDeviceInformation* spice_usb_backend_device_get_info(SpiceUsbBackendDevice *dev)
> +const UsbDeviceInformation* spice_usb_backend_device_get_info(const SpiceUsbBackendDevice *dev)
>  {
>      return &dev->device_info;
>  }
>  
> -gconstpointer spice_usb_backend_device_get_libdev(SpiceUsbBackendDevice *dev)
> +gconstpointer spice_usb_backend_device_get_libdev(const SpiceUsbBackendDevice *dev)
>  {
>      return dev->libusb_device;
>  }
> diff --git a/src/usb-backend.h b/src/usb-backend.h
> index 69a490b5..6eb02cb5 100644
> --- a/src/usb-backend.h
> +++ b/src/usb-backend.h
> @@ -28,7 +28,7 @@
>  G_BEGIN_DECLS
>  
>  typedef struct _SpiceUsbBackend SpiceUsbBackend;
> -typedef struct _SpiceUsbBackendDevice SpiceUsbBackendDevice;
> +typedef struct _SpiceUsbDevice SpiceUsbBackendDevice;
>  typedef struct _SpiceUsbBackendChannel SpiceUsbBackendChannel;
>  
>  typedef struct UsbDeviceInformation
> @@ -65,8 +65,8 @@ void spice_usb_backend_deregister_hotplug(SpiceUsbBackend *be);
>  /* Spice USB backend device API */
>  SpiceUsbBackendDevice *spice_usb_backend_device_ref(SpiceUsbBackendDevice *dev);
>  void spice_usb_backend_device_unref(SpiceUsbBackendDevice *dev);
> -gconstpointer spice_usb_backend_device_get_libdev(SpiceUsbBackendDevice *dev);
> -const UsbDeviceInformation* spice_usb_backend_device_get_info(SpiceUsbBackendDevice *dev);
> +gconstpointer spice_usb_backend_device_get_libdev(const SpiceUsbBackendDevice *dev);
> +const UsbDeviceInformation* spice_usb_backend_device_get_info(const SpiceUsbBackendDevice *dev);
>  gboolean spice_usb_backend_device_isoch(SpiceUsbBackendDevice *dev);
>  /* returns 0 if the device passes the filter */
>  int spice_usb_backend_device_check_filter(SpiceUsbBackendDevice *dev,
> diff --git a/src/usb-device-manager.c b/src/usb-device-manager.c
> index bf1c23bd..897aa09c 100644
> --- a/src/usb-device-manager.c
> +++ b/src/usb-device-manager.c
> @@ -120,12 +120,6 @@ enum {
>  
>  #ifdef USE_USBREDIR
>  
> -struct _SpiceUsbDevice {
> -    SpiceUsbBackendDevice *bdev;
> -    gint    ref;
> -};
> -
> -
>  static void channel_new(SpiceSession *session, SpiceChannel *channel,
>                          gpointer user_data);
>  static void channel_destroy(SpiceSession *session, SpiceChannel *channel,
> @@ -637,7 +631,7 @@ spice_usb_device_get_libusb_device(const SpiceUsbDevice *info G_GNUC_UNUSED)
>  #ifdef USE_USBREDIR
>      g_return_val_if_fail(info != NULL, FALSE);
>  
> -    return spice_usb_backend_device_get_libdev(info->bdev);
> +    return spice_usb_backend_device_get_libdev(info);
>  #endif
>      return NULL;
>  }
> @@ -1476,16 +1470,9 @@ gchar *spice_usb_device_get_description(SpiceUsbDevice *device, const gchar *for
>   */
>  static SpiceUsbDevice *spice_usb_device_new(SpiceUsbBackendDevice *bdev)
>  {
> -    SpiceUsbDevice *info;
> -
>      g_return_val_if_fail(bdev != NULL, NULL);
>  
> -    info = g_new0(SpiceUsbDevice, 1);
> -
> -    info->ref = 1;
> -    info->bdev = spice_usb_backend_device_ref(bdev);
> -
> -    return info;
> +    return spice_usb_backend_device_ref(bdev);
>  }
>  
>  guint8 spice_usb_device_get_busnum(const SpiceUsbDevice *info)
> @@ -1494,7 +1481,7 @@ guint8 spice_usb_device_get_busnum(const SpiceUsbDevice *info)
>  
>      g_return_val_if_fail(info != NULL, 0);
>  
> -    b_info = spice_usb_backend_device_get_info(info->bdev);
> +    b_info = spice_usb_backend_device_get_info(info);
>      return b_info->bus;
>  }
>  
> @@ -1504,7 +1491,7 @@ guint8 spice_usb_device_get_devaddr(const SpiceUsbDevice *info)
>  
>      g_return_val_if_fail(info != NULL, 0);
>  
> -    b_info = spice_usb_backend_device_get_info(info->bdev);
> +    b_info = spice_usb_backend_device_get_info(info);
>      return b_info->address;
>  }
>  
> @@ -1514,7 +1501,7 @@ guint16 spice_usb_device_get_vid(const SpiceUsbDevice *info)
>  
>      g_return_val_if_fail(info != NULL, 0);
>  
> -    b_info = spice_usb_backend_device_get_info(info->bdev);
> +    b_info = spice_usb_backend_device_get_info(info);
>      return b_info->vid;
>  }
>  
> @@ -1524,7 +1511,7 @@ guint16 spice_usb_device_get_pid(const SpiceUsbDevice *info)
>  
>      g_return_val_if_fail(info != NULL, 0);
>  
> -    b_info = spice_usb_backend_device_get_info(info->bdev);
> +    b_info = spice_usb_backend_device_get_info(info);
>      return b_info->pid;
>  }
>  
> @@ -1532,7 +1519,7 @@ gboolean spice_usb_device_is_isochronous(const SpiceUsbDevice *info)
>  {
>      g_return_val_if_fail(info != NULL, 0);
>  
> -    return spice_usb_backend_device_isoch(info->bdev);
> +    return spice_usb_backend_device_isoch((SpiceUsbBackendDevice*) info);
>  }
>  
>  #ifdef G_OS_WIN32
> @@ -1605,21 +1592,14 @@ void _usbdk_hider_update(SpiceUsbDeviceManager *manager)
>  static SpiceUsbDevice *spice_usb_device_ref(SpiceUsbDevice *info)
>  {
>      g_return_val_if_fail(info != NULL, NULL);
> -    g_atomic_int_inc(&info->ref);
> -    return info;
> +    return spice_usb_backend_device_ref(info);
>  }
>  
>  static void spice_usb_device_unref(SpiceUsbDevice *info)
>  {
> -    gboolean ref_count_is_0;
> -
>      g_return_if_fail(info != NULL);
>  
> -    ref_count_is_0 = g_atomic_int_dec_and_test(&info->ref);
> -    if (ref_count_is_0) {
> -        spice_usb_backend_device_unref(info->bdev);
> -        g_free(info);
> -    }
> +    spice_usb_backend_device_unref(info);
>  }
>  
>  static gboolean
> @@ -1630,7 +1610,7 @@ spice_usb_manager_device_equal_bdev(SpiceUsbDeviceManager *manager,
>      if ((info == NULL) || (bdev == NULL))
>          return FALSE;
>  
> -    return info->bdev == bdev;
> +    return info == bdev;
>  }
>  
>  /*
> @@ -1642,6 +1622,6 @@ spice_usb_device_manager_device_to_bdev(SpiceUsbDeviceManager *self,
>                                          SpiceUsbDevice *info)
>  {
>      /* Simply return a ref to the cached libdev */
> -    return spice_usb_backend_device_ref(info->bdev);
> +    return spice_usb_backend_device_ref(info);
>  }
>  #endif /* USE_USBREDIR */
> -- 
> 2.20.1
> 
> _______________________________________________
> Spice-devel mailing list
> Spice-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/spice-devel
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: not available
URL: <https://lists.freedesktop.org/archives/spice-devel/attachments/20190902/e88b68ca/attachment-0001.sig>


More information about the Spice-devel mailing list