[PATCH] D68192: Fix PR40710: Outlined Function has token parameter but isn't an intrinsic
Aditya Kumar via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Sun Sep 29 07:02:37 PDT 2019
hiraditya created this revision.
hiraditya added reviewers: compnerd, vsk, tejohnson, sebpop.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.
Code extractor outlines function with token parameter which isn't an intrinsic. This patch:
- Adds a verifier to check valid parameter types.
- Allows hotcoldsplit to bail out once input parameters are calculated (before splitting)
- Adds a sanity check using the verifier in debug mode (after splitting)
https://bugs.llvm.org/show_bug.cgi?id=40710
Repository:
rL LLVM
https://reviews.llvm.org/D68192
Files:
llvm/include/llvm/Transforms/Utils/CodeExtractor.h
llvm/lib/Transforms/IPO/HotColdSplitting.cpp
llvm/lib/Transforms/Utils/CodeExtractor.cpp
llvm/test/Transforms/HotColdSplit/token-arg.ll
Index: llvm/test/Transforms/HotColdSplit/token-arg.ll
===================================================================
--- /dev/null
+++ llvm/test/Transforms/HotColdSplit/token-arg.ll
@@ -0,0 +1,27 @@
+; RUN: opt -S %s -hotcoldsplit -o /dev/null
+define void @zot() personality i8* bitcast (i32 (...)* @bar to i8*) {
+bb:
+ invoke void @barney()
+ to label %bb1 unwind label %bb2
+
+bb1: ; preds = %bb
+ ret void
+
+bb2: ; preds = %bb
+ %tmp = cleanuppad within none []
+ br label %bb3
+
+bb3: ; preds = %bb2
+ call void @barney() [ "funclet"(token %tmp) ]
+ br label %bb4
+
+bb4: ; preds = %bb3
+ call void @barney.1() [ "funclet"(token %tmp) ]
+ unreachable
+}
+
+declare void @barney()
+
+declare i32 @bar(...)
+
+declare void @barney.1()
Index: llvm/lib/Transforms/Utils/CodeExtractor.cpp
===================================================================
--- llvm/lib/Transforms/Utils/CodeExtractor.cpp
+++ llvm/lib/Transforms/Utils/CodeExtractor.cpp
@@ -1563,5 +1563,21 @@
});
LLVM_DEBUG(if (verifyFunction(*oldFunction))
report_fatal_error("verification of oldFunction failed!"));
+ LLVM_DEBUG(if (!validInputs(inputs, *newFunction))
+ report_fatal_error("verification of newFunction args failed!"));
return newFunction;
}
+
+bool CodeExtractor::validInputs(const ValueSet &inputs, const Function &F) {
+ AttributeList Attrs = F.getAttributes();
+ unsigned i = 0;
+ for (const Value *Arg : inputs) {
+ Type *Ty = Arg->getType();
+ if (!Ty->isFirstClassType() || Ty->isMetadataTy() ||
+ Ty->isTokenTy() || Attrs.hasParamAttribute(i, Attribute::SwiftError)) {
+ return false;
+ }
+ ++i;
+ }
+ return true;
+}
Index: llvm/lib/Transforms/IPO/HotColdSplitting.cpp
===================================================================
--- llvm/lib/Transforms/IPO/HotColdSplitting.cpp
+++ llvm/lib/Transforms/IPO/HotColdSplitting.cpp
@@ -309,6 +309,11 @@
// splitting.
SetVector<Value *> Inputs, Outputs, Sinks;
CE.findInputsOutputs(Inputs, Outputs, Sinks);
+ Function *OrigF = Region[0]->getParent();
+
+ if (!CE.validInputs(Inputs, *OrigF))
+ return nullptr;
+
int OutliningBenefit = getOutliningBenefit(Region, TTI);
int OutliningPenalty =
getOutliningPenalty(Region, Inputs.size(), Outputs.size());
@@ -317,7 +322,6 @@
if (OutliningBenefit <= OutliningPenalty)
return nullptr;
- Function *OrigF = Region[0]->getParent();
if (Function *OutF = CE.extractCodeRegion()) {
User *U = *OutF->user_begin();
CallInst *CI = cast<CallInst>(U);
Index: llvm/include/llvm/Transforms/Utils/CodeExtractor.h
===================================================================
--- llvm/include/llvm/Transforms/Utils/CodeExtractor.h
+++ llvm/include/llvm/Transforms/Utils/CodeExtractor.h
@@ -106,6 +106,11 @@
/// returns false.
Function *extractCodeRegion();
+ /// Verify if args to the new function are valid.
+ /// Returns false when any argument is invalid.
+ ///
+ static bool validInputs(const ValueSet &inputs, const Function &F);
+
/// Test whether this code extractor is eligible.
///
/// Based on the blocks used when constructing the code extractor,
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D68192.222323.patch
Type: text/x-patch
Size: 3402 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190929/ac69a946/attachment.bin>
More information about the llvm-commits
mailing list