mbox series

[v7,0/5] Dynamic rdma link creation

Message ID cover.1544826079.git.swise@opengridcomputing.com (mailing list archive)
Headers show
Series Dynamic rdma link creation | expand

Message

Steve Wise Dec. 14, 2018, 10:21 p.m. UTC
This series enables creating soft rdma links dynamically using netlink
messages.  The user 'rdma' command [1] will be enhanced to send these new
messages.

Note there is at least one outstanding issue:  the rdma-core requires
RXE links to be named "rxe*" or it fails to associate an rxe uverbs
driver with the rxe provider.  This, however, can be addressed
in a subsequent series.

[1] rdma tool support (work-in-progress):
https://github.com/larrystevenwise/iproute2/tree/wip/newlink

Changes since V6:
- added Jason's patch to refactor device unregisteration and
  rxe reference cleanup.
- added Yuval's patch as a dependency.
- remove dellink() rdma_link_ops method replaced with
  IB_DEVICE_ALLOW_USER_UNREG device caps flag.  If set, then the core
  will unregister the device in nldev_dellink() for the driver using the
  new ib_unregister_device_and_put().
- add r-b tags.

Changes since V4/V5:
- fixed device remove races in rxe
- fixed deadlock in NETDEV_UNREGISTER induced rxe device removal
- removed redundant string checks in nldev_newlink()
- added reviewed-by tag

Changes since V3:
- link_ops mutex replaced with rwsem
- save link_ops pointer in ib_device struct to be used when deleting
  a link
- only require the device index from userland for DELLINK operations
- pass struct ib_device pointer to drivers for dellink()

Changes since V2:
- removed unneeded enum value assignment
- removed gotos where there was no unwind logic
- protect get and use of link_ops with mutex

Changes since V1:
- rebased on for-next branch of linux-rdma repo
- removed 2 pr_debug()s
- validate string lengths in nldev_newlink()/nldev_dellink()
- don't allow '%' in ibdev names
- make all string parameters const char * in rdma_link_ops
- simplified the request_module logic in nldev_newlink()
- add leon's reviewed-by tag.

Changes since RFC:
- rebased on top of leon's and jason's device name work
- request module load if the link ops aren't found
- detect duplicate link ops adds
- const char * changes
- use the RDMA_NLDEV open enum values


Jason Gunthorpe (1):
  verbs/rxe: Use core services to keep track of RXE things

Steve Wise (3):
  rdma_rxe: schedule ib_unregister_device_and_put()
  RDMA/Core: add RDMA_NLDEV_CMD_NEWLINK/DELLINK support
  rdma_rxe: use netlink messages to add/delete links

Yuval Shaia (1):
  IB/rxe: Reuse code which sets port state

 drivers/infiniband/core/core_priv.h   |   1 -
 drivers/infiniband/core/device.c      | 213 ++++++++++++++++++++++++++++++++--
 drivers/infiniband/core/nldev.c       | 122 +++++++++++++++++++
 drivers/infiniband/sw/rxe/rxe.c       |  68 ++++++-----
 drivers/infiniband/sw/rxe/rxe.h       |  17 +--
 drivers/infiniband/sw/rxe/rxe_loc.h   |   2 +-
 drivers/infiniband/sw/rxe/rxe_net.c   | 108 ++++++-----------
 drivers/infiniband/sw/rxe/rxe_net.h   |   3 +-
 drivers/infiniband/sw/rxe/rxe_param.h |   3 +-
 drivers/infiniband/sw/rxe/rxe_pool.c  |   4 -
 drivers/infiniband/sw/rxe/rxe_sysfs.c |  53 +++------
 drivers/infiniband/sw/rxe/rxe_verbs.c |  11 +-
 drivers/infiniband/sw/rxe/rxe_verbs.h |   6 +-
 include/rdma/ib_verbs.h               |  13 +++
 include/rdma/rdma_netlink.h           |  11 ++
 include/uapi/rdma/rdma_netlink.h      |  11 +-
 16 files changed, 470 insertions(+), 176 deletions(-)