1. 07 Dec, 2006 2 commits
    • Patrick Caulfield's avatar
      [DLM] Clean up lowcomms · ac33d071
      Patrick Caulfield authored
      This fixes up most of the things pointed out by akpm and Pavel Machek
      with comments below indicating why some things have been left:
      
      Andrew Morton wrote:
      >
      >> +static struct nodeinfo *nodeid2nodeinfo(int nodeid, gfp_t alloc)
      >> +{
      >> +	struct nodeinfo *ni;
      >> +	int r;
      >> +	int n;
      >> +
      >> +	down_read(&nodeinfo_lock);
      >
      > Given that this function can sleep, I wonder if `alloc' is useful.
      >
      > I see lots of callers passing in a literal "0" for `alloc'.  That's in fact
      > a secret (GFP_ATOMIC & ~__GFP_HIGH).  I doubt if that's what you really
      > meant.  Particularly as the code could at least have used __GFP_WAIT (aka
      > GFP_NOIO) which is much, much more reliable than "0".  In fact "0" is the
      > least reliable mode possible.
      >
      > IOW, this is all bollixed up.
      
      When 0 is passed into nodeid2nodeinfo the function does not try to allocate a
      new structure at all. it's an indication that the caller only wants the nodeinfo
      struct for that nodeid if there actually is one in existance.
      I've tidied the function itself so it's more obvious, (and tidier!)
      
      >> +/* Data received from remote end */
      >> +static int receive_from_sock(void)
      >> +{
      >> +	int ret = 0;
      >> +	struct msghdr msg;
      >> +	struct kvec iov[2];
      >> +	unsigned len;
      >> +	int r;
      >> +	struct sctp_sndrcvinfo *sinfo;
      >> +	struct cmsghdr *cmsg;
      >> +	struct nodeinfo *ni;
      >> +
      >> +	/* These two are marginally too big for stack allocation, but this
      >> +	 * function is (currently) only called by dlm_recvd so static should be
      >> +	 * OK.
      >> +	 */
      >> +	static struct sockaddr_storage msgname;
      >> +	static char incmsg[CMSG_SPACE(sizeof(struct sctp_sndrcvinfo))];
      >
      > whoa.  This is globally singly-threaded code??
      
      Yes. it is only ever run in the context of dlm_recvd.
      >>
      >> +static void initiate_association(int nodeid)
      >> +{
      >> +	struct sockaddr_storage rem_addr;
      >> +	static char outcmsg[CMSG_SPACE(sizeof(struct sctp_sndrcvinfo))];
      >
      > Another static buffer to worry about.  Globally singly-threaded code?
      
      Yes. Only ever called by dlm_sendd.
      
      >> +
      >> +/* Send a message */
      >> +static int send_to_sock(struct nodeinfo *ni)
      >> +{
      >> +	int ret = 0;
      >> +	struct writequeue_entry *e;
      >> +	int len, offset;
      >> +	struct msghdr outmsg;
      >> +	static char outcmsg[CMSG_SPACE(sizeof(struct sctp_sndrcvinfo))];
      >
      > Singly-threaded?
      
      Yep.
      
      >>
      >> +static void dealloc_nodeinfo(void)
      >> +{
      >> +	int i;
      >> +
      >> +	for (i=1; i<=max_nodeid; i++) {
      >> +		struct nodeinfo *ni = nodeid2nodeinfo(i, 0);
      >> +		if (ni) {
      >> +			idr_remove(&nodeinfo_idr, i);
      >
      > Didn't that need locking?
      
      Not. it's only ever called at DLM shutdown after all the other threads
      have been stopped.
      
      >>
      >> +static int write_list_empty(void)
      >> +{
      >> +	int status;
      >> +
      >> +	spin_lock_bh(&write_nodes_lock);
      >> +	status = list_empty(&write_nodes);
      >> +	spin_unlock_bh(&write_nodes_lock);
      >> +
      >> +	return status;
      >> +}
      >
      > This function's return value is meaningless.  As soon as the lock gets
      > dropped, the return value can get out of sync with reality.
      >
      > Looking at the caller, this _might_ happen to be OK, but it's a nasty and
      > dangerous thing.  Really the locking should be moved into the caller.
      
      It's just an optimisation to allow the caller to schedule if there is no work
      to do. if something arrives immediately afterwards then it will get picked up
      when the process re-awakes (and it will be woken by that arrival).
      
      The 'accepting' atomic has gone completely. as Andrew pointed out it didn't
      really achieve much anyway. I suspect it was a plaster over some other
      startup or shutdown bug to be honest.
      Signed-off-by: default avatarPatrick Caulfield <pcaulfie@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      Cc: Andrew Morton <akpm@osdl.org>
      Cc: Pavel Machek <pavel@ucw.cz>
      ac33d071
    • Steven Whitehouse's avatar
      [GFS2] Change gfs2_fsync() to use write_inode_now() · 34126f9f
      Steven Whitehouse authored
      This is a bit better than the previous version of gfs2_fsync()
      although it would be better still if we were able to call a
      function which only wrote the inode & metadata. Its no big deal
      though that this will potentially write the data as well since
      the VFS has already done that before calling gfs2_fsync(). I've
      also added a comment to explain whats going on here.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      Cc: Andrew Morton <akpm@osdl.org>
      34126f9f
  2. 05 Dec, 2006 1 commit
    • Steven Whitehouse's avatar
      [GFS2] Fix indent in recovery.c · 887bc5d0
      Steven Whitehouse authored
      As per comments from Andrew Morton and Jan Engelhardt, this fixes the
      indent and removes the "static" from a variable declaration since its
      not needed in this case (now allocated on the stack of the function
      in question).
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      Cc: Jan Engelhardt <jengelh@linux01.gwdg.de>
      Cc: Andrew Morton <akpm@osdl.org>
      887bc5d0
  3. 30 Nov, 2006 37 commits
    • Steven Whitehouse's avatar
      [GFS2] Don't flush everything on fdatasync · 33c3de32
      Steven Whitehouse authored
      The gfs2_fsync() function was doing a journal flush on each
      and every call. While this is correct, its also a lot of
      overhead. This patch means that on fdatasync flushes we
      rely on the VFS to flush the data for us and we don't do
      a journal flush unless we really need to.
      
      We have to do a journal flush for stuffed files though because
      they have the data and the inode metadata in the same block.
      Journaled files also need a journal flush too of course.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      33c3de32
    • Steven Whitehouse's avatar
      [GFS2] Add a comment about reading the super block · aac1a3c7
      Steven Whitehouse authored
      The comment explains why we use the bio functions to read
      the super block.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      Cc: Andrew Morton <akpm@osdl.org>
      Cc: Srinivasa Ds <srinivasa@in.ibm.com>
      aac1a3c7
    • Srinivasa Ds's avatar
      [GFS2] Mount problem with the GFS2 code · 0da3585e
      Srinivasa Ds authored
        While mounting the gfs2 filesystem,our test team had a problem and we
      got this error message.
      =======================================================
      
      GFS2: fsid=: Trying to join cluster "lock_nolock", "dasde1"
      GFS2: fsid=dasde1.0: Joined cluster. Now mounting FS...
      GFS2: not a GFS2 filesystem
      GFS2: fsid=dasde1.0: can't read superblock: -22
      
      ==========================================================================
      On debugging further we found that problem is while reading the super
      block(gfs2_read_super) and comparing the magic number in it.
      When I  replace the submit_bio() call(present in gfs2_read_super) with
      the sb_getblk() and ll_rw_block(), mount operation succeded.
      On further analysis we found that before calling submit_bio(),
      bio->bi_sector was set to "sector" variable. This "sector" variable has
      the same value of bh->b_blocknr(block number). Hence there is a need to
      multiply this valuwith (blocksize >> 9)(9 because,sector size
      2^9,samething happens in ll_rw_block also, before calling submit_bio()).
      So I have developed the patch which solves this problem. Please let me
      know your comments.
      ================================================================
      Signed-off-by: default avatarSrinivasa DS <srinivasa@in.ibm.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      0da3585e
    • Steven Whitehouse's avatar
      [GFS2] Remove gfs2_check_acl() · 77386e1f
      Steven Whitehouse authored
      As pointed out by Adrian Bunk, the gfs2_check_acl() function is no
      longer used. This patch removes it and renamed gfs2_check_acl_locked()
      to gfs2_check_acl() since we only need one variant of that function now.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      Cc: Adrian Bunk <bunk@stusta.de>
      77386e1f
    • Ryusuke Konishi's avatar
      [DLM] fix format warnings in rcom.c and recoverd.c · 57adf7ee
      Ryusuke Konishi authored
      This fixes the following gcc warnings generated on
      the architectures where uint64_t != unsigned long long (e.g. ppc64).
      
      fs/dlm/rcom.c:154: warning: format '%llx' expects type 'long long unsigned int', but argument 4 has type 'uint64_t'
      fs/dlm/rcom.c:154: warning: format '%llx' expects type 'long long unsigned int', but argument 5 has type 'uint64_t'
      fs/dlm/recoverd.c:48: warning: format '%llx' expects type 'long long unsigned int', but argument 3 has type 'uint64_t'
      fs/dlm/recoverd.c:202: warning: format '%llx' expects type 'long long unsigned int', but argument 3 has type 'uint64_t'
      fs/dlm/recoverd.c:210: warning: format '%llx' expects type 'long long unsigned int', but argument 3 has type 'uint64_t'
      Signed-off-by: default avatarRyusuke Konishi <ryusuke@osrg.net>
      Signed-off-by: default avatarPatrick Caulfield <pcaulfie@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      57adf7ee
    • Randy Dunlap's avatar
      [GFS2] lock function parameter · 0ac23069
      Randy Dunlap authored
      Fix function parameter typing:
      fs/gfs2/glock.c:100: warning: function declaration isn't a prototype
      Signed-off-by: default avatarRandy Dunlap <randy.dunlap@oracle.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      0ac23069
    • David Teigland's avatar
      [DLM] don't accept replies to old recovery messages · 98f176fb
      David Teigland authored
      We often abort a recovery after sending a status request to a remote node.
      We want to ignore any potential status reply we get from the remote node.
      If we get one of these unwanted replies, we've often moved on to the next
      recovery message and incremented the message sequence counter, so the
      reply will be ignored due to the seq number.  In some cases, we've not
      moved on to the next message so the seq number of the reply we want to
      ignore is still correct, causing the reply to be accepted.  The next
      recovery message will then mistake this old reply as a new one.
      
      To fix this, we add the flag RCOM_WAIT to indicate when we can accept a
      new reply.  We clear this flag if we abort recovery while waiting for a
      reply.  Before the flag is set again (to allow new replies) we know that
      any old replies will be rejected due to their sequence number.  We also
      initialize the recovery-message sequence number to a random value when a
      lockspace is first created.  This makes it clear when messages are being
      rejected from an old instance of a lockspace that has since been
      recreated.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      98f176fb
    • David Teigland's avatar
      [DLM] fix size of STATUS_REPLY message · 1babdb45
      David Teigland authored
      When the not_ready routine sends a "fake" status reply with blank status
      flags, it needs to use the correct size for a normal STATUS_REPLY by
      including the size of the would-be config parameters.  We also fill in the
      non-existant config parameters with an invalid lvblen value so it's easier
      to notice if these invalid paratmers are ever being used.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      1babdb45
    • Ryusuke Konishi's avatar
      [GFS2] fs/gfs2/log.c:log_bmap() fix printk format warning · aed3255f
      Ryusuke Konishi authored
      Fix a printk format warning in fs/gfs2/log.c:
      fs/gfs2/log.c:322: warning: format '%llu' expects type 'long long unsigned int', but argument 3 has type 'sector_t'
      Signed-off-by: default avatarRyusuke Konishi <ryusuke@osrg.net>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      aed3255f
    • David Teigland's avatar
      [DLM] fix add_requestqueue checking nodes list · 2896ee37
      David Teigland authored
      Requests that arrive after recovery has started are saved in the
      requestqueue and processed after recovery is done.  Some of these requests
      are purged during recovery if they are from nodes that have been removed.
      We move the purging of the requests (dlm_purge_requestqueue) to later in
      the recovery sequence which allows the routine saving requests
      (dlm_add_requestqueue) to avoid filtering out requests by nodeid since the
      same will be done by the purge.  The current code has add_requestqueue
      filtering by nodeid but doesn't hold any locks when accessing the list of
      current nodes.  This also means that we need to call the purge routine
      when the lockspace is being shut down since the add routine will not be
      rejecting requests itself any more.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      2896ee37
    • Steven Whitehouse's avatar
      [GFS2] Fix recursive locking in gfs2_getattr · dcf3dd85
      Steven Whitehouse authored
      The readdirplus NFS operation can result in gfs2_getattr being
      called with the glock already held. In this case we do not want
      to try and grab the lock again.
      
      This fixes Red Hat bugzilla #215727
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      dcf3dd85
    • Steven Whitehouse's avatar
      [GFS2] Fix recursive locking in gfs2_permission · 300c7d75
      Steven Whitehouse authored
      Since gfs2_permission may be called either from the VFS (in which case
      we need to obtain a shared glock) or from GFS2 (in which case we already
      have a glock) we need to test to see whether or not a lock is required.
      The original test was buggy due to a potential race. This one should
      be safe.
      
      This fixes Red Hat bugzilla #217129
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      300c7d75
    • Steven Whitehouse's avatar
      [GFS2] Reduce number of arguments to meta_io.c:getbuf() · cb4c0313
      Steven Whitehouse authored
      Since the superblock and the address_space are determined by the
      glock, we might as well just pass that as the argument since all
      the callers already have that available.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      cb4c0313
    • Steven Whitehouse's avatar
      [GFS2] Move gfs2_meta_syncfs() into log.c · a25311c8
      Steven Whitehouse authored
      By moving gfs2_meta_syncfs() into log.c, gfs2_ail1_start()
      can be made static.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      a25311c8
    • Steven Whitehouse's avatar
      [GFS2] Fix journal flush problem · b004157a
      Steven Whitehouse authored
      This fixes a bug which resulted in poor performance due to flushing
      the journal too often. The code path in question was via the inode_go_sync()
      function in glops.c. The solution is not to flush the journal immediately
      when inodes are ejected from memory, but batch up the work for glockd to
      deal with later on. This means that glocks may now live on beyond the end of
      the lifetime of their inodes (but not very much longer in the normal case).
      
      Also fixed in this patch is a bug (which was hidden by the bug mentioned above) in
      calculation of the number of free journal blocks.
      
      The gfs2_logd process has been altered to be more responsive to the journal
      filling up. We now wake it up when the number of uncommitted journal blocks
      has reached the threshold level rather than trying to flush directly at the
      end of each transaction. This again means doing fewer, but larger, log
      flushes in general.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      b004157a
    • Steven Whitehouse's avatar
      [GFS2] mark_inode_dirty after write to stuffed file · ae619320
      Steven Whitehouse authored
      Writes to stuffed files were not being marked dirty correctly.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      ae619320
    • Steven Whitehouse's avatar
      [GFS2] Fix glock ordering on inode creation · 28626e20
      Steven Whitehouse authored
      The lock order here should be parent -> child rather than
      numeric order.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      28626e20
    • Steven Whitehouse's avatar
      [GFS2] Simplify glops functions · 1a14d3a6
      Steven Whitehouse authored
      The go_sync callback took two flags, but one of them was set on every
      call, so this patch removes once of the flags and makes the previously
      conditional operations (on this flag), unconditional.
      
      The go_inval callback took three flags, each of which was set on every
      call to it. This patch removes the flags and makes the operations
      unconditional, which makes the logic rather more obvious.
      
      Two now unused flags are also removed from incore.h.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      1a14d3a6
    • Steven Whitehouse's avatar
      [GFS2] Fix Kconfig wrt CRC32 · fa2ecfc5
      Steven Whitehouse authored
      GFS2 requires the CRC32 library function. This was reported by
      Toralf Förster.
      
      Cc: Toralf Förster <toralf.foerster@gmx.de>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      fa2ecfc5
    • Steven Whitehouse's avatar
      [GFS2] Make sentinel dirents compatible with gfs1 · 5e7d65cd
      Steven Whitehouse authored
      When deleting directory entries, we set the inum.no_addr to zero
      in a dirent when its the first dirent in a block and thus cannot
      be merged into the previous dirent as is the usual case. In gfs1,
      inum.no_formal_ino was used instead.
      
      This patch changes gfs2 to set both inum.no_addr and inum.no_formal_ino
      to zero. It also changes the test from just looking at inum.no_addr to
      look at both inum.no_addr and inum.no_formal_ino and a sentinel is
      now considered to be a dirent in which _either_ (or both) of them
      is set to zero.
      
      This resolves Red Hat bugzillas: #215809, #211465
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      5e7d65cd
    • Steven Whitehouse's avatar
      [GFS2] Remove unused function from inode.c · dcd24799
      Steven Whitehouse authored
      The gfs2_glock_nq_m_atime function is unused in so far as its only
      ever called with num_gh = 1, and this falls through to the
      gfs2_glock_nq_atime function, so we might as well call that directly.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      dcd24799
    • Steven Whitehouse's avatar
      [GFS2] Remove unused sysfs files · 175011cf
      Steven Whitehouse authored
      Four of the sysfs files are unused and can therefore be removed.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      175011cf
    • Steven Whitehouse's avatar
      [GFS2] Tidy up bmap & fix boundary bug · 4cf1ed81
      Steven Whitehouse authored
      This moves the locking for bmap into the bmap function itself
      rather than using a wrapper function. It also fixes a bug where
      the boundary flag was set on the wrong bh. Also the flags on
      the mapped bh are reset earlier in the function to ensure that
      they are 100% correct on the error path.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      4cf1ed81
    • Steven Whitehouse's avatar
      [GFS2] Fix memory allocation in glock.c · ab923031
      Steven Whitehouse authored
      Change from GFP_KERNEL to GFP_NOFS as this was causing a
      slow down when trying to push inodes from cache.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      ab923031
    • Patrick Caulfield's avatar
      [DLM] Fix DLM config · b98c95af
      Patrick Caulfield authored
      The attached patch fixes the DLM config so that it selects the chosen network
      transport. It should fix the bug where DLM can be left selected when NET gets
      unselected. This incorporates all the comments received about this patch.
      
      Cc: Adrian Bunk <bunk@stusta.de>
      Cc: Andrew Morton <akpm@osdl.org>
      Signed-Off-By: default avatarPatrick Caulfield <pcaulfie@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      b98c95af
    • David Teigland's avatar
      [DLM] clear sbflags on lock master · 6f90a8b1
      David Teigland authored
      RH BZ 211622
      
      The ALTMODE flag can be set in the lock master's copy of the lock but
      never cleared, so ALTMODE will also be returned in a subsequent conversion
      of the lock when it shouldn't be.  This results in lock_dlm incorrectly
      switching to the alternate lock mode when returning the result to gfs
      which then asserts when it sees the wrong lock state.  The fix is to
      propagate the cleared sbflags value to the master node when the lock is
      requested.  QA's d_rwrandirectlarge test triggers this bug very quickly.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      6f90a8b1
    • David Teigland's avatar
      [DLM] do full recover_locks barrier · 4b77f2c9
      David Teigland authored
      Red Hat BZ 211914
      
      The previous patch "[DLM] fix aborted recovery during
      node removal" was incomplete as discovered with further testing.  It set
      the bit for the RS_LOCKS barrier but did not then wait for the barrier.
      This is often ok, but sometimes it will cause yet another recovery hang.
      If it's a new node that also has the lowest nodeid that skips the barrier
      wait, then it misses the important step of collecting and reporting the
      barrier status from the other nodes (which is the job of the low nodeid in
      the barrier wait routine).
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      4b77f2c9
    • David Teigland's avatar
      [DLM] fix stopping unstarted recovery · 2cdc98aa
      David Teigland authored
      Red Hat BZ 211914
      
      When many nodes are joining a lockspace simultaneously, the dlm gets a
      quick sequence of stop/start events, a pair for adding each node.
      dlm_controld in user space sends dlm_recoverd in the kernel each stop and
      start event.  dlm_controld will sometimes send the stop before
      dlm_recoverd has had a chance to take up the previously queued start.  The
      stop aborts the processing of the previous start by setting the
      RECOVERY_STOP flag.  dlm_recoverd is erroneously clearing this flag and
      ignoring the stop/abort if it happens to take up the start after the stop
      meant to abort it.  The fix is to check the sequence number that's
      incremented for each stop/start before clearing the flag.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      2cdc98aa
    • David Teigland's avatar
      [DLM] fix aborted recovery during node removal · 91c0dc93
      David Teigland authored
      Red Hat BZ 211914
      
      With the new cluster infrastructure, dlm recovery for a node removal can
      be aborted and restarted for a node addition.  When this happens, the
      restarted recovery isn't aware that it's doing recovery for the earlier
      removal as well as the addition.  So, it then skips the recovery steps
      only required when nodes are removed.  This can result in locks not being
      purged for failed/removed nodes.  The fix is to check for removed nodes
      for which recovery has not been completed at the start of a new recovery
      sequence.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      91c0dc93
    • David Teigland's avatar
      [DLM] fix requestqueue race · d4400156
      David Teigland authored
      Red Hat BZ 211914
      
      There's a race between dlm_recoverd (1) enabling locking and (2) clearing
      out the requestqueue, and dlm_recvd (1) checking if locking is enabled and
      (2) adding a message to the requestqueue.  An order of recoverd(1),
      recvd(1), recvd(2), recoverd(2) will result in a message being left on the
      requestqueue.  The fix is to have dlm_recvd check if dlm_recoverd has
      enabled locking after taking the mutex for the requestqueue and if it has
      processing the message instead of queueing it.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      d4400156
    • David Teigland's avatar
      [DLM] status messages ping-pong between unmounted nodes · 435618b7
      David Teigland authored
      Red Hat BZ 213682
      
      If two nodes leave the lockspace (while unmounting the fs in the case of
      gfs) after one has sent a STATUS message to the other, STATUS/STATUS_REPLY
      messages will then ping-pong between the nodes when neither of them can
      find the lockspace in question any longer.  We kill this by not sending
      another STATUS message when we get a STATUS_REPLY for an unknown
      lockspace.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      435618b7
    • David Teigland's avatar
      [DLM] res_recover_locks_count not reset when recover_locks is aborted · 52069809
      David Teigland authored
      Red Hat BZ 213684
      
      If a node sends an lkb to the new master (RCOM_LOCK message) during
      recovery and recovery is then aborted on both nodes before it gets a
      reply, the res_recover_locks_count needs to be reset to 0 so that when the
      subsequent recovery comes along and sends the lkb to the new master again
      the assertion doesn't trigger that checks that counter is zero.
      Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      52069809
    • Patrick Caulfield's avatar
      [DLM] Add support for tcp communications · fdda387f
      Patrick Caulfield authored
      The following patch adds a TCP based communications layer
      to the DLM which is compile time selectable. The existing SCTP
      layer gives the advantage of allowing multihoming, whereas
      the TCP layer has been heavily tested in previous versions of
      the DLM and is known to be robust and therefore can be used as
      a baseline for performance testing.
      Signed-off-by: default avatarPatrick Caulfield <pcaulfie@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      fdda387f
    • Russell Cattelan's avatar
      [GFS2] Remove unused zero_readpage from stuffed_readpage · 61057c6b
      Russell Cattelan authored
      Stuffed files only consist of a maximum of
      (gfs2 block size - sizeof(struct gfs2_dinode)) bytes. Since the
      gfs2 block size is always less than page size, we will never see
      a call to stuffed_readpage for anything other than the first page
      in the file.
      Signed-off-by: default avatarRussell Cattelan <cattelan@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      61057c6b
    • Russell Cattelan's avatar
      [GFS2] Fix race in logging code · 70209331
      Russell Cattelan authored
      The log lock is dropped prior to io submittion, but
      this exposes a hole in which the log data structures
      may be going away due to a truncate.
      Store the buffer head in a local pointer prior to
      dropping the lock and relay on the buffer_head lock
      for consitency on the buffer head.
      Signed-Off-By: default avatarRussell Cattelan <cattelan@redhat.com>
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      70209331
    • Steven Whitehouse's avatar
      [GFS2] Remove gfs2_inode_attr_in · 9e2dbdac
      Steven Whitehouse authored
      This function wasn't really doing the right thing. There was no need
      to update the inode size at this point and the updating of the
      i_blocks field has now been moved to the places where di_blocks is
      updated. A result of this patch and some those preceeding it is that
      unlocking a glock is now a much more efficient process, since there
      is no longer any requirement to copy data from the gfs2 inode into
      the vfs inode at this point.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      9e2dbdac
    • Steven Whitehouse's avatar
      [GFS2] Inode number is constant · e7c698d7
      Steven Whitehouse authored
      Since the inode number is constant, we don't need to keep updating
      it everytime we refresh the other inode fields.
      Signed-off-by: default avatarSteven Whitehouse <swhiteho@redhat.com>
      e7c698d7