OSDN Git Service

cifs: sort interface list by speed
authorAurelien Aptel <aaptel@suse.com>
Fri, 20 Sep 2019 04:29:39 +0000 (06:29 +0200)
committerSteve French <stfrench@microsoft.com>
Mon, 25 Nov 2019 07:16:30 +0000 (01:16 -0600)
New channels are going to be opened by walking the list sequentially,
so by sorting it we will connect to the fastest interfaces first.

Signed-off-by: Aurelien Aptel <aaptel@suse.com>
Signed-off-by: Steve French <stfrench@microsoft.com>
fs/cifs/smb2ops.c

index eb92cd4..3b0f6cd 100644 (file)
@@ -10,6 +10,7 @@
 #include <linux/falloc.h>
 #include <linux/scatterlist.h>
 #include <linux/uuid.h>
+#include <linux/sort.h>
 #include <crypto/aead.h>
 #include "cifsglob.h"
 #include "smb2pdu.h"
@@ -552,6 +553,13 @@ out:
        return rc;
 }
 
+static int compare_iface(const void *ia, const void *ib)
+{
+       const struct cifs_server_iface *a = (struct cifs_server_iface *)ia;
+       const struct cifs_server_iface *b = (struct cifs_server_iface *)ib;
+
+       return a->speed == b->speed ? 0 : (a->speed > b->speed ? -1 : 1);
+}
 
 static int
 SMB3_request_interfaces(const unsigned int xid, struct cifs_tcon *tcon)
@@ -581,6 +589,9 @@ SMB3_request_interfaces(const unsigned int xid, struct cifs_tcon *tcon)
        if (rc)
                goto out;
 
+       /* sort interfaces from fastest to slowest */
+       sort(iface_list, iface_count, sizeof(*iface_list), compare_iface, NULL);
+
        spin_lock(&ses->iface_lock);
        kfree(ses->iface_list);
        ses->iface_list = iface_list;