From: Christoph Hellwig Date: Wed, 18 Jan 2023 17:30:22 +0000 (+0100) Subject: minix: fix error handling in minix_delete_entry X-Git-Tag: v6.3-rc1~95^2~3 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=b61d15d5ff67c07907c194d4354ec0c35bc657d1;p=thirdparty%2Fkernel%2Flinux.git minix: fix error handling in minix_delete_entry If minix_prepare_chunk fails, updating c/mtime and marking the dir inode dirty is wrong, as the inode hasn't been modified. Signed-off-by: Christoph Hellwig Signed-off-by: Al Viro --- diff --git a/fs/minix/dir.c b/fs/minix/dir.c index ec462330e749a..242e179aa1fbe 100644 --- a/fs/minix/dir.c +++ b/fs/minix/dir.c @@ -297,18 +297,20 @@ int minix_delete_entry(struct minix_dir_entry *de, struct page *page) lock_page(page); err = minix_prepare_chunk(page, pos, len); - if (err == 0) { - if (sbi->s_version == MINIX_V3) - ((minix3_dirent *) de)->inode = 0; - else - de->inode = 0; - err = dir_commit_chunk(page, pos, len); - } else { + if (err) { unlock_page(page); + return err; } + if (sbi->s_version == MINIX_V3) + ((minix3_dirent *)de)->inode = 0; + else + de->inode = 0; + err = dir_commit_chunk(page, pos, len); + if (err) + return err; inode->i_ctime = inode->i_mtime = current_time(inode); mark_inode_dirty(inode); - return err; + return 0; } int minix_make_empty(struct inode *inode, struct inode *dir)