From: Eli Friedman Date: Thu, 26 Mar 2009 07:32:37 +0000 (+0000) Subject: Sanity-check argument to indirect goto. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=33083823342649b1fccec856c1f239c09fc0d7e1;p=clang Sanity-check argument to indirect goto. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67746 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaStmt.cpp b/lib/Sema/SemaStmt.cpp index 4ef0fda361..bbcc71d6e4 100644 --- a/lib/Sema/SemaStmt.cpp +++ b/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(); + 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)); } diff --git a/test/Sema/indirect-goto.c b/test/Sema/indirect-goto.c new file mode 100644 index 0000000000..35fb5e6315 --- /dev/null +++ b/test/Sema/indirect-goto.c @@ -0,0 +1,8 @@ +// RUN: clang-cc -fsyntax-only -verify %s + +struct c {int x;}; +int a(struct c x, long long y) { + goto *x; // expected-error{{incompatible type}} + goto *y; // expected-warning{{incompatible integer to pointer conversion}} +} +