]> git.karo-electronics.de Git - karo-tx-linux.git/commit
ext4: discard preallocation when restarting a transaction during truncate
authorAneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
Mon, 2 Nov 2009 23:50:49 +0000 (18:50 -0500)
committerGreg Kroah-Hartman <gregkh@suse.de>
Mon, 14 Dec 2009 16:07:15 +0000 (08:07 -0800)
commitba593a59c912b3ae1f18b74d8ad66594ba3a47b6
tree1cad53b79804666f5d18d97679e7fedacd740b32
parent620c66ab00f5b06de7119fbe0cc7dba3cc9aca7d
ext4: discard preallocation when restarting a transaction during truncate

(cherry picked from commit fa5d11133b07053270e18fa9c18560e66e79217e)

When restart a transaction during a truncate operation, we drop and
reacquire i_data_sem.  After reacquiring i_data_sem, we need to
discard any inode-based preallocation that might have been grabbed
while we released i_data_sem (for example, if pdflush is allocating
blocks and racing against the truncate).

Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
fs/ext4/inode.c