]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
usb: usbip tool: Add ncontrollers in vhci_driver structure
authorYuyang Du <yuyang.du@intel.com>
Mon, 22 May 2017 10:20:16 +0000 (18:20 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 13 Jun 2017 08:48:24 +0000 (10:48 +0200)
A new field ncontrollers is added to the vhci_driver structure.
And this field is stored by scanning the vhci_hcd* dirs in the
platform udev.

Suggested-and-reviewed-by: Krzysztof Opasiak <k.opasiak@samsung.com>
Signed-off-by: Yuyang Du <yuyang.du@intel.com>
Acked-by: Shuah Khan <shuahkh@osg.samsung.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
tools/usb/usbip/libsrc/vhci_driver.c
tools/usb/usbip/libsrc/vhci_driver.h

index 036b62be0fc71f9c16a99aa398a5c95202c6665e..f6f3a19ba385f9ef8347f6a5b91a2b935748b096 100644 (file)
@@ -7,6 +7,7 @@
 #include <limits.h>
 #include <netdb.h>
 #include <libudev.h>
+#include <dirent.h>
 #include "sysfs_utils.h"
 
 #undef  PROGNAME
@@ -134,6 +135,33 @@ static int get_nports(void)
        return (int)strtoul(attr_nports, NULL, 10);
 }
 
+static int vhci_hcd_filter(const struct dirent *dirent)
+{
+       return strcmp(dirent->d_name, "vhci_hcd") >= 0;
+}
+
+static int get_ncontrollers(void)
+{
+       struct dirent **namelist;
+       struct udev_device *platform;
+       int n;
+
+       platform = udev_device_get_parent(vhci_driver->hc_device);
+       if (platform == NULL)
+               return -1;
+
+       n = scandir(udev_device_get_syspath(platform), &namelist, vhci_hcd_filter, NULL);
+       if (n < 0)
+               err("scandir failed");
+       else {
+               for (int i = 0; i < n; i++)
+                       free(namelist[i]);
+               free(namelist);
+       }
+
+       return n;
+}
+
 /*
  * Read the given port's record.
  *
@@ -230,6 +258,14 @@ int usbip_vhci_driver_open(void)
                goto err;
        }
 
+       vhci_driver->ncontrollers = get_ncontrollers();
+       dbg("available controllers: %d", vhci_driver->ncontrollers);
+
+       if (vhci_driver->ncontrollers <=0) {
+               err("no available usb controllers");
+               goto err;
+       }
+
        if (refresh_imported_device_list())
                goto err;
 
index fa2316cf2cacc9dab036fa1b4d41927e51a06428..33add142c46e4b2c7f263a10f19a7fb1974bb138 100644 (file)
@@ -31,6 +31,7 @@ struct usbip_vhci_driver {
        /* /sys/devices/platform/vhci_hcd */
        struct udev_device *hc_device;
 
+       int ncontrollers;
        int nports;
        struct usbip_imported_device idev[MAXNPORT];
 };