[clang][DebugInfo] Set EnumKind based on enum_extensibility attribute (#126045)

This is the 2nd part to
https://github.com/llvm/llvm-project/pull/124752. Here we make sure to
set the `DICompositeType` `EnumKind` if the enum was declared with
`__attribute__((enum_extensibility(...)))`. In DWARF this will be
rendered as `DW_AT_APPLE_enum_kind` and will be used by LLDB when
creating `clang::EnumDecl`s from debug-info.
 
Depends on https://github.com/llvm/llvm-project/pull/126044
This commit is contained in:
Michael Buch 2025-02-07 09:28:10 +00:00 committed by GitHub
parent 1608fe8d56
commit e00fc80c19
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 54 additions and 1 deletions

View File

@ -3567,6 +3567,10 @@ llvm::DIType *CGDebugInfo::CreateTypeDefinition(const EnumType *Ty) {
DBuilder.createEnumerator(Enum->getName(), Enum->getInitVal())); DBuilder.createEnumerator(Enum->getName(), Enum->getInitVal()));
} }
std::optional<EnumExtensibilityAttr::Kind> EnumKind;
if (auto *Attr = ED->getAttr<EnumExtensibilityAttr>())
EnumKind = Attr->getExtensibility();
// Return a CompositeType for the enum itself. // Return a CompositeType for the enum itself.
llvm::DINodeArray EltArray = DBuilder.getOrCreateArray(Enumerators); llvm::DINodeArray EltArray = DBuilder.getOrCreateArray(Enumerators);
@ -3576,7 +3580,7 @@ llvm::DIType *CGDebugInfo::CreateTypeDefinition(const EnumType *Ty) {
llvm::DIType *ClassTy = getOrCreateType(ED->getIntegerType(), DefUnit); llvm::DIType *ClassTy = getOrCreateType(ED->getIntegerType(), DefUnit);
return DBuilder.createEnumerationType( return DBuilder.createEnumerationType(
EnumContext, ED->getName(), DefUnit, Line, Size, Align, EltArray, ClassTy, EnumContext, ED->getName(), DefUnit, Line, Size, Align, EltArray, ClassTy,
/*RunTimeLang=*/0, Identifier, ED->isScoped()); /*RunTimeLang=*/0, Identifier, ED->isScoped(), EnumKind);
} }
llvm::DIMacro *CGDebugInfo::CreateMacro(llvm::DIMacroFile *Parent, llvm::DIMacro *CGDebugInfo::CreateMacro(llvm::DIMacroFile *Parent,

View File

@ -0,0 +1,49 @@
// RUN: %clang_cc1 -emit-llvm -debug-info-kind=limited %s -o - | FileCheck %s
// CHECK-NOT: enumKind
// CHECK: !DICompositeType(tag: DW_TAG_enumeration_type, name: "ClosedEnum"
// CHECK-SAME: enumKind: DW_APPLE_ENUM_KIND_Closed)
// CHECK: !DICompositeType(tag: DW_TAG_enumeration_type, name: "OpenEnum"
// CHECK-SAME: enumKind: DW_APPLE_ENUM_KIND_Open)
// CHECK: !DICompositeType(tag: DW_TAG_enumeration_type, name: "ClosedFlagEnum"
// CHECK-SAME: enumKind: DW_APPLE_ENUM_KIND_Closed)
// CHECK: !DICompositeType(tag: DW_TAG_enumeration_type, name: "OpenFlagEnum"
// CHECK-SAME: enumKind: DW_APPLE_ENUM_KIND_Open)
// CHECK: !DICompositeType(tag: DW_TAG_enumeration_type, name: "MixedEnum"
// CHECK-SAME: enumKind: DW_APPLE_ENUM_KIND_Open)
enum Enum {
E0, E1
};
enum FlagEnum {
FE0 = 1 << 0, FE1 = 1 << 1
};
enum __attribute__((enum_extensibility(closed))) ClosedEnum {
A0, A1
};
enum __attribute__((enum_extensibility(open))) OpenEnum {
B0, B1
};
enum __attribute__((enum_extensibility(closed),flag_enum)) ClosedFlagEnum {
C0 = 1 << 0, C1 = 1 << 1
};
enum __attribute__((enum_extensibility(open),flag_enum)) OpenFlagEnum {
D0 = 1 << 0, D1 = 1 << 1
};
enum __attribute__((enum_extensibility(open), enum_extensibility(closed))) MixedEnum {
M0, M1
};
enum Enum e;
enum FlagEnum fe;
enum ClosedEnum ce;
enum OpenEnum oe;
enum ClosedFlagEnum cfe;
enum OpenFlagEnum ofe;
enum MixedEnum me;