This is necessary so the clang gives hidden visibility to fundamental types when
-fvisibility=hidden is passed. Fixes
https://bugs.llvm.org/show_bug.cgi?id=35066
Details
Diff Detail
Event Timeline
lib/CodeGen/ItaniumCXXABI.cpp | ||
---|---|---|
1620–1628 | I think this code can be replaced with options.Visibility = CodeGenModule::GetLLVMVisibility(RD->getVisibility()); | |
3180 | Would it be worth splitting the BuildTypeInfo function in two at this point? I'm thinking that the first function would decide whether to create an RTTI entry. If so it would determine the linkage, visibility and dllexport and pass them to a second function, otherwise it would create an external reference. The second function would take a type, linkage, visibility and dllexport and create the RTTI unconditionally. |
lib/CodeGen/ItaniumCXXABI.cpp | ||
---|---|---|
3180 | Sorry, I didn't complete my thought. I was imagining that we would change EmitFundamentalRTTIDescriptor to call the second function directly and drop the Force and Options argument from this function. |
lib/CodeGen/ItaniumCXXABI.cpp | ||
---|---|---|
3201–3202 | IsStdLib will always be false at this point because of the if statement on line 3211 so I think you can change this to just llvm::GlobalVariable::LinkageTypes Linkage = getTypeInfoLinkage(CGM, Ty); and fold the call to IsStandardLibraryRTTIDescriptor(Ty) into the if statement. | |
3242–3244 | Similarly, ShouldUseExternalRTTIDescriptor(CGM, Ty) should always return false here because of the if statement, so this code is dead. | |
3386–3387 | You can remove the if statement, setting the storage class to default has no effect here because it is initialized to default. | |
3388–3394 | This code is also dead. | |
3663 | You might consider inlining EmitFundamentalRTTIDescriptor into this function and having it take a CXXRecordDecl. Then you wouldn't need to pass the TypeInfoOptions structure around, you can just compute the properties in this function outside of the loop. |
I think this code can be replaced with options.Visibility = CodeGenModule::GetLLVMVisibility(RD->getVisibility());