Remove an untrue assertion: lval::FuncVals can be returned in both rvalue and lvalue contexts.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@57659 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Analysis/GRExprEngine.cpp b/lib/Analysis/GRExprEngine.cpp
index 2bc46d5..1c0773a 100644
--- a/lib/Analysis/GRExprEngine.cpp
+++ b/lib/Analysis/GRExprEngine.cpp
@@ -834,8 +834,10 @@
return;
} else if (const FunctionDecl* FD = dyn_cast<FunctionDecl>(D)) {
- assert(!asLValue && "FunctionDecl does not have lvalue.");
-
+ // We return the lval::FuncVal for an FunctionDecl in both rvalue
+ // and lvalue contexts.
+ // FIXME: Does this need to be revised? We were getting cases in
+ // real code that did this.
RVal V = lval::FuncVal(FD);
MakeNode(Dst, Ex, Pred, SetRVal(St, Ex, V));
return;