From: Manuel Jacob Date: Tue, 29 Dec 2015 21:57:55 +0000 (+0000) Subject: [PlaceSafepoints] Assert that the gc.safepoint_poll function is present in the module. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=df4a54ad91f3493a4009b7850a8a2da392c5f6c1;p=oota-llvm.git [PlaceSafepoints] Assert that the gc.safepoint_poll function is present in the module. If running the PlaceSafepoints pass on a module which doesn't have the gc.safepoint_poll function without disabling entry and backedge safepoints, previously the pass crashed with an obscure error because of a null pointer. Now it fails the assert instead. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@256580 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/PlaceSafepoints.cpp b/lib/Transforms/Scalar/PlaceSafepoints.cpp index 7fe286f70c4..28c610c2486 100644 --- a/lib/Transforms/Scalar/PlaceSafepoints.cpp +++ b/lib/Transforms/Scalar/PlaceSafepoints.cpp @@ -762,6 +762,7 @@ InsertSafepointPoll(Instruction *InsertBefore, // path call - where we need to insert a safepoint (parsepoint). auto *F = M->getFunction(GCSafepointPollName); + assert(F && "gc.safepoint_poll function is missing"); assert(F->getType()->getElementType() == FunctionType::get(Type::getVoidTy(M->getContext()), false) && "gc.safepoint_poll declared with wrong type");