Blame SOURCES/e2fsprogs-1.42.9-14-misc-fix-Coverity-bugs.patch

1f0cb0
From df9c49cb287a9cd79ee2589ddfa3db0bc1a9d97b Mon Sep 17 00:00:00 2001
1f0cb0
From: "Darrick J. Wong" <darrick.wong@oracle.com>
1f0cb0
Date: Sat, 16 May 2015 18:32:33 -0400
1f0cb0
Subject: [PATCH 12/16] misc: fix Coverity bugs
1f0cb0
1f0cb0
commit 63cd76d6ac3bb7f90c583f240fc75e657610f2ea
1f0cb0
1f0cb0
Fix Coverity bugs 1297093, 1297096, 1297489, 1297491, 1297493,
1f0cb0
1297506, 1297507, 1297514, 1297516, and 1297517.
1f0cb0
1f0cb0
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
1f0cb0
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
1f0cb0
---
1f0cb0
 debugfs/util.c    | 2 +-
1f0cb0
 lib/e2p/feature.c | 4 ++--
1f0cb0
 lib/e2p/mntopts.c | 2 +-
1f0cb0
 misc/e4defrag.c   | 4 +++-
1f0cb0
 misc/logsave.c    | 2 +-
1f0cb0
 5 files changed, 8 insertions(+), 6 deletions(-)
1f0cb0
1f0cb0
diff --git a/debugfs/util.c b/debugfs/util.c
1f0cb0
index aafbc567..b355e5cd 100644
1f0cb0
--- a/debugfs/util.c
1f0cb0
+++ b/debugfs/util.c
1f0cb0
@@ -373,7 +373,7 @@ int common_block_args_process(int argc, char *argv[],
1f0cb0
 		return 1;
1f0cb0
 	if (*block == 0) {
1f0cb0
 		com_err(argv[0], 0, "Invalid block number 0");
1f0cb0
-		err = 1;
1f0cb0
+		return 1;
1f0cb0
 	}
1f0cb0
 
1f0cb0
 	if (argc > 2) {
1f0cb0
diff --git a/lib/e2p/feature.c b/lib/e2p/feature.c
1f0cb0
index 96912638..d4f1bf1a 100644
1f0cb0
--- a/lib/e2p/feature.c
1f0cb0
+++ b/lib/e2p/feature.c
1f0cb0
@@ -177,7 +177,7 @@ int e2p_string2feature(char *string, int *compat_type, unsigned int *mask)
1f0cb0
 	if (string[9] == 0)
1f0cb0
 		return 1;
1f0cb0
 	num = strtol(string+9, &eptr, 10);
1f0cb0
-	if (num > 32 || num < 0)
1f0cb0
+	if (num > 31 || num < 0)
1f0cb0
 		return 1;
1f0cb0
 	if (*eptr)
1f0cb0
 		return 1;
1f0cb0
@@ -251,7 +251,7 @@ int e2p_jrnl_string2feature(char *string, int *compat_type, unsigned int *mask)
1f0cb0
 	if (string[9] == 0)
1f0cb0
 		return 1;
1f0cb0
 	num = strtol(string+9, &eptr, 10);
1f0cb0
-	if (num > 32 || num < 0)
1f0cb0
+	if (num > 31 || num < 0)
1f0cb0
 		return 1;
1f0cb0
 	if (*eptr)
1f0cb0
 		return 1;
1f0cb0
diff --git a/lib/e2p/mntopts.c b/lib/e2p/mntopts.c
1f0cb0
index d56cc527..ff2e5de9 100644
1f0cb0
--- a/lib/e2p/mntopts.c
1f0cb0
+++ b/lib/e2p/mntopts.c
1f0cb0
@@ -72,7 +72,7 @@ int e2p_string2mntopt(char *string, unsigned int *mask)
1f0cb0
 	if (string[8] == 0)
1f0cb0
 		return 1;
1f0cb0
 	num = strtol(string+8, &eptr, 10);
1f0cb0
-	if (num > 32 || num < 0)
1f0cb0
+	if (num > 31 || num < 0)
1f0cb0
 		return 1;
1f0cb0
 	if (*eptr)
1f0cb0
 		return 1;
1f0cb0
diff --git a/misc/e4defrag.c b/misc/e4defrag.c
1f0cb0
index 2c2034cf..99baeb7b 100644
1f0cb0
--- a/misc/e4defrag.c
1f0cb0
+++ b/misc/e4defrag.c
1f0cb0
@@ -440,8 +440,10 @@ static int page_in_core(int fd, struct move_extent defrag_data,
1f0cb0
 	*page_num = 0;
1f0cb0
 	*page_num = (length + pagesize - 1) / pagesize;
1f0cb0
 	*vec = (unsigned char *)calloc(*page_num, 1);
1f0cb0
-	if (*vec == NULL)
1f0cb0
+	if (*vec == NULL) {
1f0cb0
+		munmap(page, length);
1f0cb0
 		return -1;
1f0cb0
+	}
1f0cb0
 
1f0cb0
 	/* Get information on whether pages are in core */
1f0cb0
 	if (mincore(page, (size_t)length, *vec) == -1 ||
1f0cb0
diff --git a/misc/logsave.c b/misc/logsave.c
1f0cb0
index 8612edfb..cd6037dd 100644
1f0cb0
--- a/misc/logsave.c
1f0cb0
+++ b/misc/logsave.c
1f0cb0
@@ -219,7 +219,7 @@ static int run_program(char **argv)
1f0cb0
 			sprintf(buffer, "died with signal %d\n",
1f0cb0
 				WTERMSIG(status));
1f0cb0
 			send_output(buffer, 0, SEND_BOTH);
1f0cb0
-			rc = 1;
1f0cb0
+			return 1;
1f0cb0
 		}
1f0cb0
 		rc = 0;
1f0cb0
 	}
1f0cb0
-- 
1f0cb0
2.20.1
1f0cb0