ECC-1165: Assertion: calling codes_set_bytes with incorrect length passed in

This commit is contained in:
Shahram Najm 2020-11-19 21:19:55 +00:00
parent 07582f04db
commit 4b46a70b4c
1 changed files with 19 additions and 15 deletions

View File

@ -171,7 +171,7 @@ static void init(grib_accessor* a, const long len, grib_arguments* param)
s_len = sizeof(tmp); s_len = sizeof(tmp);
p = grib_expression_evaluate_string(grib_handle_of_accessor(a), expression, tmp, &s_len, &ret); p = grib_expression_evaluate_string(grib_handle_of_accessor(a), expression, tmp, &s_len, &ret);
if (ret != GRIB_SUCCESS) { if (ret != GRIB_SUCCESS) {
grib_context_log(a->context, GRIB_LOG_ERROR, "unable to evaluate %s as string", a->name); grib_context_log(a->context, GRIB_LOG_ERROR, "Unable to evaluate %s as string", a->name);
Assert(0); Assert(0);
} }
s_len = strlen(p) + 1; s_len = strlen(p) + 1;
@ -243,14 +243,12 @@ static int unpack_bytes(grib_accessor* a, unsigned char* val, size_t* len)
long length = grib_byte_count(a); long length = grib_byte_count(a);
long offset = grib_byte_offset(a); long offset = grib_byte_offset(a);
if (*len < length) { if (*len < length) {
grib_context_log(a->context, GRIB_LOG_ERROR, "Wrong size for %s it is %d bytes long\n", a->name, length); grib_context_log(a->context, GRIB_LOG_ERROR, "Wrong size for %s it is %d bytes long\n", a->name, length);
*len = length; *len = length;
return GRIB_ARRAY_TOO_SMALL; return GRIB_ARRAY_TOO_SMALL;
} }
memcpy(val, buf + offset, length); memcpy(val, buf + offset, length);
*len = length; *len = length;
@ -279,7 +277,7 @@ static int unpack_long(grib_accessor* a, long* v, size_t* len)
*v = GRIB_MISSING_LONG; *v = GRIB_MISSING_LONG;
else else
*v = (long)val; *v = (long)val;
grib_context_log(a->context, GRIB_LOG_DEBUG, " Casting double %s to long", a->name); grib_context_log(a->context, GRIB_LOG_DEBUG, "Casting double %s to long", a->name);
return GRIB_SUCCESS; return GRIB_SUCCESS;
} }
@ -292,7 +290,7 @@ static int unpack_long(grib_accessor* a, long* v, size_t* len)
*v = strtol(val, &last, 10); *v = strtol(val, &last, 10);
if (*last == 0) { if (*last == 0) {
grib_context_log(a->context, GRIB_LOG_DEBUG, " Casting string %s to long", a->name); grib_context_log(a->context, GRIB_LOG_DEBUG, "Casting string %s to long", a->name);
return GRIB_SUCCESS; return GRIB_SUCCESS;
} }
} }
@ -312,7 +310,7 @@ static int unpack_double(grib_accessor* a, double* v, size_t* len)
size_t l = 1; size_t l = 1;
grib_unpack_long(a, &val, &l); grib_unpack_long(a, &val, &l);
*v = val; *v = val;
grib_context_log(a->context, GRIB_LOG_DEBUG, " Casting long %s to double", a->name); grib_context_log(a->context, GRIB_LOG_DEBUG, "Casting long %s to double", a->name);
return GRIB_SUCCESS; return GRIB_SUCCESS;
} }
@ -325,7 +323,7 @@ static int unpack_double(grib_accessor* a, double* v, size_t* len)
*v = strtod(val, &last); *v = strtod(val, &last);
if (*last == 0) { if (*last == 0) {
grib_context_log(a->context, GRIB_LOG_DEBUG, " Casting string %s to long", a->name); grib_context_log(a->context, GRIB_LOG_DEBUG, "Casting string %s to long", a->name);
return GRIB_SUCCESS; return GRIB_SUCCESS;
} }
} }
@ -346,7 +344,7 @@ static int unpack_string(grib_accessor* a, char* v, size_t* len)
grib_unpack_double(a, &val, &l); grib_unpack_double(a, &val, &l);
sprintf(v, "%g", val); sprintf(v, "%g", val);
*len = strlen(v); *len = strlen(v);
grib_context_log(a->context, GRIB_LOG_DEBUG, " Casting double %s to string", a->name); grib_context_log(a->context, GRIB_LOG_DEBUG, "Casting double %s to string", a->name);
return GRIB_SUCCESS; return GRIB_SUCCESS;
} }
@ -356,7 +354,7 @@ static int unpack_string(grib_accessor* a, char* v, size_t* len)
grib_unpack_long(a, &val, &l); grib_unpack_long(a, &val, &l);
sprintf(v, "%ld", val); sprintf(v, "%ld", val);
*len = strlen(v); *len = strlen(v);
grib_context_log(a->context, GRIB_LOG_DEBUG, " Casting long %s to string \n", a->name); grib_context_log(a->context, GRIB_LOG_DEBUG, "Casting long %s to string \n", a->name);
return GRIB_SUCCESS; return GRIB_SUCCESS;
} }
@ -392,7 +390,7 @@ static int pack_expression(grib_accessor* a, grib_expression* e)
len = 1; len = 1;
ret = grib_expression_evaluate_long(hand, e, &lval); ret = grib_expression_evaluate_long(hand, e, &lval);
if (ret != GRIB_SUCCESS) { if (ret != GRIB_SUCCESS) {
grib_context_log(a->context, GRIB_LOG_ERROR, "unable to set %s as long", a->name); grib_context_log(a->context, GRIB_LOG_ERROR, "Unable to set %s as long", a->name);
return ret; return ret;
} }
/*if (hand->context->debug) /*if (hand->context->debug)
@ -434,7 +432,7 @@ static int pack_long(grib_accessor* a, const long* v, size_t* len)
double* val = (double*)grib_context_malloc(c, *len * (sizeof(double))); double* val = (double*)grib_context_malloc(c, *len * (sizeof(double)));
if (!val) { if (!val) {
grib_context_log(c, GRIB_LOG_ERROR, grib_context_log(c, GRIB_LOG_ERROR,
"unable to allocate %d bytes\n", (int)(*len * (sizeof(double)))); "Unable to allocate %d bytes\n", (int)(*len * (sizeof(double))));
return GRIB_OUT_OF_MEMORY; return GRIB_OUT_OF_MEMORY;
} }
for (i = 0; i < *len; i++) for (i = 0; i < *len; i++)
@ -443,7 +441,7 @@ static int pack_long(grib_accessor* a, const long* v, size_t* len)
grib_context_free(c, val); grib_context_free(c, val);
return ret; return ret;
} }
grib_context_log(c, GRIB_LOG_ERROR, " Should not grib_pack %s as long", a->name); grib_context_log(c, GRIB_LOG_ERROR, "Should not grib_pack %s as long", a->name);
Assert(0); Assert(0);
return GRIB_NOT_IMPLEMENTED; return GRIB_NOT_IMPLEMENTED;
} }
@ -456,7 +454,7 @@ static int pack_double_array_as_long(grib_accessor* a, const double* v, size_t*
size_t numBytes = *len * (sizeof(long)); size_t numBytes = *len * (sizeof(long));
long* lValues = (long*)grib_context_malloc(c, numBytes); long* lValues = (long*)grib_context_malloc(c, numBytes);
if (!lValues) { if (!lValues) {
grib_context_log(c, GRIB_LOG_ERROR, "unable to allocate %ld bytes\n", numBytes); grib_context_log(c, GRIB_LOG_ERROR, "Unable to allocate %ld bytes\n", numBytes);
return GRIB_OUT_OF_MEMORY; return GRIB_OUT_OF_MEMORY;
} }
for (i = 0; i < *len; i++) for (i = 0; i < *len; i++)
@ -521,13 +519,19 @@ static int pack_string(grib_accessor* a, const char* v, size_t* len)
} }
grib_context_log(a->context, GRIB_LOG_ERROR, grib_context_log(a->context, GRIB_LOG_ERROR,
" Should not grib_pack %s as string", a->name); "Should not grib_pack %s as string", a->name);
return GRIB_NOT_IMPLEMENTED; return GRIB_NOT_IMPLEMENTED;
} }
static int pack_bytes(grib_accessor* a, const unsigned char* val, size_t* len) static int pack_bytes(grib_accessor* a, const unsigned char* val, size_t* len)
{ {
size_t length = *len; const size_t length = *len;
if (length != a->length) {
grib_context_log(a->context, GRIB_LOG_ERROR,
"pack_bytes: Wrong size (%lu) for %s. It is %lu bytes long",
length, a->name, a->length);
return GRIB_BUFFER_TOO_SMALL;
}
grib_buffer_replace(a, val, length, 1, 1); grib_buffer_replace(a, val, length, 1, 1);
return GRIB_SUCCESS; return GRIB_SUCCESS;
} }