1. 28 3月, 2015 1 次提交
  2. 10 2月, 2015 1 次提交
  3. 09 2月, 2015 1 次提交
    • T
      SUNRPC: Add helpers to prevent socket create from racing · 718ba5b8
      Trond Myklebust 提交于
      The socket lock is currently held by the task that is requesting the
      connection be established. While that is efficient in the case where
      the connection happens quickly, it is racy in the case where it doesn't.
      What we really want is for the connect helper to be able to block access
      to the socket while it is being set up.
      
      This patch does so by arranging to transfer the socket lock from the
      task that is requesting the connect attempt, and then releasing that
      lock once everything is done.
      This scheme also gives us automatic protection against collisions with
      the RPC close code, so we can kill the cancel_delayed_work_sync()
      call in xs_close().
      Signed-off-by: NTrond Myklebust <trond.myklebust@primarydata.com>
      718ba5b8
  4. 28 11月, 2014 1 次提交
  5. 25 11月, 2014 2 次提交
  6. 18 7月, 2014 1 次提交
  7. 03 7月, 2014 1 次提交
  8. 04 6月, 2014 1 次提交
  9. 18 4月, 2014 1 次提交
  10. 30 3月, 2014 1 次提交
  11. 15 1月, 2014 1 次提交
  12. 01 1月, 2014 1 次提交
  13. 29 10月, 2013 1 次提交
  14. 02 10月, 2013 5 次提交
  15. 26 4月, 2013 1 次提交
    • J
      SUNRPC: allow disabling idle timeout · 33d90ac0
      J. Bruce Fields 提交于
      In the gss-proxy case we don't want to have to reconnect at random--we
      want to connect only on gss-proxy startup when we can steal gss-proxy's
      context to do the connect in the right namespace.
      
      So, provide a flag that allows the rpc_create caller to turn off the
      idle timeout.
      Signed-off-by: NJ. Bruce Fields <bfields@redhat.com>
      33d90ac0
  16. 15 4月, 2013 1 次提交
  17. 23 2月, 2013 1 次提交
  18. 01 2月, 2013 5 次提交
  19. 09 1月, 2013 1 次提交
    • T
      SUNRPC: Ensure we release the socket write lock if the rpc_task exits early · 87ed5003
      Trond Myklebust 提交于
      If the rpc_task exits while holding the socket write lock before it has
      allocated an rpc slot, then the usual mechanism for releasing the write
      lock in xprt_release() is defeated.
      
      The problem occurs if the call to xprt_lock_write() initially fails, so
      that the rpc_task is put on the xprt->sending wait queue. If the task
      exits after being assigned the lock by __xprt_lock_write_func, but
      before it has retried the call to xprt_lock_and_alloc_slot(), then
      it calls xprt_release() while holding the write lock, but will
      immediately exit due to the test for task->tk_rqstp != NULL.
      Reported-by: NChris Perl <chris.perl@gmail.com>
      Signed-off-by: NTrond Myklebust <Trond.Myklebust@netapp.com>
      Cc: stable@vger.kernel.org [>= 3.1]
      87ed5003
  20. 29 9月, 2012 1 次提交
  21. 07 9月, 2012 1 次提交
    • T
      SUNRPC: Fix a UDP transport regression · f39c1bfb
      Trond Myklebust 提交于
      Commit 43cedbf0 (SUNRPC: Ensure that
      we grab the XPRT_LOCK before calling xprt_alloc_slot) is causing
      hangs in the case of NFS over UDP mounts.
      
      Since neither the UDP or the RDMA transport mechanism use dynamic slot
      allocation, we can skip grabbing the socket lock for those transports.
      Add a new rpc_xprt_op to allow switching between the TCP and UDP/RDMA
      case.
      
      Note that the NFSv4.1 back channel assigns the slot directly
      through rpc_run_bc_task, so we can ignore that case.
      Reported-by: NDick Streefland <dick.streefland@altium.nl>
      Signed-off-by: NTrond Myklebust <Trond.Myklebust@netapp.com>
      Cc: stable@vger.kernel.org [>= 3.1]
      f39c1bfb
  22. 11 7月, 2012 1 次提交
  23. 20 5月, 2012 1 次提交
  24. 17 5月, 2012 1 次提交
  25. 16 4月, 2012 1 次提交
  26. 03 3月, 2012 1 次提交
  27. 18 2月, 2012 1 次提交
  28. 17 2月, 2012 1 次提交
    • A
      SUNRPC: add sending,pending queue and max slot to xprt stats · 15a45206
      Andy Adamson 提交于
      With static RPC slots, the xprt backlog queue stats were useful in showing
      when the transport (TCP) was starved by lack of RPC slots. The new dynamic
      RPC slot code, commit d9ba131d, always
      provides an RPC slot and so only uses the xprt backlog queue when the
      tcp_max_slot_table_entries value has been hit or when an allocation error
      occurs. All requests are now placed on the xprt sending or pending queue which
      need to be monitored for debugging.
      
      The max_slot stat shows the maximum number of dynamic RPC slots reached which is
      useful when debugging performance issues.
      
      Add the new fields at the end of the mountstats xprt stanza so that mountstats
      outputs the previous correct values and ignores the new fields. Bump
      NFS_IOSTATS_VERS.
      Signed-off-by: NAndy Adamson <andros@netapp.com>
      Signed-off-by: NTrond Myklebust <Trond.Myklebust@netapp.com>
      15a45206
  29. 07 2月, 2012 1 次提交
  30. 01 2月, 2012 1 次提交
  31. 02 12月, 2011 1 次提交