aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-05-03 18:11:37 +0000
committerDouglas Gregor <dgregor@apple.com>2011-05-03 18:11:37 +0000
commite452c78072156c14cd9998733e3b4b28b6fc7fd7 (patch)
treee7dcfa2b59e65674d476b82470ce872f2f52e7ac
parent2bc0e5d955dbee5518afa59e1c66025a78b097f1 (diff)
Only check the use of memset() if we're refering to a C function named
'memset' with external linkage. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@130770 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Sema/SemaChecking.cpp4
-rw-r--r--test/SemaCXX/warn-non-pod-memset.cpp9
2 files changed, 11 insertions, 2 deletions
diff --git a/lib/Sema/SemaChecking.cpp b/lib/Sema/SemaChecking.cpp
index dcfb7cc521..ee1a924e5a 100644
--- a/lib/Sema/SemaChecking.cpp
+++ b/lib/Sema/SemaChecking.cpp
@@ -319,7 +319,9 @@ bool Sema::CheckFunctionCall(FunctionDecl *FDecl, CallExpr *TheCall) {
}
// Memset handling
- if (FnInfo->isStr("memset"))
+ if (FnInfo->isStr("memset") &&
+ FDecl->getLinkage() == ExternalLinkage &&
+ (!getLangOptions().CPlusPlus || FDecl->isExternC()))
CheckMemsetArguments(TheCall);
return false;
diff --git a/test/SemaCXX/warn-non-pod-memset.cpp b/test/SemaCXX/warn-non-pod-memset.cpp
index fbdceadae2..9023793bd5 100644
--- a/test/SemaCXX/warn-non-pod-memset.cpp
+++ b/test/SemaCXX/warn-non-pod-memset.cpp
@@ -1,6 +1,6 @@
// RUN: %clang_cc1 -fsyntax-only -Wnon-pod-memset -verify %s
-extern void *memset(void *, int, unsigned);
+extern "C" void *memset(void *, int, unsigned);
// Several POD types that should not warn.
struct S1 {} s1;
@@ -61,3 +61,10 @@ void test_nowarn(void *void_ptr) {
// Dead code shouldn't warn.
if (false) memset(&x1, 0, sizeof x1);
}
+
+namespace N {
+ void *memset(void *, int, unsigned);
+ void test_nowarn() {
+ N::memset(&x1, 0, sizeof x1);
+ }
+}