diff options
-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 b59ba7ccef0e..de5fe161a1b9 100644 --- a/drivers/infiniband/core/addr.c +++ b/drivers/infiniband/core/addr.c | |||
@@ -36,7 +36,6 @@ | |||
36 | #include <linux/mutex.h> | 36 | #include <linux/mutex.h> |
37 | #include <linux/inetdevice.h> | 37 | #include <linux/inetdevice.h> |
38 | #include <linux/workqueue.h> | 38 | #include <linux/workqueue.h> |
39 | #include <linux/if_arp.h> | ||
40 | #include <net/arp.h> | 39 | #include <net/arp.h> |
41 | #include <net/neighbour.h> | 40 | #include <net/neighbour.h> |
42 | #include <net/route.h> | 41 | #include <net/route.h> |
@@ -92,17 +91,7 @@ EXPORT_SYMBOL(rdma_addr_unregister_client); | |||
92 | int rdma_copy_addr(struct rdma_dev_addr *dev_addr, struct net_device *dev, | 91 | int rdma_copy_addr(struct rdma_dev_addr *dev_addr, struct net_device *dev, |
93 | const unsigned char *dst_dev_addr) | 92 | const unsigned char *dst_dev_addr) |
94 | { | 93 | { |
95 | switch (dev->type) { | 94 | dev_addr->dev_type = dev->type; |
96 | case ARPHRD_INFINIBAND: | ||
97 | dev_addr->dev_type = RDMA_NODE_IB_CA; | ||
98 | break; | ||
99 | case ARPHRD_ETHER: | ||
100 | dev_addr->dev_type = RDMA_NODE_RNIC; | ||
101 | break; | ||
102 | default: | ||
103 | return -EADDRNOTAVAIL; | ||
104 | } | ||
105 | |||
106 | memcpy(dev_addr->src_dev_addr, dev->dev_addr, MAX_ADDR_LEN); | 95 | memcpy(dev_addr->src_dev_addr, dev->dev_addr, MAX_ADDR_LEN); |
107 | memcpy(dev_addr->broadcast, dev->broadcast, MAX_ADDR_LEN); | 96 | memcpy(dev_addr->broadcast, dev->broadcast, MAX_ADDR_LEN); |
108 | if (dst_dev_addr) | 97 | if (dst_dev_addr) |
diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c index 699ad12b3a2f..b305b5c17f8d 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) | |||
330 | union ib_gid gid; | 330 | union ib_gid gid; |
331 | int ret = -ENODEV; | 331 | int ret = -ENODEV; |
332 | 332 | ||
333 | switch (rdma_node_get_transport(dev_addr->dev_type)) { | 333 | switch (dev_addr->dev_type) { |
334 | case RDMA_TRANSPORT_IB: | 334 | case ARPHRD_INFINIBAND: |
335 | ib_addr_get_sgid(dev_addr, &gid); | 335 | ib_addr_get_sgid(dev_addr, &gid); |
336 | break; | 336 | break; |
337 | case RDMA_TRANSPORT_IWARP: | 337 | case ARPHRD_ETHER: |
338 | iw_addr_get_sgid(dev_addr, &gid); | 338 | iw_addr_get_sgid(dev_addr, &gid); |
339 | break; | 339 | break; |
340 | default: | 340 | default: |
diff --git a/include/rdma/ib_addr.h b/include/rdma/ib_addr.h index 27f17cc2c919..3a39c55d2b9a 100644 --- a/include/rdma/ib_addr.h +++ b/include/rdma/ib_addr.h | |||
@@ -36,6 +36,7 @@ | |||
36 | 36 | ||
37 | #include <linux/in.h> | 37 | #include <linux/in.h> |
38 | #include <linux/in6.h> | 38 | #include <linux/in6.h> |
39 | #include <linux/if_arp.h> | ||
39 | #include <linux/netdevice.h> | 40 | #include <linux/netdevice.h> |
40 | #include <linux/socket.h> | 41 | #include <linux/socket.h> |
41 | #include <rdma/ib_verbs.h> | 42 | #include <rdma/ib_verbs.h> |
@@ -60,7 +61,7 @@ struct rdma_dev_addr { | |||
60 | unsigned char src_dev_addr[MAX_ADDR_LEN]; | 61 | unsigned char src_dev_addr[MAX_ADDR_LEN]; |
61 | unsigned char dst_dev_addr[MAX_ADDR_LEN]; | 62 | unsigned char dst_dev_addr[MAX_ADDR_LEN]; |
62 | unsigned char broadcast[MAX_ADDR_LEN]; | 63 | unsigned char broadcast[MAX_ADDR_LEN]; |
63 | enum rdma_node_type dev_type; | 64 | unsigned short dev_type; |
64 | int bound_dev_if; | 65 | int bound_dev_if; |
65 | }; | 66 | }; |
66 | 67 | ||