diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-04-11 15:45:47 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-04-11 15:45:47 -0700 | 
| commit | a97b52022a73ec12e43f0b2c7d4bd1f40f89c81d (patch) | |
| tree | 1a35544915a5704fa59c63b43e9f46e20be1e296 /fs/jbd2 | |
| parent | 18770c7c3a0ccd60017ac76b5d2e7d1f71376b94 (diff) | |
| parent | c8205636029fc869278c55b7336053b3e7ae3ef4 (diff) | |
Merge branch 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4
* 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4:
  ext4: fix data corruption regression by reverting commit 6de9843dab3f
  ext4: Allow indirect-block file to grow the file size to max file size
  ext4: allow an active handle to be started when freezing
  ext4: sync the directory inode in ext4_sync_parent()
  ext4: init timer earlier to avoid a kernel panic in __save_error_info
  jbd2: fix potential memory leak on transaction commit
  ext4: fix a double free in ext4_register_li_request
  ext4: fix credits computing for indirect mapped files
  ext4: remove unnecessary [cm]time update of quota file
  jbd2: move bdget out of critical section
Diffstat (limited to 'fs/jbd2')
| -rw-r--r-- | fs/jbd2/commit.c | 4 | ||||
| -rw-r--r-- | fs/jbd2/journal.c | 3 | 
2 files changed, 5 insertions, 2 deletions
| diff --git a/fs/jbd2/commit.c b/fs/jbd2/commit.c index 20af62f4304..6e28000a4b2 100644 --- a/fs/jbd2/commit.c +++ b/fs/jbd2/commit.c @@ -105,6 +105,8 @@ static int journal_submit_commit_record(journal_t *journal,  	int ret;  	struct timespec now = current_kernel_time(); +	*cbh = NULL; +  	if (is_journal_aborted(journal))  		return 0; @@ -806,7 +808,7 @@ wait_for_iobuf:  		if (err)  			__jbd2_journal_abort_hard(journal);  	} -	if (!err && !is_journal_aborted(journal)) +	if (cbh)  		err = journal_wait_on_commit_record(journal, cbh);  	if (JBD2_HAS_INCOMPAT_FEATURE(journal,  				      JBD2_FEATURE_INCOMPAT_ASYNC_COMMIT) && diff --git a/fs/jbd2/journal.c b/fs/jbd2/journal.c index aba8ebaec25..e0ec3db1c39 100644 --- a/fs/jbd2/journal.c +++ b/fs/jbd2/journal.c @@ -2413,10 +2413,12 @@ const char *jbd2_dev_to_name(dev_t device)  	new_dev = kmalloc(sizeof(struct devname_cache), GFP_KERNEL);  	if (!new_dev)  		return "NODEV-ALLOCFAILURE"; /* Something non-NULL */ +	bd = bdget(device);  	spin_lock(&devname_cache_lock);  	if (devcache[i]) {  		if (devcache[i]->device == device) {  			kfree(new_dev); +			bdput(bd);  			ret = devcache[i]->devname;  			spin_unlock(&devname_cache_lock);  			return ret; @@ -2425,7 +2427,6 @@ const char *jbd2_dev_to_name(dev_t device)  	}  	devcache[i] = new_dev;  	devcache[i]->device = device; -	bd = bdget(device);  	if (bd) {  		bdevname(bd, devcache[i]->devname);  		bdput(bd); | 
