diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2009-03-26 07:32:37 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2009-03-26 07:32:37 +0000 |
commit | 6568eef9f90d7c843676f47ee2938a8af2600bf3 (patch) | |
tree | cd98ba9f72cc6561fba9c5d9631234b5930eae57 /clang/lib/Sema/SemaStmt.cpp | |
parent | 55a2cd736d91e024ea5718f80edadff8c24434b7 (diff) | |
download | bcm5719-llvm-6568eef9f90d7c843676f47ee2938a8af2600bf3.tar.gz bcm5719-llvm-6568eef9f90d7c843676f47ee2938a8af2600bf3.zip |
Sanity-check argument to indirect goto.
llvm-svn: 67746
Diffstat (limited to 'clang/lib/Sema/SemaStmt.cpp')
-rw-r--r-- | clang/lib/Sema/SemaStmt.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaStmt.cpp b/clang/lib/Sema/SemaStmt.cpp index 4ef0fda3612..bbcc71d6e4d 100644 --- a/clang/lib/Sema/SemaStmt.cpp +++ b/clang/lib/Sema/SemaStmt.cpp @@ -687,10 +687,14 @@ Sema::ActOnGotoStmt(SourceLocation GotoLoc, SourceLocation LabelLoc, Action::OwningStmtResult Sema::ActOnIndirectGotoStmt(SourceLocation GotoLoc,SourceLocation StarLoc, ExprArg DestExp) { - // FIXME: Verify that the operand is convertible to void*. // Convert operand to void* - Expr* E = (Expr*)DestExp.release(); - ImpCastExprToType(E, Context.VoidPtrTy); + Expr* E = DestExp.takeAs<Expr>(); + QualType ETy = E->getType(); + AssignConvertType ConvTy = + CheckSingleAssignmentConstraints(Context.VoidPtrTy, E); + if (DiagnoseAssignmentResult(ConvTy, StarLoc, Context.VoidPtrTy, ETy, + E, "passing")) + return StmtError(); return Owned(new (Context) IndirectGotoStmt(E)); } |