зеркало из https://github.com/microsoft/clang-1.git
Add a test case for the divide-by-zero fix in r137234
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@137240 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
18f169770d
Коммит
d10f4bc5a0
|
@ -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
|
||||
|
|
|
@ -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}}
|
||||
}
|
Загрузка…
Ссылка в новой задаче