opal/keyval: fix coverity issues
CID 1292738 Dereference after null check (FORWARD_NULL) It is an error if NULL is passed for val in add_to_env_str. Removed the NULL-check @ keyval_parse.c:253 and added a NULL check and an error return. CID 1292737 Logically dead code (DEADCODE) Coverity is correct, the error code at the end of parse_line_new is never reached. This means we fail to report parsing errors when parsing -x and -mca lines in keyval files. I moved the error code into the loop and removed the checks @ keyval_parse.c:314. I also named the parse state enum type and updated parse_line_new to use this type. Signed-off-by: Nathan Hjelm <hjelmn@lanl.gov>
Этот коммит содержится в:
родитель
9e56ef0da9
Коммит
f5389cbb03
@ -54,7 +54,7 @@ extern int opal_util_keyval_yylineno;
|
|||||||
#define YY_NO_UNPUT 1
|
#define YY_NO_UNPUT 1
|
||||||
#define YY_SKIP_YYWRAP 1
|
#define YY_SKIP_YYWRAP 1
|
||||||
|
|
||||||
enum {
|
enum opal_keyval_parse_state_t {
|
||||||
OPAL_UTIL_KEYVAL_PARSE_DONE,
|
OPAL_UTIL_KEYVAL_PARSE_DONE,
|
||||||
OPAL_UTIL_KEYVAL_PARSE_ERROR,
|
OPAL_UTIL_KEYVAL_PARSE_ERROR,
|
||||||
|
|
||||||
@ -68,5 +68,6 @@ enum {
|
|||||||
|
|
||||||
OPAL_UTIL_KEYVAL_PARSE_MAX
|
OPAL_UTIL_KEYVAL_PARSE_MAX
|
||||||
};
|
};
|
||||||
|
typedef enum opal_keyval_parse_state_t opal_keyval_parse_state_t;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,3 +1,23 @@
|
|||||||
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
||||||
|
* University Research and Technology
|
||||||
|
* Corporation. All rights reserved.
|
||||||
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
||||||
|
* of Tennessee Research Foundation. All rights
|
||||||
|
* reserved.
|
||||||
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
||||||
|
* University of Stuttgart. All rights reserved.
|
||||||
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
||||||
|
* All rights reserved.
|
||||||
|
* Copyright (c) 2015 Los Alamos National Security, LLC. All rights
|
||||||
|
* reserved.
|
||||||
|
* $COPYRIGHT$
|
||||||
|
*
|
||||||
|
* Additional copyrights may follow
|
||||||
|
*
|
||||||
|
* $HEADER$
|
||||||
|
*/
|
||||||
|
|
||||||
#include "opal_config.h"
|
#include "opal_config.h"
|
||||||
|
|
||||||
@ -19,7 +39,7 @@ static size_t key_buffer_len = 0;
|
|||||||
static opal_mutex_t keyval_mutex;
|
static opal_mutex_t keyval_mutex;
|
||||||
|
|
||||||
static int parse_line(void);
|
static int parse_line(void);
|
||||||
static int parse_line_new(int first_val);
|
static int parse_line_new(opal_keyval_parse_state_t first_val);
|
||||||
static void parse_error(int num);
|
static void parse_error(int num);
|
||||||
|
|
||||||
static char *env_str = NULL;
|
static char *env_str = NULL;
|
||||||
@ -249,31 +269,45 @@ static int save_param_name(const char* prefix, const char* suffix)
|
|||||||
static int add_to_env_str(char *var, char *val)
|
static int add_to_env_str(char *var, char *val)
|
||||||
{
|
{
|
||||||
int sz, varsz, valsz;
|
int sz, varsz, valsz;
|
||||||
|
void *tmp;
|
||||||
|
|
||||||
|
if (NULL == var) {
|
||||||
|
return OPAL_ERR_BAD_PARAM;
|
||||||
|
}
|
||||||
|
|
||||||
if (NULL != env_str) {
|
if (NULL != env_str) {
|
||||||
varsz = (NULL != var) ? strlen(var) : 0;
|
varsz = strlen(var);
|
||||||
valsz = (NULL != val) ? strlen(val) : 0;
|
valsz = (NULL != val) ? strlen(val) : 0;
|
||||||
sz = strlen(env_str)+varsz+valsz+2;
|
sz = strlen(env_str)+varsz+valsz+2;
|
||||||
if (envsize <= sz) {
|
if (envsize <= sz) {
|
||||||
envsize *=2;
|
envsize *=2;
|
||||||
env_str = realloc(env_str, envsize);
|
|
||||||
memset(env_str + strlen(env_str), 0, envsize/2);
|
tmp = realloc(env_str, envsize);
|
||||||
|
if (NULL == tmp) {
|
||||||
|
return OPAL_ERR_OUT_OF_RESOURCE;
|
||||||
|
}
|
||||||
|
env_str = tmp;
|
||||||
}
|
}
|
||||||
strcat(env_str, ";");
|
strcat(env_str, ";");
|
||||||
} else {
|
} else {
|
||||||
env_str = malloc(envsize);
|
env_str = calloc(1, envsize);
|
||||||
memset(env_str, 0, envsize);
|
if (NULL == env_str) {
|
||||||
|
return OPAL_ERR_OUT_OF_RESOURCE;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
strcat(env_str, var);
|
strcat(env_str, var);
|
||||||
if (NULL != val) {
|
if (NULL != val) {
|
||||||
strcat(env_str, "=");
|
strcat(env_str, "=");
|
||||||
strcat(env_str, val);
|
strcat(env_str, val);
|
||||||
}
|
}
|
||||||
return 0;
|
|
||||||
|
return OPAL_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int parse_line_new(int first_val)
|
static int parse_line_new(opal_keyval_parse_state_t first_val)
|
||||||
{
|
{
|
||||||
int val;
|
opal_keyval_parse_state_t val;
|
||||||
char *tmp;
|
char *tmp;
|
||||||
|
|
||||||
val = first_val;
|
val = first_val;
|
||||||
@ -307,16 +341,14 @@ static int parse_line_new(int first_val)
|
|||||||
} else if (OPAL_UTIL_KEYVAL_PARSE_ENVVAR == val) {
|
} else if (OPAL_UTIL_KEYVAL_PARSE_ENVVAR == val) {
|
||||||
save_param_name("-x", "=");
|
save_param_name("-x", "=");
|
||||||
add_to_env_str(key_buffer, NULL);
|
add_to_env_str(key_buffer, NULL);
|
||||||
|
} else {
|
||||||
|
/* we got something unexpected. Bonk! */
|
||||||
|
parse_error(6);
|
||||||
|
return OPAL_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
val = opal_util_keyval_yylex();
|
val = opal_util_keyval_yylex();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (OPAL_UTIL_KEYVAL_PARSE_DONE == val ||
|
|
||||||
OPAL_UTIL_KEYVAL_PARSE_NEWLINE == val) {
|
|
||||||
return OPAL_SUCCESS;
|
return OPAL_SUCCESS;
|
||||||
}
|
|
||||||
|
|
||||||
/* Nope -- we got something unexpected. Bonk! */
|
|
||||||
parse_error(6);
|
|
||||||
return OPAL_ERROR;
|
|
||||||
}
|
}
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user