Revert "Revert "usb_funcfs: Check descriptors received from systemd"" 52/177952/2
authorAdhavan M <adhavan.m@samsung.com>
Fri, 4 May 2018 11:36:36 +0000 (11:36 +0000)
committerManish Rathod <manish.r@samsung.com>
Fri, 4 May 2018 11:36:41 +0000 (11:36 +0000)
This reverts commit 54f43e108db2665341d553573f002f296e012987.

Change-Id: I3d16fc11babb78d852bc7caf55539329e49f4ff6

src/usb_funcfs_client.c

index 94f56f4..a7cee7d 100644 (file)
@@ -138,13 +138,29 @@ error:
 static void *usb_open_thread(void *x)
 {
     struct usb_handle *usb = (struct usb_handle *)x;
+    int maxfd = sd_listen_fds(0) + SD_LISTEN_FDS_START;
+    int fd;
+    int ep[3];
+    int received;
+
+    usb->control = -1;
+    usb->bulk_in = -1;
+    usb->bulk_out = -1;
+
+    received = 0;
+    for (fd = SD_LISTEN_FDS_START; fd < maxfd; ++fd) {
+        if (sd_is_special(fd, NULL) > 0) {
+            ep[received++] = fd;
+        }
+    }
 
     /* Endpoints are received from sytemd */
-    if (sd_listen_fds(0) >= 3) {
+    if (received == 3) {
+        D("Using functionfs socket activation\n");
         sdb_mutex_lock(&usb->control_lock);
-        usb->control = SD_LISTEN_FDS_START + 0;
-        usb->bulk_out = SD_LISTEN_FDS_START + 1;
-        usb->bulk_in = SD_LISTEN_FDS_START + 2;
+        usb->control = ep[0];
+        usb->bulk_out = ep[1];
+        usb->bulk_in = ep[2];
         sdb_cond_signal(&usb->control_notify);
         sdb_mutex_unlock(&usb->control_lock);
     } else {