| // RUN: %clang_cc1 -w -analyze -analyzer-eagerly-assume -fcxx-exceptions -analyzer-checker=core -analyzer-checker=alpha.core.PointerArithm,alpha.core.CastToStruct -analyzer-max-loop 64 -verify %s |
| // RUN: %clang_cc1 -w -analyze -analyzer-checker=core -analyzer-checker=cplusplus -fcxx-exceptions -analyzer-checker alpha.core.PointerArithm,alpha.core.CastToStruct -analyzer-max-loop 63 -verify %s |
| |
| // These tests used to hit an assertion in the bug report. Test case from http://llvm.org/PR24184. |
| typedef struct { |
| int cbData; |
| unsigned pbData; |
| } CRYPT_DATA_BLOB; |
| |
| typedef enum { DT_NONCE_FIXED } DATA_TYPE; |
| int a; |
| typedef int *vcreate_t(int *, DATA_TYPE, int, int); |
| void fn1(unsigned, unsigned) { |
| char b = 0; |
| for (; 1; a++, &b + a * 0) |
| ; |
| } |
| |
| vcreate_t fn2; |
| struct A { |
| CRYPT_DATA_BLOB value; |
| int m_fn1() { |
| int c; |
| value.pbData == 0; |
| fn1(0, 0); |
| } |
| }; |
| struct B { |
| A IkeHashAlg; |
| A IkeGType; |
| A NoncePhase1_r; |
| }; |
| class C { |
| int m_fn2(B *); |
| void m_fn3(B *, int, int, int); |
| }; |
| int C::m_fn2(B *p1) { |
| int *d; |
| int e = p1->IkeHashAlg.m_fn1(); |
| unsigned f = p1->IkeGType.m_fn1(), h; |
| int g; |
| d = fn2(0, DT_NONCE_FIXED, (char)0, p1->NoncePhase1_r.value.cbData); |
| h = 0 | 0; |
| m_fn3(p1, 0, 0, 0); |
| } |
| |
| // case 2: |
| typedef struct { |
| int cbData; |
| unsigned char *pbData; |
| } CRYPT_DATA_BLOB_1; |
| typedef unsigned uint32_t; |
| void fn1_1(void *p1, const void *p2) { p1 != p2; } |
| |
| void fn2_1(uint32_t *p1, unsigned char *p2, uint32_t p3) { |
| unsigned i = 0; |
| for (0; i < p3; i++) |
| fn1_1(p1 + i, p2 + i * 0); |
| } |
| |
| struct A_1 { |
| CRYPT_DATA_BLOB_1 value; |
| uint32_t m_fn1() { |
| uint32_t a; |
| if (value.pbData) |
| fn2_1(&a, value.pbData, value.cbData); |
| return 0; |
| } |
| }; |
| struct { |
| A_1 HashAlgId; |
| } *b; |
| void fn3() { |
| uint32_t c, d; |
| d = b->HashAlgId.m_fn1(); |
| d << 0 | 0 | 0; |
| c = 0; |
| 0 | 1 << 0 | 0 && b; |
| } |
| |
| // case 3: |
| struct ST { |
| char c; |
| }; |
| char *p; |
| int foo1(ST); |
| int foo2() { |
| ST *p1 = (ST *)(p); // expected-warning{{Casting a non-structure type to a structure type and accessing a field can lead to memory access errors or data corruption}} |
| while (p1->c & 0x0F || p1->c & 0x07) |
| p1 = p1 + foo1(*p1); |
| } |
| |
| int foo3(int *node) { |
| int i = foo2(); |
| if (i) |
| return foo2(); |
| } |