|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
From e2bd2af6e4f9323cf732563b430ef02e075fc804 Mon Sep 17 00:00:00 2001
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
From: Boris Fiuczynski <fiuczy@linux.ibm.com>
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Date: Thu, 13 Aug 2020 16:03:45 +0200
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Subject: [PATCH] tools: avoid potential null pointer dereference by GCC 10
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
MIME-Version: 1.0
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Content-Type: text/plain; charset=UTF-8
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Content-Transfer-Encoding: 8bit
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
GCC 10 complains about "arg" possibly being a NULL dereference.
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Even though it might be a false positive, we can easily avoid it.
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Avoiding
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
../tools/vsh.c: In function ‘vshCommandOptStringReq’:
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
../tools/vsh.c:1034:19: error: potential null pointer dereference [-Werror=null-dereference]
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
1034 | else if (!*arg->data && !(arg->def->flags & VSH_OFLAG_EMPTY_OK))
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
| ~~~^~~~~~
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Signed-off-by: Boris Fiuczynski <fiuczy@linux.ibm.com>
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Reviewed-by: Marc Hartmayer <mhartmay@linux.ibm.com>
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
Reviewed-by: Erik Skultety <eskultet@redhat.com>
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
---
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
tools/vsh.c | 2 +-
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
diff --git a/tools/vsh.c b/tools/vsh.c
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
index 5e2e3ac219..11f493f969 100644
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
--- a/tools/vsh.c
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
+++ b/tools/vsh.c
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
@@ -1031,7 +1031,7 @@ vshCommandOptStringReq(vshControl *ctl,
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
/* this should not be propagated here, just to be sure */
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
if (ret == -1)
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
error = N_("Mandatory option not present");
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
- else if (!*arg->data && !(arg->def->flags & VSH_OFLAG_EMPTY_OK))
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
+ else if (arg && !*arg->data && !(arg->def->flags & VSH_OFLAG_EMPTY_OK))
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
error = N_("Option argument is empty");
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
if (error) {
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
--
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
GitLab
|
|
data:image/s3,"s3://crabby-images/c7e40/c7e40b2c344bc5061f27209570850cee80bcb59c" alt="" |
15c305 |
|