mirror of
https://github.com/asmjit/asmjit.git
synced 2025-12-17 12:34:35 +03:00
[ABI] Improvements to avoid UB and warnings, clean build with MSAN
* Added more clang compilers on CI (CI) * Added memory sanitizer to build matrix (CI) * Use problem matcher in all builds (CI) * Fixed the use of some constructs in tests * Fixed warnings about unused functions in tests * Fixed warnings about unused variables caused by some build options * Fixed tests to be clean with MSAN (zeroing memory filled by JIT code) * Removed -Wclass-memaccess (gcc) from ignored warnings * Removed -Wconstant-logical-operand (clang) from ignored warnings * Removed -Wunnamed-type-template-args (clang) from ignored warnings * Reworked InstData and InstExData to not cause UB (ABI break) Unfortunately the existing InstData and InstExData was not good for static analysis and in general compilers emitted warnings regarding accessing InstNode::_opArray. The reason was that InstExNode added one or two more operands which extended InstData::_opArray, but there was no way to tell the C++ compiler about this layout. It has been changed to InstNode having no operands and InstNodeWithOperands being templatized for the right number of operands. Nodes that need to inherit InstNode would just inherit InstNodeWithOperands<N>. It works the same way as before, just the class hierarchy changed a little.
This commit is contained in:
@@ -109,7 +109,8 @@ static void dumpSizeOf(void) noexcept {
|
||||
DUMP_TYPE(BaseBuilder);
|
||||
DUMP_TYPE(BaseNode);
|
||||
DUMP_TYPE(InstNode);
|
||||
DUMP_TYPE(InstExNode);
|
||||
DUMP_TYPE(InstNodeWithOperands<InstNode::kBaseOpCapacity>);
|
||||
DUMP_TYPE(InstNodeWithOperands<InstNode::kFullOpCapacity>);
|
||||
DUMP_TYPE(AlignNode);
|
||||
DUMP_TYPE(LabelNode);
|
||||
DUMP_TYPE(EmbedDataNode);
|
||||
|
||||
Reference in New Issue
Block a user