rds: Changing IP address internal representation to struct in6_addr
This patch changes the internal representation of an IP address to use struct in6_addr. IPv4 address is stored as an IPv4 mapped address. All the functions which take an IP address as argument are also changed to use struct in6_addr. But RDS socket layer is not modified such that it still does not accept IPv6 address from an application. And RDS layer does not accept nor initiate IPv6 connections. v2: Fixed sparse warnings. Signed-off-by: Ka-Cheong Poon <ka-cheong.poon@oracle.com> Acked-by: Santosh Shilimkar <santosh.shilimkar@oracle.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
a6c90dd321
commit
eee2fa6ab3
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2006 Oracle. All rights reserved.
|
||||
* Copyright (c) 2006, 2017 Oracle and/or its affiliates. All rights reserved.
|
||||
*
|
||||
* This software is available to you under a choice of one of two
|
||||
* licenses. You may choose to be licensed under the terms of the GNU
|
||||
@@ -100,18 +100,19 @@ static void rds_ib_remove_ipaddr(struct rds_ib_device *rds_ibdev, __be32 ipaddr)
|
||||
kfree_rcu(to_free, rcu);
|
||||
}
|
||||
|
||||
int rds_ib_update_ipaddr(struct rds_ib_device *rds_ibdev, __be32 ipaddr)
|
||||
int rds_ib_update_ipaddr(struct rds_ib_device *rds_ibdev,
|
||||
struct in6_addr *ipaddr)
|
||||
{
|
||||
struct rds_ib_device *rds_ibdev_old;
|
||||
|
||||
rds_ibdev_old = rds_ib_get_device(ipaddr);
|
||||
rds_ibdev_old = rds_ib_get_device(ipaddr->s6_addr32[3]);
|
||||
if (!rds_ibdev_old)
|
||||
return rds_ib_add_ipaddr(rds_ibdev, ipaddr);
|
||||
return rds_ib_add_ipaddr(rds_ibdev, ipaddr->s6_addr32[3]);
|
||||
|
||||
if (rds_ibdev_old != rds_ibdev) {
|
||||
rds_ib_remove_ipaddr(rds_ibdev_old, ipaddr);
|
||||
rds_ib_remove_ipaddr(rds_ibdev_old, ipaddr->s6_addr32[3]);
|
||||
rds_ib_dev_put(rds_ibdev_old);
|
||||
return rds_ib_add_ipaddr(rds_ibdev, ipaddr);
|
||||
return rds_ib_add_ipaddr(rds_ibdev, ipaddr->s6_addr32[3]);
|
||||
}
|
||||
rds_ib_dev_put(rds_ibdev_old);
|
||||
|
||||
@@ -544,7 +545,7 @@ void *rds_ib_get_mr(struct scatterlist *sg, unsigned long nents,
|
||||
struct rds_ib_connection *ic = rs->rs_conn->c_transport_data;
|
||||
int ret;
|
||||
|
||||
rds_ibdev = rds_ib_get_device(rs->rs_bound_addr);
|
||||
rds_ibdev = rds_ib_get_device(rs->rs_bound_addr.s6_addr32[3]);
|
||||
if (!rds_ibdev) {
|
||||
ret = -ENODEV;
|
||||
goto out;
|
||||
|
||||
Reference in New Issue
Block a user