diff options
author | Chris Lattner <sabre@nondot.org> | 2011-08-02 21:44:23 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2011-08-02 21:44:23 +0000 |
commit | 9e6a1caf18565849cc7bec265bcb0b8af4e1d93a (patch) | |
tree | fe47a898ffd937a30b419e2c59f8ebc583d3da9f /test/SemaCXX/array-bounds.cpp | |
parent | fc6142779f42058b4a39a29b6209a01a6de9fe7c (diff) |
disable array bounds overflow warning for cases where an array
has a single element. This disables the warning in cases where
there is a clear bug, but this is really rare (who uses arrays
with one element?) and it also silences a large class of false
positive issues with C89 code that is using tail padding in structs.
A better version of this patch would detect when an array is in
a tail position in a struct, but at least patch fixes the huge
false positives that are hitting postgres and other code.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@136724 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/SemaCXX/array-bounds.cpp')
-rw-r--r-- | test/SemaCXX/array-bounds.cpp | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/test/SemaCXX/array-bounds.cpp b/test/SemaCXX/array-bounds.cpp index 3bd6c35420..044949200e 100644 --- a/test/SemaCXX/array-bounds.cpp +++ b/test/SemaCXX/array-bounds.cpp @@ -24,8 +24,8 @@ void f1(int a[1]) { int val = a[3]; // no warning for function argumnet } -void f2(const int (&a)[1]) { // expected-note {{declared here}} - int val = a[3]; // expected-warning {{array index of '3' indexes past the end of an array (that contains 1 elements)}} +void f2(const int (&a)[2]) { // expected-note {{declared here}} + int val = a[3]; // expected-warning {{array index of '3' indexes past the end of an array (that contains 2 elements)}} } void test() { @@ -42,8 +42,8 @@ void test() { u.c[3] = 1; // no warning const int const_subscript = 3; - int array[1]; // expected-note {{declared here}} - array[const_subscript] = 0; // expected-warning {{array index of '3' indexes past the end of an array (that contains 1 elements)}} + int array[2]; // expected-note {{declared here}} + array[const_subscript] = 0; // expected-warning {{array index of '3' indexes past the end of an array (that contains 2 elements)}} int *ptr; ptr[3] = 0; // no warning for pointer references @@ -58,8 +58,8 @@ void test() { const char str2[] = "foo"; // expected-note {{declared here}} char c2 = str2[5]; // expected-warning {{array index of '5' indexes past the end of an array (that contains 4 elements)}} - int (*array_ptr)[1]; - (*array_ptr)[3] = 1; // expected-warning {{array index of '3' indexes past the end of an array (that contains 1 elements)}} + int (*array_ptr)[2]; + (*array_ptr)[3] = 1; // expected-warning {{array index of '3' indexes past the end of an array (that contains 2 elements)}} } template <int I> struct S { @@ -173,3 +173,14 @@ void test_all_enums_covered(enum Values v) { } x[2] = 0; // no-warning } + +namespace tailpad { + struct foo { + int x; + char c[1]; + }; + + char bar(struct foo *F) { + return F->c[3]; // no warning, foo could have tail padding allocated. + } +} |