mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-04 12:15:46 +00:00
[randstruct] Move initializer check to be more effective
If a randomized structure has an initializer with a dedicated initializer in it, the field initialzed by that dedicated initializer may end up at the end of the RecordDecl. This however may skip the random layout initization check. struct t { int a, b, c, d, e; } x = { .a = 2, 4, 5, 6 }; Let's say that "a" is lands as the last field after randomization. The call to CheckDesignatedInitializer sets the iterator to the end of the initializer list. During the next iteration of the initializer list check, it detects that and fails to issue the error about initializing a randomized struct with non-designated initializer. Instead, it issues an error about "excess elements in struct initializer", which is confusing under these circumstances. Reviewed By: aaron.ballman Differential Revision: https://reviews.llvm.org/D124694
This commit is contained in:
parent
2f9fc576be
commit
f2639cf3fe
@ -2170,11 +2170,6 @@ void InitListChecker::CheckStructUnionTypes(
|
||||
continue;
|
||||
}
|
||||
|
||||
if (Field == FieldEnd) {
|
||||
// We've run out of fields. We're done.
|
||||
break;
|
||||
}
|
||||
|
||||
// Check if this is an initializer of forms:
|
||||
//
|
||||
// struct foo f = {};
|
||||
@ -2204,6 +2199,11 @@ void InitListChecker::CheckStructUnionTypes(
|
||||
break;
|
||||
}
|
||||
|
||||
if (Field == FieldEnd) {
|
||||
// We've run out of fields. We're done.
|
||||
break;
|
||||
}
|
||||
|
||||
// We've already initialized a member of a union. We're done.
|
||||
if (InitializedSomething && DeclType->isUnionType())
|
||||
break;
|
||||
|
@ -1,6 +1,13 @@
|
||||
// RUN: %clang_cc1 -triple=x86_64-unknown-linux -frandomize-layout-seed=1234567890abcdef \
|
||||
// RUN: %clang_cc1 -triple=x86_64-unknown-linux -frandomize-layout-seed=1234567890abcded \
|
||||
// RUN: -verify -fsyntax-only -Werror %s
|
||||
|
||||
// NOTE: The current seed (1234567890abcded) is specifically chosen because it
|
||||
// uncovered a bug in diagnostics. With it the randomization of "t9" places the
|
||||
// "a" element at the end of the record. When that happens, the clang complains
|
||||
// about excessive initializers, which is confusing, because there aren't
|
||||
// excessive initializers. It should instead complain about using a
|
||||
// non-designated initializer on a raqndomized struct.
|
||||
|
||||
// Initializing a randomized structure requires a designated initializer,
|
||||
// otherwise the element ordering will be off. The only exceptions to this rule
|
||||
// are:
|
||||
|
Loading…
Reference in New Issue
Block a user