[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <456BA59D.3060208@linux.vnet.ibm.com>
Date: Mon, 27 Nov 2006 18:57:33 -0800
From: suzuki <suzuki@...ux.vnet.ibm.com>
To: Andrew Morton <akpm@...l.org>
CC: amitarora@...ibm.com, "Vladimir V. Saveliev" <vs@...esys.com>,
reiserfs-list@...esys.com, reiserfs-dev@...esys.com,
lkml <linux-kernel@...r.kernel.org>, rdunlap@...otime.net
Subject: Re: [BUG] Reiserfs panic while running fsstress due to multiple truncate
"safe links" for a file.
Andrew Morton wrote:
> On Mon, 27 Nov 2006 15:37:49 -0800
> Suzuki <suzuki@...ibm.com> wrote:
>
>
>>* Do not add save links for O_DIRECT writes.
>>
>>We add a save link for O_DIRECT writes to protect the i_size against the crashes before we actually finish the I/O. If we hit an -ENOSPC in aops->prepare_write(), we would do a truncate() to release the blocks which might have got initialized. Now the truncate would add another save link for the same inode causing a reiserfs panic for having multiple save links for the same inode.
>>
>>
>
>
> OK...
>
> But how does this patch fix it? It removes a lot of code - how come we
> don't need it any more?
We were adding save links for appending writes only. The links were
removed once we finish the write operation successfully.
Now we don't add the save links at all.
May be Valdimir has better answers for this.
Thanks,
Suzuki
>
>
>>
>>Index: linux-2.6.19-rc1/fs/reiserfs/file.c
>>===================================================================
>>--- linux-2.6.19-rc1.orig/fs/reiserfs/file.c 2006-10-10 05:54:30.000000000 -0700
>>+++ linux-2.6.19-rc1/fs/reiserfs/file.c 2006-11-21 17:17:36.000000000 -0800
>>@@ -1306,56 +1306,8 @@
>> count = MAX_NON_LFS - (unsigned long)*ppos;
>> }
>>
>>- if (file->f_flags & O_DIRECT) { // Direct IO needs treatment
>>- ssize_t result, after_file_end = 0;
>>- if ((*ppos + count >= inode->i_size)
>>- || (file->f_flags & O_APPEND)) {
>>- /* If we are appending a file, we need to put this savelink in here.
>>- If we will crash while doing direct io, finish_unfinished will
>>- cut the garbage from the file end. */
>>- reiserfs_write_lock(inode->i_sb);
>>- err =
>>- journal_begin(&th, inode->i_sb,
>>- JOURNAL_PER_BALANCE_CNT);
>>- if (err) {
>>- reiserfs_write_unlock(inode->i_sb);
>>- return err;
>>- }
>>- reiserfs_update_inode_transaction(inode);
>>- add_save_link(&th, inode, 1 /* Truncate */ );
>>- after_file_end = 1;
>>- err =
>>- journal_end(&th, inode->i_sb,
>>- JOURNAL_PER_BALANCE_CNT);
>>- reiserfs_write_unlock(inode->i_sb);
>>- if (err)
>>- return err;
>>- }
>>- result = do_sync_write(file, buf, count, ppos);
>>-
>>- if (after_file_end) { /* Now update i_size and remove the savelink */
>>- struct reiserfs_transaction_handle th;
>>- reiserfs_write_lock(inode->i_sb);
>>- err = journal_begin(&th, inode->i_sb, 1);
>>- if (err) {
>>- reiserfs_write_unlock(inode->i_sb);
>>- return err;
>>- }
>>- reiserfs_update_inode_transaction(inode);
>>- mark_inode_dirty(inode);
>>- err = journal_end(&th, inode->i_sb, 1);
>>- if (err) {
>>- reiserfs_write_unlock(inode->i_sb);
>>- return err;
>>- }
>>- err = remove_save_link(inode, 1 /* truncate */ );
>>- reiserfs_write_unlock(inode->i_sb);
>>- if (err)
>>- return err;
>>- }
>>-
>>- return result;
>>- }
>>+ if (file->f_flags & O_DIRECT)
>>+ return do_sync_write(file, buf, count, ppos);
>>
>> if (unlikely((ssize_t) count < 0))
>> return -EINVAL;
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists