RDMA/cma: Handle global/non-linklocal IPv6 addresses in cma_check_linklocal()
authorSomnath Kotur <somnath.kotur@emulex.com>
Sat, 16 Nov 2013 04:00:01 +0000 (09:30 +0530)
committerRoland Dreier <roland@purestorage.com>
Thu, 23 Jan 2014 06:49:17 +0000 (22:49 -0800)
If addr is not a linklocal address, the code incorrectly fails to
return and ends up assigning the scope ID to the scope id of the
address, which is wrong.  Fix by checking if it's a link local address
first, and immediately return 0 if not.

Signed-off-by: Somnath Kotur <somnath.kotur@emulex.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
drivers/infiniband/core/cma.c

index 8e49db6..4173a2a 100644 (file)
@@ -2480,8 +2480,11 @@ static int cma_check_linklocal(struct rdma_dev_addr *dev_addr,
                return 0;
 
        sin6 = (struct sockaddr_in6 *) addr;
-       if ((ipv6_addr_type(&sin6->sin6_addr) & IPV6_ADDR_LINKLOCAL) &&
-           !sin6->sin6_scope_id)
+
+       if (!(ipv6_addr_type(&sin6->sin6_addr) & IPV6_ADDR_LINKLOCAL))
+               return 0;
+
+       if (!sin6->sin6_scope_id)
                        return -EINVAL;
 
        dev_addr->bound_dev_if = sin6->sin6_scope_id;