Add a test case for the divide-by-zero fix in r137234

llvm-svn: 137240
This commit is contained in:
Kaelyn Uhrain 2011-08-10 19:47:25 +00:00
parent 410a11fe82
commit 0fb0bb179a
2 changed files with 15 additions and 0 deletions

View File

@ -3553,6 +3553,7 @@ void Sema::CheckArrayAccess(const Expr *BaseExpr, const Expr *IndexExpr,
// Make sure we're comparing apples to apples when comparing index to size
uint64_t ptrarith_typesize = Context.getTypeSize(EffectiveType);
uint64_t array_typesize = Context.getTypeSize(BaseType);
// Handle ptrarith_typesize being zero, such as when casting to void*
if (!ptrarith_typesize) ptrarith_typesize = 1;
if (ptrarith_typesize != array_typesize) {
// There's a cast to a different size type involved

View File

@ -0,0 +1,14 @@
// RUN: %clang_cc1 -verify -Warray-bounds-pointer-arithmetic %s
// Test case from PR10615
struct ext2_super_block{
unsigned char s_uuid[8]; // expected-note {{declared here}}
};
void* ext2_statfs (struct ext2_super_block *es,int a)
{
return (void *)es->s_uuid + sizeof(int); // no-warning
}
void* broken (struct ext2_super_block *es,int a)
{
return (void *)es->s_uuid + 80; // expected-warning {{refers past the end of the array}}
}