annotate clang/lib/Frontend/InterfaceStubFunctionsConsumer.cpp @ 252:1f2b6ac9f198 llvm-original

LLVM16-1
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 18 Aug 2023 09:04:13 +0900
parents 70dce7da266c
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===--- InterfaceStubFunctionsConsumer.cpp -------------------------------===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #include "clang/AST/Mangle.h"
anatofuz
parents:
diff changeset
10 #include "clang/AST/RecursiveASTVisitor.h"
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
11 #include "clang/Basic/TargetInfo.h"
150
anatofuz
parents:
diff changeset
12 #include "clang/Frontend/CompilerInstance.h"
anatofuz
parents:
diff changeset
13 #include "clang/Frontend/FrontendActions.h"
anatofuz
parents:
diff changeset
14 #include "clang/Sema/TemplateInstCallback.h"
anatofuz
parents:
diff changeset
15 #include "llvm/BinaryFormat/ELF.h"
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 using namespace clang;
anatofuz
parents:
diff changeset
18
anatofuz
parents:
diff changeset
19 namespace {
anatofuz
parents:
diff changeset
20 class InterfaceStubFunctionsConsumer : public ASTConsumer {
anatofuz
parents:
diff changeset
21 CompilerInstance &Instance;
anatofuz
parents:
diff changeset
22 StringRef InFile;
anatofuz
parents:
diff changeset
23 StringRef Format;
anatofuz
parents:
diff changeset
24 std::set<std::string> ParsedTemplates;
anatofuz
parents:
diff changeset
25
anatofuz
parents:
diff changeset
26 enum RootDeclOrigin { TopLevel = 0, FromTU = 1, IsLate = 2 };
anatofuz
parents:
diff changeset
27 struct MangledSymbol {
anatofuz
parents:
diff changeset
28 std::string ParentName;
anatofuz
parents:
diff changeset
29 uint8_t Type;
anatofuz
parents:
diff changeset
30 uint8_t Binding;
anatofuz
parents:
diff changeset
31 std::vector<std::string> Names;
anatofuz
parents:
diff changeset
32 MangledSymbol() = delete;
anatofuz
parents:
diff changeset
33
anatofuz
parents:
diff changeset
34 MangledSymbol(const std::string &ParentName, uint8_t Type, uint8_t Binding,
anatofuz
parents:
diff changeset
35 std::vector<std::string> Names)
anatofuz
parents:
diff changeset
36 : ParentName(ParentName), Type(Type), Binding(Binding), Names(Names) {}
anatofuz
parents:
diff changeset
37 };
anatofuz
parents:
diff changeset
38 using MangledSymbols = std::map<const NamedDecl *, MangledSymbol>;
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 bool WriteNamedDecl(const NamedDecl *ND, MangledSymbols &Symbols, int RDO) {
anatofuz
parents:
diff changeset
41 // Here we filter out anything that's not set to DefaultVisibility.
anatofuz
parents:
diff changeset
42 // DefaultVisibility is set on a decl when -fvisibility is not specified on
anatofuz
parents:
diff changeset
43 // the command line (or specified as default) and the decl does not have
anatofuz
parents:
diff changeset
44 // __attribute__((visibility("hidden"))) set or when the command line
anatofuz
parents:
diff changeset
45 // argument is set to hidden but the decl explicitly has
anatofuz
parents:
diff changeset
46 // __attribute__((visibility ("default"))) set. We do this so that the user
anatofuz
parents:
diff changeset
47 // can have fine grain control of what they want to expose in the stub.
anatofuz
parents:
diff changeset
48 auto isVisible = [](const NamedDecl *ND) -> bool {
anatofuz
parents:
diff changeset
49 return ND->getVisibility() == DefaultVisibility;
anatofuz
parents:
diff changeset
50 };
anatofuz
parents:
diff changeset
51
anatofuz
parents:
diff changeset
52 auto ignoreDecl = [this, isVisible](const NamedDecl *ND) -> bool {
anatofuz
parents:
diff changeset
53 if (!isVisible(ND))
anatofuz
parents:
diff changeset
54 return true;
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 if (const VarDecl *VD = dyn_cast<VarDecl>(ND)) {
anatofuz
parents:
diff changeset
57 if (const auto *Parent = VD->getParentFunctionOrMethod())
anatofuz
parents:
diff changeset
58 if (isa<BlockDecl>(Parent) || isa<CXXMethodDecl>(Parent))
anatofuz
parents:
diff changeset
59 return true;
anatofuz
parents:
diff changeset
60
anatofuz
parents:
diff changeset
61 if ((VD->getStorageClass() == StorageClass::SC_Extern) ||
anatofuz
parents:
diff changeset
62 (VD->getStorageClass() == StorageClass::SC_Static &&
anatofuz
parents:
diff changeset
63 VD->getParentFunctionOrMethod() == nullptr))
anatofuz
parents:
diff changeset
64 return true;
anatofuz
parents:
diff changeset
65 }
anatofuz
parents:
diff changeset
66
anatofuz
parents:
diff changeset
67 if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(ND)) {
anatofuz
parents:
diff changeset
68 if (FD->isInlined() && !isa<CXXMethodDecl>(FD) &&
anatofuz
parents:
diff changeset
69 !Instance.getLangOpts().GNUInline)
anatofuz
parents:
diff changeset
70 return true;
anatofuz
parents:
diff changeset
71 if (const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD)) {
anatofuz
parents:
diff changeset
72 if (const auto *RC = dyn_cast<CXXRecordDecl>(MD->getParent()))
anatofuz
parents:
diff changeset
73 if (isa<ClassTemplateDecl>(RC->getParent()) || !isVisible(RC))
anatofuz
parents:
diff changeset
74 return true;
anatofuz
parents:
diff changeset
75 if (MD->isDependentContext() || !MD->hasBody())
anatofuz
parents:
diff changeset
76 return true;
anatofuz
parents:
diff changeset
77 }
anatofuz
parents:
diff changeset
78 if (FD->getStorageClass() == StorageClass::SC_Static)
anatofuz
parents:
diff changeset
79 return true;
anatofuz
parents:
diff changeset
80 }
anatofuz
parents:
diff changeset
81 return false;
anatofuz
parents:
diff changeset
82 };
anatofuz
parents:
diff changeset
83
anatofuz
parents:
diff changeset
84 auto getParentFunctionDecl = [](const NamedDecl *ND) -> const NamedDecl * {
anatofuz
parents:
diff changeset
85 if (const VarDecl *VD = dyn_cast<VarDecl>(ND))
anatofuz
parents:
diff changeset
86 if (const auto *FD =
anatofuz
parents:
diff changeset
87 dyn_cast_or_null<FunctionDecl>(VD->getParentFunctionOrMethod()))
anatofuz
parents:
diff changeset
88 return FD;
anatofuz
parents:
diff changeset
89 return nullptr;
anatofuz
parents:
diff changeset
90 };
anatofuz
parents:
diff changeset
91
anatofuz
parents:
diff changeset
92 auto getMangledNames = [](const NamedDecl *ND) -> std::vector<std::string> {
anatofuz
parents:
diff changeset
93 if (!ND)
anatofuz
parents:
diff changeset
94 return {""};
anatofuz
parents:
diff changeset
95 ASTNameGenerator NameGen(ND->getASTContext());
anatofuz
parents:
diff changeset
96 std::vector<std::string> MangledNames = NameGen.getAllManglings(ND);
anatofuz
parents:
diff changeset
97 if (isa<CXXConstructorDecl>(ND) || isa<CXXDestructorDecl>(ND))
anatofuz
parents:
diff changeset
98 return MangledNames;
anatofuz
parents:
diff changeset
99 #ifdef EXPENSIVE_CHECKS
anatofuz
parents:
diff changeset
100 assert(MangledNames.size() <= 1 && "Expected only one name mangling.");
anatofuz
parents:
diff changeset
101 #endif
anatofuz
parents:
diff changeset
102 return {NameGen.getName(ND)};
anatofuz
parents:
diff changeset
103 };
anatofuz
parents:
diff changeset
104
anatofuz
parents:
diff changeset
105 if (!(RDO & FromTU))
anatofuz
parents:
diff changeset
106 return true;
anatofuz
parents:
diff changeset
107 if (Symbols.find(ND) != Symbols.end())
anatofuz
parents:
diff changeset
108 return true;
anatofuz
parents:
diff changeset
109 // - Currently have not figured out how to produce the names for FieldDecls.
anatofuz
parents:
diff changeset
110 // - Do not want to produce symbols for function paremeters.
anatofuz
parents:
diff changeset
111 if (isa<FieldDecl>(ND) || isa<ParmVarDecl>(ND))
anatofuz
parents:
diff changeset
112 return true;
anatofuz
parents:
diff changeset
113
anatofuz
parents:
diff changeset
114 const NamedDecl *ParentDecl = getParentFunctionDecl(ND);
anatofuz
parents:
diff changeset
115 if ((ParentDecl && ignoreDecl(ParentDecl)) || ignoreDecl(ND))
anatofuz
parents:
diff changeset
116 return true;
anatofuz
parents:
diff changeset
117
anatofuz
parents:
diff changeset
118 if (RDO & IsLate) {
anatofuz
parents:
diff changeset
119 Instance.getDiagnostics().Report(diag::err_asm_invalid_type_in_input)
anatofuz
parents:
diff changeset
120 << "Generating Interface Stubs is not supported with "
anatofuz
parents:
diff changeset
121 "delayed template parsing.";
anatofuz
parents:
diff changeset
122 } else {
anatofuz
parents:
diff changeset
123 if (const auto *FD = dyn_cast<FunctionDecl>(ND))
anatofuz
parents:
diff changeset
124 if (FD->isDependentContext())
anatofuz
parents:
diff changeset
125 return true;
anatofuz
parents:
diff changeset
126
anatofuz
parents:
diff changeset
127 const bool IsWeak = (ND->hasAttr<WeakAttr>() ||
anatofuz
parents:
diff changeset
128 ND->hasAttr<WeakRefAttr>() || ND->isWeakImported());
anatofuz
parents:
diff changeset
129
anatofuz
parents:
diff changeset
130 Symbols.insert(std::make_pair(
anatofuz
parents:
diff changeset
131 ND,
anatofuz
parents:
diff changeset
132 MangledSymbol(getMangledNames(ParentDecl).front(),
anatofuz
parents:
diff changeset
133 // Type:
anatofuz
parents:
diff changeset
134 isa<VarDecl>(ND) ? llvm::ELF::STT_OBJECT
anatofuz
parents:
diff changeset
135 : llvm::ELF::STT_FUNC,
anatofuz
parents:
diff changeset
136 // Binding:
anatofuz
parents:
diff changeset
137 IsWeak ? llvm::ELF::STB_WEAK : llvm::ELF::STB_GLOBAL,
anatofuz
parents:
diff changeset
138 getMangledNames(ND))));
anatofuz
parents:
diff changeset
139 }
anatofuz
parents:
diff changeset
140 return true;
anatofuz
parents:
diff changeset
141 }
anatofuz
parents:
diff changeset
142
anatofuz
parents:
diff changeset
143 void
anatofuz
parents:
diff changeset
144 HandleDecls(const llvm::iterator_range<DeclContext::decl_iterator> &Decls,
anatofuz
parents:
diff changeset
145 MangledSymbols &Symbols, int RDO) {
anatofuz
parents:
diff changeset
146 for (const auto *D : Decls)
anatofuz
parents:
diff changeset
147 HandleNamedDecl(dyn_cast<NamedDecl>(D), Symbols, RDO);
anatofuz
parents:
diff changeset
148 }
anatofuz
parents:
diff changeset
149
anatofuz
parents:
diff changeset
150 void HandleTemplateSpecializations(const FunctionTemplateDecl &FTD,
anatofuz
parents:
diff changeset
151 MangledSymbols &Symbols, int RDO) {
anatofuz
parents:
diff changeset
152 for (const auto *D : FTD.specializations())
anatofuz
parents:
diff changeset
153 HandleNamedDecl(dyn_cast<NamedDecl>(D), Symbols, RDO);
anatofuz
parents:
diff changeset
154 }
anatofuz
parents:
diff changeset
155
anatofuz
parents:
diff changeset
156 void HandleTemplateSpecializations(const ClassTemplateDecl &CTD,
anatofuz
parents:
diff changeset
157 MangledSymbols &Symbols, int RDO) {
anatofuz
parents:
diff changeset
158 for (const auto *D : CTD.specializations())
anatofuz
parents:
diff changeset
159 HandleNamedDecl(dyn_cast<NamedDecl>(D), Symbols, RDO);
anatofuz
parents:
diff changeset
160 }
anatofuz
parents:
diff changeset
161
anatofuz
parents:
diff changeset
162 bool HandleNamedDecl(const NamedDecl *ND, MangledSymbols &Symbols, int RDO) {
anatofuz
parents:
diff changeset
163 if (!ND)
anatofuz
parents:
diff changeset
164 return false;
anatofuz
parents:
diff changeset
165
anatofuz
parents:
diff changeset
166 switch (ND->getKind()) {
anatofuz
parents:
diff changeset
167 default:
anatofuz
parents:
diff changeset
168 break;
anatofuz
parents:
diff changeset
169 case Decl::Kind::Namespace:
anatofuz
parents:
diff changeset
170 HandleDecls(cast<NamespaceDecl>(ND)->decls(), Symbols, RDO);
anatofuz
parents:
diff changeset
171 return true;
anatofuz
parents:
diff changeset
172 case Decl::Kind::CXXRecord:
anatofuz
parents:
diff changeset
173 HandleDecls(cast<CXXRecordDecl>(ND)->decls(), Symbols, RDO);
anatofuz
parents:
diff changeset
174 return true;
anatofuz
parents:
diff changeset
175 case Decl::Kind::ClassTemplateSpecialization:
anatofuz
parents:
diff changeset
176 HandleDecls(cast<ClassTemplateSpecializationDecl>(ND)->decls(), Symbols,
anatofuz
parents:
diff changeset
177 RDO);
anatofuz
parents:
diff changeset
178 return true;
anatofuz
parents:
diff changeset
179 case Decl::Kind::ClassTemplate:
anatofuz
parents:
diff changeset
180 HandleTemplateSpecializations(*cast<ClassTemplateDecl>(ND), Symbols, RDO);
anatofuz
parents:
diff changeset
181 return true;
anatofuz
parents:
diff changeset
182 case Decl::Kind::FunctionTemplate:
anatofuz
parents:
diff changeset
183 HandleTemplateSpecializations(*cast<FunctionTemplateDecl>(ND), Symbols,
anatofuz
parents:
diff changeset
184 RDO);
anatofuz
parents:
diff changeset
185 return true;
anatofuz
parents:
diff changeset
186 case Decl::Kind::Record:
anatofuz
parents:
diff changeset
187 case Decl::Kind::Typedef:
anatofuz
parents:
diff changeset
188 case Decl::Kind::Enum:
anatofuz
parents:
diff changeset
189 case Decl::Kind::EnumConstant:
anatofuz
parents:
diff changeset
190 case Decl::Kind::TemplateTypeParm:
anatofuz
parents:
diff changeset
191 case Decl::Kind::NonTypeTemplateParm:
anatofuz
parents:
diff changeset
192 case Decl::Kind::CXXConversion:
anatofuz
parents:
diff changeset
193 case Decl::Kind::UnresolvedUsingValue:
anatofuz
parents:
diff changeset
194 case Decl::Kind::Using:
anatofuz
parents:
diff changeset
195 case Decl::Kind::UsingShadow:
anatofuz
parents:
diff changeset
196 case Decl::Kind::TypeAliasTemplate:
anatofuz
parents:
diff changeset
197 case Decl::Kind::TypeAlias:
anatofuz
parents:
diff changeset
198 case Decl::Kind::VarTemplate:
anatofuz
parents:
diff changeset
199 case Decl::Kind::VarTemplateSpecialization:
anatofuz
parents:
diff changeset
200 case Decl::Kind::UsingDirective:
anatofuz
parents:
diff changeset
201 case Decl::Kind::TemplateTemplateParm:
anatofuz
parents:
diff changeset
202 case Decl::Kind::ClassTemplatePartialSpecialization:
anatofuz
parents:
diff changeset
203 case Decl::Kind::IndirectField:
anatofuz
parents:
diff changeset
204 case Decl::Kind::ConstructorUsingShadow:
anatofuz
parents:
diff changeset
205 case Decl::Kind::CXXDeductionGuide:
anatofuz
parents:
diff changeset
206 case Decl::Kind::NamespaceAlias:
anatofuz
parents:
diff changeset
207 case Decl::Kind::UnresolvedUsingTypename:
anatofuz
parents:
diff changeset
208 return true;
anatofuz
parents:
diff changeset
209 case Decl::Kind::Var: {
anatofuz
parents:
diff changeset
210 // Bail on any VarDecl that either has no named symbol.
anatofuz
parents:
diff changeset
211 if (!ND->getIdentifier())
anatofuz
parents:
diff changeset
212 return true;
anatofuz
parents:
diff changeset
213 const auto *VD = cast<VarDecl>(ND);
anatofuz
parents:
diff changeset
214 // Bail on any VarDecl that is a dependent or templated type.
anatofuz
parents:
diff changeset
215 if (VD->isTemplated() || VD->getType()->isDependentType())
anatofuz
parents:
diff changeset
216 return true;
anatofuz
parents:
diff changeset
217 if (WriteNamedDecl(ND, Symbols, RDO))
anatofuz
parents:
diff changeset
218 return true;
anatofuz
parents:
diff changeset
219 break;
anatofuz
parents:
diff changeset
220 }
anatofuz
parents:
diff changeset
221 case Decl::Kind::ParmVar:
anatofuz
parents:
diff changeset
222 case Decl::Kind::CXXMethod:
anatofuz
parents:
diff changeset
223 case Decl::Kind::CXXConstructor:
anatofuz
parents:
diff changeset
224 case Decl::Kind::CXXDestructor:
anatofuz
parents:
diff changeset
225 case Decl::Kind::Function:
anatofuz
parents:
diff changeset
226 case Decl::Kind::Field:
anatofuz
parents:
diff changeset
227 if (WriteNamedDecl(ND, Symbols, RDO))
anatofuz
parents:
diff changeset
228 return true;
anatofuz
parents:
diff changeset
229 }
anatofuz
parents:
diff changeset
230
anatofuz
parents:
diff changeset
231 // While interface stubs are in the development stage, it's probably best to
anatofuz
parents:
diff changeset
232 // catch anything that's not a VarDecl or Template/FunctionDecl.
anatofuz
parents:
diff changeset
233 Instance.getDiagnostics().Report(diag::err_asm_invalid_type_in_input)
anatofuz
parents:
diff changeset
234 << "Expected a function or function template decl.";
anatofuz
parents:
diff changeset
235 return false;
anatofuz
parents:
diff changeset
236 }
anatofuz
parents:
diff changeset
237
anatofuz
parents:
diff changeset
238 public:
anatofuz
parents:
diff changeset
239 InterfaceStubFunctionsConsumer(CompilerInstance &Instance, StringRef InFile,
anatofuz
parents:
diff changeset
240 StringRef Format)
anatofuz
parents:
diff changeset
241 : Instance(Instance), InFile(InFile), Format(Format) {}
anatofuz
parents:
diff changeset
242
anatofuz
parents:
diff changeset
243 void HandleTranslationUnit(ASTContext &context) override {
anatofuz
parents:
diff changeset
244 struct Visitor : public RecursiveASTVisitor<Visitor> {
anatofuz
parents:
diff changeset
245 bool VisitNamedDecl(NamedDecl *ND) {
anatofuz
parents:
diff changeset
246 if (const auto *FD = dyn_cast<FunctionDecl>(ND))
anatofuz
parents:
diff changeset
247 if (FD->isLateTemplateParsed()) {
anatofuz
parents:
diff changeset
248 LateParsedDecls.insert(FD);
anatofuz
parents:
diff changeset
249 return true;
anatofuz
parents:
diff changeset
250 }
anatofuz
parents:
diff changeset
251
anatofuz
parents:
diff changeset
252 if (const auto *VD = dyn_cast<ValueDecl>(ND)) {
anatofuz
parents:
diff changeset
253 ValueDecls.insert(VD);
anatofuz
parents:
diff changeset
254 return true;
anatofuz
parents:
diff changeset
255 }
anatofuz
parents:
diff changeset
256
anatofuz
parents:
diff changeset
257 NamedDecls.insert(ND);
anatofuz
parents:
diff changeset
258 return true;
anatofuz
parents:
diff changeset
259 }
anatofuz
parents:
diff changeset
260
anatofuz
parents:
diff changeset
261 std::set<const NamedDecl *> LateParsedDecls;
anatofuz
parents:
diff changeset
262 std::set<NamedDecl *> NamedDecls;
anatofuz
parents:
diff changeset
263 std::set<const ValueDecl *> ValueDecls;
anatofuz
parents:
diff changeset
264 } v;
anatofuz
parents:
diff changeset
265
anatofuz
parents:
diff changeset
266 v.TraverseDecl(context.getTranslationUnitDecl());
anatofuz
parents:
diff changeset
267
anatofuz
parents:
diff changeset
268 MangledSymbols Symbols;
anatofuz
parents:
diff changeset
269 auto OS = Instance.createDefaultOutputFile(/*Binary=*/false, InFile, "ifs");
anatofuz
parents:
diff changeset
270 if (!OS)
anatofuz
parents:
diff changeset
271 return;
anatofuz
parents:
diff changeset
272
anatofuz
parents:
diff changeset
273 if (Instance.getLangOpts().DelayedTemplateParsing) {
anatofuz
parents:
diff changeset
274 clang::Sema &S = Instance.getSema();
anatofuz
parents:
diff changeset
275 for (const auto *FD : v.LateParsedDecls) {
anatofuz
parents:
diff changeset
276 clang::LateParsedTemplate &LPT =
anatofuz
parents:
diff changeset
277 *S.LateParsedTemplateMap.find(cast<FunctionDecl>(FD))->second;
anatofuz
parents:
diff changeset
278 S.LateTemplateParser(S.OpaqueParser, LPT);
anatofuz
parents:
diff changeset
279 HandleNamedDecl(FD, Symbols, (FromTU | IsLate));
anatofuz
parents:
diff changeset
280 }
anatofuz
parents:
diff changeset
281 }
anatofuz
parents:
diff changeset
282
anatofuz
parents:
diff changeset
283 for (const NamedDecl *ND : v.ValueDecls)
anatofuz
parents:
diff changeset
284 HandleNamedDecl(ND, Symbols, FromTU);
anatofuz
parents:
diff changeset
285 for (const NamedDecl *ND : v.NamedDecls)
anatofuz
parents:
diff changeset
286 HandleNamedDecl(ND, Symbols, FromTU);
anatofuz
parents:
diff changeset
287
anatofuz
parents:
diff changeset
288 auto writeIfsV1 = [this](const llvm::Triple &T,
anatofuz
parents:
diff changeset
289 const MangledSymbols &Symbols,
anatofuz
parents:
diff changeset
290 const ASTContext &context, StringRef Format,
anatofuz
parents:
diff changeset
291 raw_ostream &OS) -> void {
anatofuz
parents:
diff changeset
292 OS << "--- !" << Format << "\n";
232
70dce7da266c llvm original Jul 20 16:41:34 2021
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
293 OS << "IfsVersion: 3.0\n";
70dce7da266c llvm original Jul 20 16:41:34 2021
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
294 OS << "Target: " << T.str() << "\n";
150
anatofuz
parents:
diff changeset
295 OS << "Symbols:\n";
anatofuz
parents:
diff changeset
296 for (const auto &E : Symbols) {
anatofuz
parents:
diff changeset
297 const MangledSymbol &Symbol = E.second;
anatofuz
parents:
diff changeset
298 for (auto Name : Symbol.Names) {
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
299 OS << " - { Name: \""
150
anatofuz
parents:
diff changeset
300 << (Symbol.ParentName.empty() || Instance.getLangOpts().CPlusPlus
anatofuz
parents:
diff changeset
301 ? ""
anatofuz
parents:
diff changeset
302 : (Symbol.ParentName + "."))
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
303 << Name << "\", Type: ";
150
anatofuz
parents:
diff changeset
304 switch (Symbol.Type) {
anatofuz
parents:
diff changeset
305 default:
anatofuz
parents:
diff changeset
306 llvm_unreachable(
anatofuz
parents:
diff changeset
307 "clang -emit-interface-stubs: Unexpected symbol type.");
anatofuz
parents:
diff changeset
308 case llvm::ELF::STT_NOTYPE:
anatofuz
parents:
diff changeset
309 OS << "NoType";
anatofuz
parents:
diff changeset
310 break;
anatofuz
parents:
diff changeset
311 case llvm::ELF::STT_OBJECT: {
anatofuz
parents:
diff changeset
312 auto VD = cast<ValueDecl>(E.first)->getType();
anatofuz
parents:
diff changeset
313 OS << "Object, Size: "
anatofuz
parents:
diff changeset
314 << context.getTypeSizeInChars(VD).getQuantity();
anatofuz
parents:
diff changeset
315 break;
anatofuz
parents:
diff changeset
316 }
anatofuz
parents:
diff changeset
317 case llvm::ELF::STT_FUNC:
anatofuz
parents:
diff changeset
318 OS << "Func";
anatofuz
parents:
diff changeset
319 break;
anatofuz
parents:
diff changeset
320 }
anatofuz
parents:
diff changeset
321 if (Symbol.Binding == llvm::ELF::STB_WEAK)
anatofuz
parents:
diff changeset
322 OS << ", Weak: true";
anatofuz
parents:
diff changeset
323 OS << " }\n";
anatofuz
parents:
diff changeset
324 }
anatofuz
parents:
diff changeset
325 }
anatofuz
parents:
diff changeset
326 OS << "...\n";
anatofuz
parents:
diff changeset
327 OS.flush();
anatofuz
parents:
diff changeset
328 };
anatofuz
parents:
diff changeset
329
232
70dce7da266c llvm original Jul 20 16:41:34 2021
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
330 assert(Format == "ifs-v1" && "Unexpected IFS Format.");
150
anatofuz
parents:
diff changeset
331 writeIfsV1(Instance.getTarget().getTriple(), Symbols, context, Format, *OS);
anatofuz
parents:
diff changeset
332 }
anatofuz
parents:
diff changeset
333 };
anatofuz
parents:
diff changeset
334 } // namespace
anatofuz
parents:
diff changeset
335
anatofuz
parents:
diff changeset
336 std::unique_ptr<ASTConsumer>
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
337 GenerateInterfaceStubsAction::CreateASTConsumer(CompilerInstance &CI,
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
338 StringRef InFile) {
232
70dce7da266c llvm original Jul 20 16:41:34 2021
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
339 return std::make_unique<InterfaceStubFunctionsConsumer>(CI, InFile, "ifs-v1");
150
anatofuz
parents:
diff changeset
340 }