diff options
author | whitequark <whitequark@whitequark.org> | 2020-12-02 23:36:22 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-02 23:36:22 +0000 |
commit | 3e13cfe53dd62f71820b227d4c04cc47bbb95001 (patch) | |
tree | f51b573a0aae2accf93e77c5709b7422974b7de8 | |
parent | 3cb109f54bb35ad1c29474c2742c8767535174e1 (diff) | |
parent | aa0a15a42cf7513697b3d93457a69ecf2d8b9e05 (diff) | |
download | yosys-3e13cfe53dd62f71820b227d4c04cc47bbb95001.tar.gz yosys-3e13cfe53dd62f71820b227d4c04cc47bbb95001.tar.bz2 yosys-3e13cfe53dd62f71820b227d4c04cc47bbb95001.zip |
Merge pull request #2468 from whitequark/cxxrtl-assert
cxxrtl: use CXXRTL_ASSERT for RTL contract violations instead of assert
-rw-r--r-- | backends/cxxrtl/cxxrtl.h | 14 | ||||
-rw-r--r-- | backends/cxxrtl/cxxrtl_backend.cc | 4 |
2 files changed, 16 insertions, 2 deletions
diff --git a/backends/cxxrtl/cxxrtl.h b/backends/cxxrtl/cxxrtl.h index 4528a7d8f..eb7d7eaeb 100644 --- a/backends/cxxrtl/cxxrtl.h +++ b/backends/cxxrtl/cxxrtl.h @@ -53,6 +53,20 @@ #define CXXRTL_ALWAYS_INLINE inline #endif +// CXXRTL uses assert() to check for C++ contract violations (which may result in e.g. undefined behavior +// of the simulation code itself), and CXXRTL_ASSERT to check for RTL contract violations (which may at +// most result in undefined simulation results). +// +// Though by default, CXXRTL_ASSERT() expands to assert(), it may be overridden e.g. when integrating +// the simulation into another process that should survive violating RTL contracts. +#ifndef CXXRTL_ASSERT +#ifndef CXXRTL_NDEBUG +#define CXXRTL_ASSERT(x) assert(x) +#else +#define CXXRTL_ASSERT(x) +#endif +#endif + namespace cxxrtl { // All arbitrary-width values in CXXRTL are backed by arrays of unsigned integers called chunks. The chunk size diff --git a/backends/cxxrtl/cxxrtl_backend.cc b/backends/cxxrtl/cxxrtl_backend.cc index eb021dddb..7efb0aeaf 100644 --- a/backends/cxxrtl/cxxrtl_backend.cc +++ b/backends/cxxrtl/cxxrtl_backend.cc @@ -1162,7 +1162,7 @@ struct CxxrtlWorker { // larger program) will never crash the code that calls into it. // // If assertions are disabled, out of bounds reads are defined to return zero. - f << indent << "assert(" << valid_index_temp << ".valid && \"out of bounds read\");\n"; + f << indent << "CXXRTL_ASSERT(" << valid_index_temp << ".valid && \"out of bounds read\");\n"; f << indent << "if(" << valid_index_temp << ".valid) {\n"; inc_indent(); if (writable_memories[memory]) { @@ -1219,7 +1219,7 @@ struct CxxrtlWorker { // See above for rationale of having both the assert and the condition. // // If assertions are disabled, out of bounds writes are defined to do nothing. - f << indent << "assert(" << valid_index_temp << ".valid && \"out of bounds write\");\n"; + f << indent << "CXXRTL_ASSERT(" << valid_index_temp << ".valid && \"out of bounds write\");\n"; f << indent << "if (" << valid_index_temp << ".valid) {\n"; inc_indent(); f << indent << mangle(memory) << ".update(" << valid_index_temp << ".index, "; |