All of lore.kernel.org
 help / color / mirror / Atom feed
From: Chuck Lever <chuck.lever@oracle.com>
To: bfields@fieldses.org
Cc: linux-nfs@vger.kernel.org, linux-rdma@vger.kernel.org
Subject: [PATCH v1 00/16] NFS/RDMA server patches maybe for v5.7
Date: Thu, 27 Feb 2020 19:30:24 -0500	[thread overview]
Message-ID: <158284930886.38468.17045380766660946827.stgit@seurat29.1015granger.net> (raw)

Hey Bruce-

Here's the part of the RFC patch series I recently sent out that is
likely to be ready for the v5.7 merge window. These need a little
more soak-time. Please review them and let me know if there's
something terribly objectionable.

Again, the direction of the larger series is eventual support for
the server's RPC/RDMA transport to deal correctly with multiple
Write chunks in an RPC. Today the server transport supports only
one Write chunk per RPC. That's somewhat less than compliant with
RFC 8166, though good enough for any operation the Linux NFS/RDMA
client uses, and most every operation Solaris can send.

The patches below are clean-ups and optimizations that prepare the
way for multi-Write chunk support.

---

Chuck Lever (16):
      nfsd: Fix NFSv4 READ on RDMA when using readv
      NFSD: Clean up nfsd4_encode_readv
      svcrdma: Fix double svc_rdma_send_ctxt_put() in an error path
      SUNRPC: Add xdr_pad_size() helper
      svcrdma: Create a generic tracing class for displaying xdr_buf layout
      svcrdma: Remove svcrdma_cm_event() trace point
      svcrdma: Use struct xdr_stream to decode ingress transport headers
      svcrdma: De-duplicate code that locates Write and Reply chunks
      svcrdma: Update synopsis of svc_rdma_send_reply_chunk()
      svcrdma: Update synopsis of svc_rdma_map_reply_msg()
      svcrdma: Update synopsis of svc_rdma_send_reply_msg()
      svcrdma: Rename svcrdma_encode trace points in send routines
      SUNRPC: Add encoders for list item discriminators
      svcrdma: Refactor chunk list encoders
      svcrdma: Fix double sync of transport header buffer
      svcrdma: Avoid DMA mapping small RPC Replies


 fs/nfsd/nfs4xdr.c                          |   29 +-
 include/linux/sunrpc/rpc_rdma.h            |    3 
 include/linux/sunrpc/svc.h                 |    3 
 include/linux/sunrpc/svc_rdma.h            |   23 +
 include/linux/sunrpc/svc_xprt.h            |    2 
 include/linux/sunrpc/xdr.h                 |   54 +++
 include/trace/events/rpcrdma.h             |   67 ++--
 include/trace/events/sunrpc.h              |   43 ++
 net/sunrpc/auth_gss/auth_gss.c             |    4 
 net/sunrpc/auth_gss/svcauth_gss.c          |    4 
 net/sunrpc/svc.c                           |   16 +
 net/sunrpc/svc_xprt.c                      |    6 
 net/sunrpc/svcsock.c                       |    8 
 net/sunrpc/xprt.c                          |    4 
 net/sunrpc/xprtrdma/rpc_rdma.c             |   39 --
 net/sunrpc/xprtrdma/svc_rdma_backchannel.c |   16 +
 net/sunrpc/xprtrdma/svc_rdma_recvfrom.c    |  248 +++++++++-----
 net/sunrpc/xprtrdma/svc_rdma_rw.c          |   55 ++-
 net/sunrpc/xprtrdma/svc_rdma_sendto.c      |  504 ++++++++++++++++------------
 net/sunrpc/xprtrdma/svc_rdma_transport.c   |    8 
 20 files changed, 693 insertions(+), 443 deletions(-)

--
Chuck Lever

             reply	other threads:[~2020-02-28  0:30 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-02-28  0:30 Chuck Lever [this message]
2020-02-28  0:30 ` [PATCH v1 01/16] nfsd: Fix NFSv4 READ on RDMA when using readv Chuck Lever
2020-02-28  0:30 ` [PATCH v1 02/16] NFSD: Clean up nfsd4_encode_readv Chuck Lever
2020-02-28  0:30 ` [PATCH v1 03/16] svcrdma: Fix double svc_rdma_send_ctxt_put() in an error path Chuck Lever
2020-02-28  0:30 ` [PATCH v1 04/16] SUNRPC: Add xdr_pad_size() helper Chuck Lever
2020-02-28  0:30 ` [PATCH v1 05/16] svcrdma: Create a generic tracing class for displaying xdr_buf layout Chuck Lever
2020-02-28 22:02   ` Fwd: " Chuck Lever
2020-02-28  0:31 ` [PATCH v1 06/16] svcrdma: Remove svcrdma_cm_event() trace point Chuck Lever
2020-02-28  0:31 ` [PATCH v1 07/16] svcrdma: Use struct xdr_stream to decode ingress transport headers Chuck Lever
2020-02-28  0:31 ` [PATCH v1 08/16] svcrdma: De-duplicate code that locates Write and Reply chunks Chuck Lever
2020-02-28  0:31 ` [PATCH v1 09/16] svcrdma: Update synopsis of svc_rdma_send_reply_chunk() Chuck Lever
2020-02-28  0:31 ` [PATCH v1 10/16] svcrdma: Update synopsis of svc_rdma_map_reply_msg() Chuck Lever
2020-02-28  0:31 ` [PATCH v1 11/16] svcrdma: Update synopsis of svc_rdma_send_reply_msg() Chuck Lever
2020-02-28  0:31 ` [PATCH v1 12/16] svcrdma: Rename svcrdma_encode trace points in send routines Chuck Lever
2020-02-28  0:31 ` [PATCH v1 13/16] SUNRPC: Add encoders for list item discriminators Chuck Lever
2020-02-28  0:32 ` [PATCH v1 14/16] svcrdma: Refactor chunk list encoders Chuck Lever
2020-02-28  0:32 ` [PATCH v1 15/16] svcrdma: Fix double sync of transport header buffer Chuck Lever
2020-02-28  0:32 ` [PATCH v1 16/16] svcrdma: Avoid DMA mapping small RPC Replies Chuck Lever

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=158284930886.38468.17045380766660946827.stgit@seurat29.1015granger.net \
    --to=chuck.lever@oracle.com \
    --cc=bfields@fieldses.org \
    --cc=linux-nfs@vger.kernel.org \
    --cc=linux-rdma@vger.kernel.org \
    /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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.