GFS2: Make rename not save dirent location
authorBob Peterson <rpeterso@redhat.com>
Mon, 29 Sep 2014 12:52:04 +0000 (08:52 -0400)
committerSteven Whitehouse <swhiteho@redhat.com>
Wed, 1 Oct 2014 13:06:15 +0000 (14:06 +0100)
commit19aeb5a65f1a6504fc665466c188241e7393d66f
treeed2f2cb66536ab4dfa5b1c2bffe9780889ad369c
parent00a158be83839f2d5370612d633eb2643ddf844e
GFS2: Make rename not save dirent location

This patch fixes a regression in the patch "GFS2: Remember directory
insert point", commit 2b47dad866d04f14c328f888ba5406057b8c7d33.
The problem had to do with the rename function: The function found
space for the new dirent, and remembered that location. But then the
old dirent was removed, which often moved the eligible location for
the renamed dirent. Putting the new dirent at the saved location
caused file system corruption.

This patch adds a new "save_loc" variable to struct gfs2_diradd.
If 1, the dirent location is saved. If 0, the dirent location is not
saved and the buffer_head is released as per previous behavior.

Signed-off-by: Bob Peterson <rpeterso@redhat.com>
Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
fs/gfs2/dir.c
fs/gfs2/dir.h
fs/gfs2/inode.c