[cfe-commits] r68435 - in /cfe/trunk: include/clang/Basic/DiagnosticSemaKinds.td lib/Sema/SemaExpr.cpp test/Sema/varargs-x86-64.c test/Sema/varargs.c
Chris Lattner
sabre at nondot.org
Sat Apr 4 17:59:54 PDT 2009
Author: lattner
Date: Sat Apr 4 19:59:53 2009
New Revision: 68435
URL: http://llvm.org/viewvc/llvm-project?rev=68435&view=rev
Log:
Add a warning for questionable va_args usage.
Added:
cfe/trunk/test/Sema/varargs-x86-64.c
Modified:
cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td
cfe/trunk/lib/Sema/SemaExpr.cpp
cfe/trunk/test/Sema/varargs.c
Modified: cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td?rev=68435&r1=68434&r2=68435&view=diff
==============================================================================
--- cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td (original)
+++ cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td Sat Apr 4 19:59:53 2009
@@ -1464,6 +1464,8 @@
"'va_start' used in function with fixed args">;
def warn_second_parameter_of_va_start_not_last_named_argument : Warning<
"second parameter of 'va_start' not last named argument">;
+def warn_va_arg_with_qualified_va_list : Warning<
+ "va_arg applied to va_list type %0 with unexpected qualifiers">;
def err_first_argument_to_va_arg_not_of_type_va_list : Error<
"first argument to 'va_arg' is of type %0 and not 'va_list'">;
Modified: cfe/trunk/lib/Sema/SemaExpr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaExpr.cpp?rev=68435&r1=68434&r2=68435&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaExpr.cpp (original)
+++ cfe/trunk/lib/Sema/SemaExpr.cpp Sat Apr 4 19:59:53 2009
@@ -4726,11 +4726,18 @@
AssignConvertType ConvResult =
CheckAssignmentConstraints(VaListType, E->getType());
- if (ConvResult != Compatible &&
- ConvResult != CompatiblePointerDiscardsQualifiers)
+ switch (ConvResult) {
+ case Compatible: break; // Everything good.
+ case CompatiblePointerDiscardsQualifiers:
+ Diag(E->getLocStart(), diag::warn_va_arg_with_qualified_va_list)
+ << E->getType() << E->getSourceRange();
+ break;
+
+ default:
return ExprError(Diag(E->getLocStart(),
diag::err_first_argument_to_va_arg_not_of_type_va_list)
<< E->getType() << E->getSourceRange());
+ }
// FIXME: Check that type is complete/non-abstract
// FIXME: Warn if a non-POD type is passed in.
Added: cfe/trunk/test/Sema/varargs-x86-64.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/varargs-x86-64.c?rev=68435&view=auto
==============================================================================
--- cfe/trunk/test/Sema/varargs-x86-64.c (added)
+++ cfe/trunk/test/Sema/varargs-x86-64.c Sat Apr 4 19:59:53 2009
@@ -0,0 +1,8 @@
+// RUN: clang-cc -fsyntax-only -verify %s -triple x86_64-apple-darwin9
+
+// rdar://6726818
+void f1() {
+ const __builtin_va_list args2;
+ (void)__builtin_va_arg(args2, int); // expected-warning {{va_arg applied to va_list type 'struct __va_list_tag const *' with unexpected qualifiers}}
+}
+
Modified: cfe/trunk/test/Sema/varargs.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Sema/varargs.c?rev=68435&r1=68434&r2=68435&view=diff
==============================================================================
--- cfe/trunk/test/Sema/varargs.c (original)
+++ cfe/trunk/test/Sema/varargs.c Sat Apr 4 19:59:53 2009
@@ -61,9 +61,3 @@
__builtin_va_end(ap);
}
-// rdar://6726818
-void f8() {
- const __builtin_va_list args2;
- (void)__builtin_va_arg(args2, int);
-}
-
More information about the cfe-commits
mailing list