This is an archive of the discontinued LLVM Phabricator instance.

[CGTypes] Remove SkippedLayout flag
AbandonedPublic

Authored by nikic on Jun 16 2023, 7:17 AM.

Details

Reviewers
efriedma
rjmccall
Summary

This is a followup to D152999. I don't believe this flag is needed anymore now that the recursion detection is gone. We have separate mechanisms (UpdateCompletedType, RefreshTypeCacheForClass) to deal with incomplete types and similar.

Diff Detail

Event Timeline

nikic created this revision.Jun 16 2023, 7:17 AM
Herald added a project: Restricted Project. · View Herald TranscriptJun 16 2023, 7:17 AM
Herald added a subscriber: StephenFan. · View Herald Transcript
nikic requested review of this revision.Jun 16 2023, 7:17 AM

The following miscompiles with this patch:

struct S;
extern S a[10];
S(*b)[10] = &a;
struct S{int x;};
int f() { return a[3].x; }

The following also behaves a bit strangely:

struct S;
void f(S);
void (*ff)(S) = &f;
struct S {int x;};
void f2(S);
void (*ff2)(S) = &f2;

With your patch, the signature of f2() changes. Granted, not sure how important that is; with opaque pointers, we don't actually use the signatures of function declarations for anything.

clang/lib/CodeGen/CodeGenTypes.cpp
272

FunctionsBeingProcessed can probably also be killed off? With opaque pointers, a function signature can never refer to another function type. (Only calls and functions declarations involve function types.)

nikic abandoned this revision.Jul 13 2023, 5:34 AM

I've added the first test case in https://github.com/llvm/llvm-project/commit/e98cbb95b8b96d3908a808bbcd639680a5197428, to make sure this doesn't regress.

Going to abandon this patch, as we clearly can't drop SkippedLayout, or at least not entirely.

We can probably make this a bit more readable/efficient by adding a mechanism for function/array types similar to RecordsWithOpaqueMemberPointers.