From: Niranjana Vishwanathapura Date: Mon, 10 Apr 2017 08:22:25 +0000 (+0300) Subject: IB/IPoIB: Introduce RDMA netdev interface and IPoIB structs X-Git-Tag: v4.12-rc1~108^2~145 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=f0ad83ac58468e3807e72e929317519b69bcde1c;p=users%2Fwilly%2Fxarray.git IB/IPoIB: Introduce RDMA netdev interface and IPoIB structs Add RDMA netdev interface to ib device structure allowing RDMA netdev devices to be allocated by ib clients. The idea is to allow to providers to optimize IPoIB data path. New struct that includes functions and data member is exposed. It exposes set of callback functions for handling data path flows in IPoIB driver. Each provider can support these set of functions in order to optimize its specific data path, and let IPoIB to leverage its data path. There is an assumption, that providers should give the full set of functions and not only part of them, in order to work properly. Signed-off-by: Erez Shitrit Signed-off-by: Niranjana Vishwanathapura Signed-off-by: Leon Romanovsky Signed-off-by: Doug Ledford --- diff --git a/include/rdma/ib_verbs.h b/include/rdma/ib_verbs.h index 5d5c0a918798..16f15ea8606e 100644 --- a/include/rdma/ib_verbs.h +++ b/include/rdma/ib_verbs.h @@ -1881,7 +1881,8 @@ struct ib_port_immutable { /* rdma netdev type - specifies protocol type */ enum rdma_netdev_t { - RDMA_NETDEV_OPA_VNIC + RDMA_NETDEV_OPA_VNIC, + RDMA_NETDEV_IPOIB, }; /** @@ -1895,6 +1896,15 @@ struct rdma_netdev { /* control functions */ void (*set_id)(struct net_device *netdev, int id); + /* send packet */ + int (*send)(struct net_device *dev, struct sk_buff *skb, + struct ib_ah *address, u32 dqpn); + /* multicast */ + int (*attach_mcast)(struct net_device *dev, struct ib_device *hca, + union ib_gid *gid, u16 mlid, + int set_qkey, u32 qkey); + int (*detach_mcast)(struct net_device *dev, struct ib_device *hca, + union ib_gid *gid, u16 mlid); }; struct ib_device {