GFS2: Update to AIL list locking
The previous patch missed a couple of places where the AIL list needed locking, so this fixes up those places, plus a comment is corrected too. Signed-off-by: Steven Whitehouse <swhiteho@redhat.com> Cc: Dave Chinner <dchinner@redhat.com>
This commit is contained in:
parent
d6a079e82e
commit
c618e87a5f
@ -67,7 +67,7 @@ unsigned int gfs2_struct2blk(struct gfs2_sbd *sdp, unsigned int nstruct,
|
|||||||
* @mapping: The associated mapping (maybe NULL)
|
* @mapping: The associated mapping (maybe NULL)
|
||||||
* @bd: The gfs2_bufdata to remove
|
* @bd: The gfs2_bufdata to remove
|
||||||
*
|
*
|
||||||
* The log lock _must_ be held when calling this function
|
* The ail lock _must_ be held when calling this function
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -51,8 +51,10 @@ static void gfs2_pin(struct gfs2_sbd *sdp, struct buffer_head *bh)
|
|||||||
/* If this buffer is in the AIL and it has already been written
|
/* If this buffer is in the AIL and it has already been written
|
||||||
* to in-place disk block, remove it from the AIL.
|
* to in-place disk block, remove it from the AIL.
|
||||||
*/
|
*/
|
||||||
|
spin_lock(&sdp->sd_ail_lock);
|
||||||
if (bd->bd_ail)
|
if (bd->bd_ail)
|
||||||
list_move(&bd->bd_ail_st_list, &bd->bd_ail->ai_ail2_list);
|
list_move(&bd->bd_ail_st_list, &bd->bd_ail->ai_ail2_list);
|
||||||
|
spin_unlock(&sdp->sd_ail_lock);
|
||||||
get_bh(bh);
|
get_bh(bh);
|
||||||
atomic_inc(&sdp->sd_log_pinned);
|
atomic_inc(&sdp->sd_log_pinned);
|
||||||
trace_gfs2_pin(bd, 1);
|
trace_gfs2_pin(bd, 1);
|
||||||
|
@ -326,6 +326,7 @@ void gfs2_remove_from_journal(struct buffer_head *bh, struct gfs2_trans *tr, int
|
|||||||
brelse(bh);
|
brelse(bh);
|
||||||
}
|
}
|
||||||
if (bd) {
|
if (bd) {
|
||||||
|
spin_lock(&sdp->sd_ail_lock);
|
||||||
if (bd->bd_ail) {
|
if (bd->bd_ail) {
|
||||||
gfs2_remove_from_ail(bd);
|
gfs2_remove_from_ail(bd);
|
||||||
bh->b_private = NULL;
|
bh->b_private = NULL;
|
||||||
@ -333,6 +334,7 @@ void gfs2_remove_from_journal(struct buffer_head *bh, struct gfs2_trans *tr, int
|
|||||||
bd->bd_blkno = bh->b_blocknr;
|
bd->bd_blkno = bh->b_blocknr;
|
||||||
gfs2_trans_add_revoke(sdp, bd);
|
gfs2_trans_add_revoke(sdp, bd);
|
||||||
}
|
}
|
||||||
|
spin_unlock(&sdp->sd_ail_lock);
|
||||||
}
|
}
|
||||||
clear_buffer_dirty(bh);
|
clear_buffer_dirty(bh);
|
||||||
clear_buffer_uptodate(bh);
|
clear_buffer_uptodate(bh);
|
||||||
|
Loading…
Reference in New Issue
Block a user