From fe4dd429dc878d877abe08c2c41eed48df4e4651 Mon Sep 17 00:00:00 2001 From: Theodore Ts'o Date: Mon, 29 Jul 2002 19:26:33 -0400 Subject: [PATCH] link.c (ext2fs_link): When adding a new link to a directory, clear the HTREE bit. --- lib/ext2fs/ChangeLog | 5 +++++ lib/ext2fs/link.c | 19 ++++++++++++++++--- 2 files changed, 21 insertions(+), 3 deletions(-) diff --git a/lib/ext2fs/ChangeLog b/lib/ext2fs/ChangeLog index c946de5..c8a00eb 100644 --- a/lib/ext2fs/ChangeLog +++ b/lib/ext2fs/ChangeLog @@ -1,3 +1,8 @@ +2002-07-29 Theodore Ts'o + + * link.c (ext2fs_link): When adding a new link to a directory, + clear the HTREE bit. + 2002-07-23 Theodore Ts'o * dirhash.c (ext2fs_dirhash): Fix bug which caused MD4 diff --git a/lib/ext2fs/link.c b/lib/ext2fs/link.c index 04ac00c..5e0f4f3 100644 --- a/lib/ext2fs/link.c +++ b/lib/ext2fs/link.c @@ -97,8 +97,9 @@ static int link_proc(struct ext2_dir_entry *dirent, errcode_t ext2fs_link(ext2_filsys fs, ext2_ino_t dir, const char *name, ext2_ino_t ino, int flags) { - errcode_t retval; - struct link_struct ls; + errcode_t retval; + struct link_struct ls; + struct ext2_inode inode; EXT2_CHECK_MAGIC(fs, EXT2_ET_MAGIC_EXT2FS_FILSYS); @@ -117,5 +118,17 @@ errcode_t ext2fs_link(ext2_filsys fs, ext2_ino_t dir, const char *name, if (retval) return retval; - return (ls.done) ? 0 : EXT2_ET_DIR_NO_SPACE; + if (!ls.done) + return EXT2_ET_DIR_NO_SPACE; + + if ((retval = ext2fs_read_inode(fs, dir, &inode)) != 0) + return retval; + + if (inode.i_flags & EXT2_INDEX_FL) { + inode.i_flags &= ~EXT2_INDEX_FL; + if ((retval = ext2fs_write_inode(fs, dir, &inode)) != 0) + return retval; + } + + return 0; } -- 1.8.3.1