Add VL_VALUE_STRING_MAX_WORDS override (#3869)

Co-authored-by: Andrew Nolte <anolte@hudson-trading.com>
This commit is contained in:
Andrew Nolte 2023-01-13 15:23:15 -05:00 committed by GitHub
parent 83f6b11235
commit e5eb7d8930
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 6 additions and 2 deletions

View File

@ -1751,13 +1751,13 @@ void vl_get_value(const VerilatedVar* varp, void* varDatap, p_vpi_value valuep,
int i; int i;
if (bits > t_outStrSz) { if (bits > t_outStrSz) {
// limit maximum size of output to size of buffer to prevent overrun. // limit maximum size of output to size of buffer to prevent overrun.
bits = t_outStrSz;
VL_VPI_WARNING_( VL_VPI_WARNING_(
__FILE__, __LINE__, __FILE__, __LINE__,
"%s: Truncating string value of %s for %s" "%s: Truncating string value of %s for %s"
" as buffer size (%d, VL_VALUE_STRING_MAX_WORDS=%d) is less than required (%d)", " as buffer size (%d, VL_VALUE_STRING_MAX_WORDS=%d) is less than required (%d)",
__func__, VerilatedVpiError::strFromVpiVal(valuep->format), fullname, t_outStrSz, __func__, VerilatedVpiError::strFromVpiVal(valuep->format), fullname, t_outStrSz,
VL_VALUE_STRING_MAX_WORDS, bits); VL_VALUE_STRING_MAX_WORDS, bits);
bits = t_outStrSz;
} }
for (i = 0; i < bits; ++i) { for (i = 0; i < bits; ++i) {
const char val = (datap[i >> 3] >> (i & 7)) & 1; const char val = (datap[i >> 3] >> (i & 7)) & 1;

View File

@ -426,7 +426,11 @@ using ssize_t = uint32_t; ///< signed size_t; returned from read()
// Verilated function size macros // Verilated function size macros
#define VL_MULS_MAX_WORDS 16 ///< Max size in words of MULS operation #define VL_MULS_MAX_WORDS 16 ///< Max size in words of MULS operation
#define VL_VALUE_STRING_MAX_WORDS 64 ///< Max size in words of String conversion operation
#ifndef VL_VALUE_STRING_MAX_WORDS
#define VL_VALUE_STRING_MAX_WORDS 64 ///< Max size in words of String conversion operation
#endif
#define VL_VALUE_STRING_MAX_CHARS (VL_VALUE_STRING_MAX_WORDS * VL_EDATASIZE / VL_BYTESIZE) #define VL_VALUE_STRING_MAX_CHARS (VL_VALUE_STRING_MAX_WORDS * VL_EDATASIZE / VL_BYTESIZE)
//========================================================================= //=========================================================================