diff options
| author | Sean Hefty <sean.hefty@intel.com> | 2009-11-19 12:57:18 -0800 | 
|---|---|---|
| committer | Roland Dreier <rolandd@cisco.com> | 2009-11-19 12:57:18 -0800 | 
| commit | c4315d85f9b76834289fd503796c01b8311c4b84 (patch) | |
| tree | 12a74b92f3b00c8d515811e131c850402cd1588a | |
| parent | d2e0886245aa9eebc1a4710c861d263b09eac493 (diff) | |
| download | olio-linux-3.10-c4315d85f9b76834289fd503796c01b8311c4b84.tar.xz olio-linux-3.10-c4315d85f9b76834289fd503796c01b8311c4b84.zip  | |
IB/addr: Store net_device type instead of translating to RDMA transport
The struct rdma_dev_addr stores net_device address information:
the source device address, destination hardware address, and
broadcast address.  For consistency, store the net_device type
rather than converting it to the rdma_node_type.
The type indicates the format of the various hardware addresses,
which is what we're concerned with, and not the RDMA node type
that the address may map to.
Signed-off-by: Sean Hefty <sean.hefty@intel.com>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
| -rw-r--r-- | drivers/infiniband/core/addr.c | 13 | ||||
| -rw-r--r-- | drivers/infiniband/core/cma.c | 6 | ||||
| -rw-r--r-- | include/rdma/ib_addr.h | 3 | 
3 files changed, 6 insertions, 16 deletions
diff --git a/drivers/infiniband/core/addr.c b/drivers/infiniband/core/addr.c index b59ba7ccef0..de5fe161a1b 100644 --- a/drivers/infiniband/core/addr.c +++ b/drivers/infiniband/core/addr.c @@ -36,7 +36,6 @@  #include <linux/mutex.h>  #include <linux/inetdevice.h>  #include <linux/workqueue.h> -#include <linux/if_arp.h>  #include <net/arp.h>  #include <net/neighbour.h>  #include <net/route.h> @@ -92,17 +91,7 @@ EXPORT_SYMBOL(rdma_addr_unregister_client);  int rdma_copy_addr(struct rdma_dev_addr *dev_addr, struct net_device *dev,  		     const unsigned char *dst_dev_addr)  { -	switch (dev->type) { -	case ARPHRD_INFINIBAND: -		dev_addr->dev_type = RDMA_NODE_IB_CA; -		break; -	case ARPHRD_ETHER: -		dev_addr->dev_type = RDMA_NODE_RNIC; -		break; -	default: -		return -EADDRNOTAVAIL; -	} - +	dev_addr->dev_type = dev->type;  	memcpy(dev_addr->src_dev_addr, dev->dev_addr, MAX_ADDR_LEN);  	memcpy(dev_addr->broadcast, dev->broadcast, MAX_ADDR_LEN);  	if (dst_dev_addr) diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c index 699ad12b3a2..b305b5c17f8 100644 --- a/drivers/infiniband/core/cma.c +++ b/drivers/infiniband/core/cma.c @@ -330,11 +330,11 @@ static int cma_acquire_dev(struct rdma_id_private *id_priv)  	union ib_gid gid;  	int ret = -ENODEV; -	switch (rdma_node_get_transport(dev_addr->dev_type)) { -	case RDMA_TRANSPORT_IB: +	switch (dev_addr->dev_type) { +	case ARPHRD_INFINIBAND:  		ib_addr_get_sgid(dev_addr, &gid);  		break; -	case RDMA_TRANSPORT_IWARP: +	case ARPHRD_ETHER:  		iw_addr_get_sgid(dev_addr, &gid);  		break;  	default: diff --git a/include/rdma/ib_addr.h b/include/rdma/ib_addr.h index 27f17cc2c91..3a39c55d2b9 100644 --- a/include/rdma/ib_addr.h +++ b/include/rdma/ib_addr.h @@ -36,6 +36,7 @@  #include <linux/in.h>  #include <linux/in6.h> +#include <linux/if_arp.h>  #include <linux/netdevice.h>  #include <linux/socket.h>  #include <rdma/ib_verbs.h> @@ -60,7 +61,7 @@ struct rdma_dev_addr {  	unsigned char src_dev_addr[MAX_ADDR_LEN];  	unsigned char dst_dev_addr[MAX_ADDR_LEN];  	unsigned char broadcast[MAX_ADDR_LEN]; -	enum rdma_node_type dev_type; +	unsigned short dev_type;  	int bound_dev_if;  };  |