lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
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

Powered by Openwall GNU/*/Linux Powered by OpenVZ