diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-29 05:00:19 +0400 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-29 05:00:19 +0400 | 
| commit | 67d2433ee7aa631bc3ab14c2af6bbc1d44d13a00 (patch) | |
| tree | eb29e1489f9f4a99308e08568328de73fb89fc2e /fs/btrfs/tree-log.c | |
| parent | 1c36ab1a318ab5b3b502e7e4fff3628d1a97861f (diff) | |
| parent | 9998eb703490589c3e8f1bf09b15203156776edb (diff) | |
| download | linux-67d2433ee7aa631bc3ab14c2af6bbc1d44d13a00.tar.xz | |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/linux-btrfs
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/linux-btrfs:
  Btrfs: fix reservations in btrfs_page_mkwrite
  Btrfs: advance window_start if we're using a bitmap
  btrfs: mask out gfp flags in releasepage
  Btrfs: fix enospc error caused by wrong checks of the chunk
  Btrfs: do not defrag a file partially
  Btrfs: fix warning for 32-bit build of fs/btrfs/check-integrity.c
  Btrfs: use cluster->window_start when allocating from a cluster bitmap
  Btrfs: Check for NULL page in extent_range_uptodate
  btrfs: Fix busyloops in transaction waiting code
  Btrfs: make sure a bitmap has enough bytes
  Btrfs: fix uninit warning in backref.c
Diffstat (limited to 'fs/btrfs/tree-log.c')
| -rw-r--r-- | fs/btrfs/tree-log.c | 6 | 
1 files changed, 4 insertions, 2 deletions
diff --git a/fs/btrfs/tree-log.c b/fs/btrfs/tree-log.c index cb877e0886a7..966cc74f5d6c 100644 --- a/fs/btrfs/tree-log.c +++ b/fs/btrfs/tree-log.c @@ -1957,7 +1957,8 @@ static int wait_log_commit(struct btrfs_trans_handle *trans,  		finish_wait(&root->log_commit_wait[index], &wait);  		mutex_lock(&root->log_mutex); -	} while (root->log_transid < transid + 2 && +	} while (root->fs_info->last_trans_log_full_commit != +		 trans->transid && root->log_transid < transid + 2 &&  		 atomic_read(&root->log_commit[index]));  	return 0;  } @@ -1966,7 +1967,8 @@ static int wait_for_writer(struct btrfs_trans_handle *trans,  			   struct btrfs_root *root)  {  	DEFINE_WAIT(wait); -	while (atomic_read(&root->log_writers)) { +	while (root->fs_info->last_trans_log_full_commit != +	       trans->transid && atomic_read(&root->log_writers)) {  		prepare_to_wait(&root->log_writer_wait,  				&wait, TASK_UNINTERRUPTIBLE);  		mutex_unlock(&root->log_mutex);  | 
