From: Yishai Hadas <yishaih@mellanox.com>
To: linux-rdma@vger.kernel.org, jgg@mellanox.com, dledford@redhat.com
Cc: yishaih@mellanox.com, maorg@mellanox.com, michaelgur@mellanox.com
Subject: [PATCH rdma-next 00/14] Refactoring FD usage
Date: Wed, 8 Jan 2020 19:21:52 +0200 [thread overview]
Message-ID: <1578504126-9400-1-git-send-email-yishaih@mellanox.com> (raw)
This series refactors the usage of FDs in both IB core and mlx5 driver.
It includes:
- Simplify destruction of FD uobjects by making them pure uobjects and use
a generic release method for all struct file operations.
- Make ib_uverbs_async_event_file into a uobject.
- Improve locking in few related areas.
- Simplify type usage for ib_uverbs_async_handler().
This refactoring series may be followed by some other series that will allow
the async FD to be allocated separately from the context and then enables
having the alloc_context command over ioctl.
Yishai
Jason Gunthorpe (14):
RDMA/mlx5: Use RCU and direct refcounts to keep memory alive
RDMA/core: Simplify destruction of FD uobjects
RDMA/mlx5: Simplify devx async commands
RDMA/core: Do not allow alloc_commit to fail
RDMA/core: Make ib_ucq_object use ib_uevent_object
RDMA/core: Do not erase the type of ib_cq.uobject
RDMA/core: Do not erase the type of ib_qp.uobject
RDMA/core: Do not erase the type of ib_srq.uobject
RDMA/core: Do not erase the type of ib_wq.uobject
RDMA/core: Simplify type usage for ib_uverbs_async_handler()
RDMA/core: Fix locking in ib_uverbs_event_read
RDMA/core: Remove the ufile arg from rdma_alloc_begin_uobject
RDMA/core: Make ib_uverbs_async_event_file into a uobject
RDMA/core: Use READ_ONCE for ib_ufile.async_file
drivers/infiniband/core/Makefile | 3 +-
drivers/infiniband/core/core_priv.h | 2 +-
drivers/infiniband/core/nldev.c | 3 +-
drivers/infiniband/core/rdma_core.c | 189 ++++++-------
drivers/infiniband/core/rdma_core.h | 45 +---
drivers/infiniband/core/uverbs.h | 28 +-
drivers/infiniband/core/uverbs_cmd.c | 201 +++++++-------
drivers/infiniband/core/uverbs_ioctl.c | 45 +---
drivers/infiniband/core/uverbs_main.c | 292 ++++++---------------
drivers/infiniband/core/uverbs_std_types.c | 44 +++-
.../infiniband/core/uverbs_std_types_async_fd.c | 33 +++
drivers/infiniband/core/uverbs_std_types_cq.c | 19 +-
drivers/infiniband/core/uverbs_uapi.c | 7 +-
drivers/infiniband/hw/mlx5/devx.c | 159 +++++------
include/rdma/ib_verbs.h | 13 +-
include/rdma/uverbs_std_types.h | 13 +-
include/rdma/uverbs_types.h | 33 ++-
include/uapi/rdma/ib_user_ioctl_cmds.h | 1 +
18 files changed, 494 insertions(+), 636 deletions(-)
create mode 100644 drivers/infiniband/core/uverbs_std_types_async_fd.c
--
1.8.3.1
next reply other threads:[~2020-01-08 17:22 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-01-08 17:21 Yishai Hadas [this message]
2020-01-08 17:21 ` [PATCH rdma-next 01/14] RDMA/mlx5: Use RCU and direct refcounts to keep memory alive Yishai Hadas
2020-01-08 17:21 ` [PATCH rdma-next 02/14] RDMA/core: Simplify destruction of FD uobjects Yishai Hadas
2020-01-08 17:21 ` [PATCH rdma-next 03/14] RDMA/mlx5: Simplify devx async commands Yishai Hadas
2020-01-08 17:21 ` [PATCH rdma-next 04/14] RDMA/core: Do not allow alloc_commit to fail Yishai Hadas
2020-01-08 17:21 ` [PATCH rdma-next 05/14] RDMA/core: Make ib_ucq_object use ib_uevent_object Yishai Hadas
2020-01-08 17:21 ` [PATCH rdma-next 06/14] RDMA/core: Do not erase the type of ib_cq.uobject Yishai Hadas
2020-01-08 17:21 ` [PATCH rdma-next 07/14] RDMA/core: Do not erase the type of ib_qp.uobject Yishai Hadas
2020-01-08 17:22 ` [PATCH rdma-next 08/14] RDMA/core: Do not erase the type of ib_srq.uobject Yishai Hadas
2020-01-08 17:22 ` [PATCH rdma-next 09/14] RDMA/core: Do not erase the type of ib_wq.uobject Yishai Hadas
2020-01-08 17:22 ` [PATCH rdma-next 10/14] RDMA/core: Simplify type usage for ib_uverbs_async_handler() Yishai Hadas
2020-01-08 17:22 ` [PATCH rdma-next 11/14] RDMA/core: Fix locking in ib_uverbs_event_read Yishai Hadas
2020-01-10 14:54 ` Jason Gunthorpe
2020-01-08 17:22 ` [PATCH rdma-next 12/14] RDMA/core: Remove the ufile arg from rdma_alloc_begin_uobject Yishai Hadas
2020-01-08 17:22 ` [PATCH rdma-next 13/14] RDMA/core: Make ib_uverbs_async_event_file into a uobject Yishai Hadas
2020-01-08 17:22 ` [PATCH rdma-next 14/14] RDMA/core: Use READ_ONCE for ib_ufile.async_file Yishai Hadas
2020-01-13 20:37 ` [PATCH rdma-next 00/14] Refactoring FD usage Jason Gunthorpe
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1578504126-9400-1-git-send-email-yishaih@mellanox.com \
--to=yishaih@mellanox.com \
--cc=dledford@redhat.com \
--cc=jgg@mellanox.com \
--cc=linux-rdma@vger.kernel.org \
--cc=maorg@mellanox.com \
--cc=michaelgur@mellanox.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).