Fix various small resource leaks and error code handling issues that Coverity pointed out. Fixes-Coverity-Bugs: 11919{39-45}, 1174118, 1049160, 1049144 Signed-off-by: Darrick J. Wong <darrick.wong@xxxxxxxxxx> --- debugfs/xattrs.c | 38 ++++++++++++++++++++------------------ lib/ext2fs/extent.c | 7 ++++--- lib/ext2fs/punch.c | 2 +- misc/create_inode.c | 34 ++++++++++++++++++++-------------- 4 files changed, 45 insertions(+), 36 deletions(-) diff --git a/debugfs/xattrs.c b/debugfs/xattrs.c index 0a29521..7109719 100644 --- a/debugfs/xattrs.c +++ b/debugfs/xattrs.c @@ -122,26 +122,26 @@ void do_get_xattr(int argc, char **argv) default: printf("%s: Usage: %s <file> <attr> [-f outfile]\n", argv[0], argv[0]); - return; + goto out2; } } if (optind != argc - 2) { printf("%s: Usage: %s <file> <attr> [-f outfile]\n", argv[0], argv[0]); - return; + goto out2; } if (check_fs_open(argv[0])) - return; + goto out2; ino = string_to_inode(argv[optind]); if (!ino) - return; + goto out2; err = ext2fs_xattrs_open(current_fs, ino, &h); if (err) - return; + goto out2; err = ext2fs_xattrs_read(h); if (err) @@ -153,18 +153,19 @@ void do_get_xattr(int argc, char **argv) if (fp) { fwrite(buf, buflen, 1, fp); - fclose(fp); } else { dump_xattr_string(stdout, buf, buflen); printf("\n"); } - if (buf) - ext2fs_free_mem(&buf); + ext2fs_free_mem(&buf); out: ext2fs_xattrs_close(&h); if (err) com_err(argv[0], err, "while getting extended attribute"); +out2: + if (fp) + fclose(fp); } void do_set_xattr(int argc, char **argv) @@ -190,30 +191,30 @@ void do_set_xattr(int argc, char **argv) default: printf("%s: Usage: %s <file> <attr> [-f infile | " "value]\n", argv[0], argv[0]); - return; + goto out2; } } if (optind != argc - 2 && optind != argc - 3) { printf("%s: Usage: %s <file> <attr> [-f infile | value>]\n", argv[0], argv[0]); - return; + goto out2; } if (check_fs_open(argv[0])) - return; + goto out2; if (check_fs_read_write(argv[0])) - return; + goto out2; if (check_fs_bitmaps(argv[0])) - return; + goto out2; ino = string_to_inode(argv[optind]); if (!ino) - return; + goto out2; err = ext2fs_xattrs_open(current_fs, ino, &h); if (err) - return; + goto out2; err = ext2fs_xattrs_read(h); if (err) @@ -238,13 +239,14 @@ void do_set_xattr(int argc, char **argv) goto out; out: + ext2fs_xattrs_close(&h); + if (err) + com_err(argv[0], err, "while setting extended attribute"); +out2: if (fp) { fclose(fp); ext2fs_free_mem(&buf); } - ext2fs_xattrs_close(&h); - if (err) - com_err(argv[0], err, "while setting extended attribute"); } void do_rm_xattr(int argc, char **argv) diff --git a/lib/ext2fs/extent.c b/lib/ext2fs/extent.c index 80ce88f..30673b5 100644 --- a/lib/ext2fs/extent.c +++ b/lib/ext2fs/extent.c @@ -1482,7 +1482,7 @@ errcode_t ext2fs_extent_set_bmap(ext2_extent_handle_t handle, if (retval) { r2 = ext2fs_extent_goto(handle, orig_lblk); if (r2 == 0) - ext2fs_extent_replace(handle, 0, + (void)ext2fs_extent_replace(handle, 0, &orig_extent); goto done; } @@ -1498,11 +1498,12 @@ errcode_t ext2fs_extent_set_bmap(ext2_extent_handle_t handle, r2 = ext2fs_extent_goto(handle, newextent.e_lblk); if (r2 == 0) - ext2fs_extent_delete(handle, 0); + (void)ext2fs_extent_delete(handle, 0); } r2 = ext2fs_extent_goto(handle, orig_lblk); if (r2 == 0) - ext2fs_extent_replace(handle, 0, &orig_extent); + (void)ext2fs_extent_replace(handle, 0, + &orig_extent); goto done; } } diff --git a/lib/ext2fs/punch.c b/lib/ext2fs/punch.c index 60cd2a3..c9250cd 100644 --- a/lib/ext2fs/punch.c +++ b/lib/ext2fs/punch.c @@ -403,7 +403,7 @@ static errcode_t ext2fs_punch_extent(ext2_filsys fs, ext2_ino_t ino, retval = 0; /* Jump forward to the next extent. */ - ext2fs_extent_goto(handle, next_lblk); + (void)ext2fs_extent_goto(handle, next_lblk); op = EXT2_EXTENT_CURRENT; } if (retval) diff --git a/misc/create_inode.c b/misc/create_inode.c index 964c66a..4bb5e5b 100644 --- a/misc/create_inode.c +++ b/misc/create_inode.c @@ -465,7 +465,7 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, char ln_target[PATH_MAX]; unsigned int save_inode; ext2_ino_t ino; - errcode_t retval; + errcode_t retval = 0; int read_cnt; int hdlink; @@ -486,7 +486,11 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, if ((!strcmp(dent->d_name, ".")) || (!strcmp(dent->d_name, ".."))) continue; - lstat(dent->d_name, &st); + if (lstat(dent->d_name, &st)) { + com_err(__func__, errno, _("while lstat \"%s\""), + dent->d_name); + goto out; + } name = dent->d_name; /* Check for hardlinks */ @@ -501,7 +505,7 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, if (retval) { com_err(__func__, retval, "while linking %s", name); - return retval; + goto out; } continue; } else @@ -517,7 +521,7 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, com_err(__func__, retval, _("while creating special file " "\"%s\""), name); - return retval; + goto out; } break; case S_IFSOCK: @@ -527,7 +531,7 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, continue; case S_IFLNK: read_cnt = readlink(name, ln_target, - sizeof(ln_target)); + sizeof(ln_target) - 1); if (read_cnt == -1) { com_err(__func__, errno, _("while trying to readlink \"%s\""), @@ -541,7 +545,7 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, com_err(__func__, retval, _("while writing symlink\"%s\""), name); - return retval; + goto out; } break; case S_IFREG: @@ -550,7 +554,7 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, if (retval) { com_err(__func__, retval, _("while writing file \"%s\""), name); - return retval; + goto out; } break; case S_IFDIR: @@ -559,25 +563,25 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, if (retval) { com_err(__func__, retval, _("while making dir \"%s\""), name); - return retval; + goto out; } retval = ext2fs_namei(fs, root, parent_ino, name, &ino); if (retval) { com_err(name, retval, 0); - return retval; + goto out; } /* Populate the dir recursively*/ retval = __populate_fs(fs, ino, name, root, hdlinks); if (retval) { com_err(__func__, retval, _("while adding dir \"%s\""), name); - return retval; + goto out; } if (chdir("..")) { com_err(__func__, errno, _("during cd ..")); - return errno; + goto out; } break; default: @@ -588,14 +592,14 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, retval = ext2fs_namei(fs, root, parent_ino, name, &ino); if (retval) { com_err(name, retval, 0); - return retval; + goto out; } retval = set_inode_extra(fs, parent_ino, ino, &st); if (retval) { com_err(__func__, retval, _("while setting inode for \"%s\""), name); - return retval; + goto out; } /* Save the hardlink ino */ @@ -612,7 +616,7 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, if (p == NULL) { com_err(name, errno, _("Not enough memory")); - return errno; + goto out; } hdlinks->hdl = p; hdlinks->size += HDLINK_CNT; @@ -623,6 +627,8 @@ static errcode_t __populate_fs(ext2_filsys fs, ext2_ino_t parent_ino, hdlinks->count++; } } + +out: closedir(dh); return retval; } -- To unsubscribe from this list: send the line "unsubscribe linux-ext4" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html