[PATCH] Generate cold attribute for functions marked __atribute__((cold))
This removes a FIXME in CodeGenModule::SetLLVMFunctionAttributesForDefinition. When a function is declared cold we can now generate the IR attribute in addition to marking the function to be optimized for size. I tried adding a separate CHECK in the existing test, but it was failing. I suppose CHECK matches one line exactly once? This would be a problem if the attributes are listed in a different order, though they seem to be sorted. llvm-svn: 182666
This commit is contained in:
@@ -620,9 +620,10 @@ void CodeGenModule::SetLLVMFunctionAttributesForDefinition(const Decl *D,
|
||||
B.addAttribute(llvm::Attribute::AlwaysInline);
|
||||
}
|
||||
|
||||
// FIXME: Communicate hot and cold attributes to LLVM more directly.
|
||||
if (D->hasAttr<ColdAttr>())
|
||||
if (D->hasAttr<ColdAttr>()) {
|
||||
B.addAttribute(llvm::Attribute::OptimizeForSize);
|
||||
B.addAttribute(llvm::Attribute::Cold);
|
||||
}
|
||||
|
||||
if (D->hasAttr<MinSizeAttr>())
|
||||
B.addAttribute(llvm::Attribute::MinSize);
|
||||
|
||||
Reference in New Issue
Block a user