1. 03 Oct, 2008 4 commits
    • Chuck Lever's avatar
      NLM: Convert nlm_lookup_host() to use a single argument · 7f1ed18b
      Chuck Lever authored
      The nlm_lookup_host() function already has a large number of arguments,
      and I'm about to add a few more.  As a clean up, convert the function
      to use a single data structure argument.
      Signed-off-by: default avatarChuck Lever <chuck.lever@oracle.com>
      Signed-off-by: default avatarJ. Bruce Fields <bfields@citi.umich.edu>
      7f1ed18b
    • J. Bruce Fields's avatar
      lockd: reject reclaims outside the grace period · d22b1cff
      J. Bruce Fields authored
      The current lockd does not reject reclaims that arrive outside of the
      grace period.
      
      Accepting a reclaim means promising to the client that no conflicting
      locks were granted since last it held the lock.  We can meet that
      promise if we assume the only lockers are nfs clients, and that they are
      sufficiently well-behaved to reclaim only locks that they held before,
      and that only reclaim locks have been permitted so far.  Once we leave
      the grace period (and start permitting non-reclaims), we can no longer
      keep that promise.  So we must start rejecting reclaims at that point.
      Signed-off-by: default avatarJ. Bruce Fields <bfields@citi.umich.edu>
      d22b1cff
    • J. Bruce Fields's avatar
      lockd: move grace period checks to common code · b2b50289
      J. Bruce Fields authored
      Do all the grace period checks in svclock.c.  This simplifies the code a
      bit, and will ease some later changes.
      Signed-off-by: default avatarJ. Bruce Fields <bfields@citi.umich.edu>
      b2b50289
    • J. Bruce Fields's avatar
      nfsd: common grace period control · af558e33
      J. Bruce Fields authored
      Rewrite grace period code to unify management of grace period across
      lockd and nfsd.  The current code has lockd and nfsd cooperate to
      compute a grace period which is satisfactory to them both, and then
      individually enforce it.  This creates a slight race condition, since
      the enforcement is not coordinated.  It's also more complicated than
      necessary.
      
      Here instead we have lockd and nfsd each inform common code when they
      enter the grace period, and when they're ready to leave the grace
      period, and allow normal locking only after both of them are ready to
      leave.
      
      We also expect the locks_start_grace()/locks_end_grace() interface here
      to be simpler to build on for future cluster/high-availability work,
      which may require (for example) putting individual filesystems into
      grace, or enforcing grace periods across multiple cluster nodes.
      Signed-off-by: default avatarJ. Bruce Fields <bfields@citi.umich.edu>
      af558e33
  2. 29 Sep, 2008 36 commits