|  | // RUN: %clang_analyze_cc1 -analyzer-checker=core,alpha.core,unix,alpha.unix -std=gnu99 -analyzer-store=region -verify %s | 
|  |  | 
|  | #include "Inputs/system-header-simulator.h" | 
|  |  | 
|  | typedef __typeof(sizeof(int)) size_t; | 
|  | void *memset(void *__s, int __c, size_t __n); | 
|  | void *malloc(size_t __size); | 
|  | void free(void *__ptr); | 
|  |  | 
|  | // The store for 'a[1]' should not be removed mistakenly. SymbolicRegions may | 
|  | // also be live roots. | 
|  | void f14(int *a) { | 
|  | int i; | 
|  | a[1] = 1; | 
|  | i = a[1]; | 
|  | if (i != 1) { | 
|  | int *p = 0; | 
|  | i = *p; // no-warning | 
|  | } | 
|  | } | 
|  |  | 
|  | void foo() { | 
|  | int *x = malloc(sizeof(int)); | 
|  | memset(x, 0, sizeof(int)); | 
|  | int n = 1 / *x; // expected-warning {{Division by zero}} | 
|  | free(x); | 
|  | } | 
|  |  | 
|  | void bar() { | 
|  | int *x = malloc(sizeof(int)); | 
|  | memset(x, 0, 1); | 
|  | int n = 1 / *x; // no-warning | 
|  | free(x); | 
|  | } | 
|  |  | 
|  | void testConcreteNull() { | 
|  | int *x = 0; | 
|  | memset(x, 0, 1); // expected-warning {{Null pointer argument in call to memory set function}} | 
|  | } | 
|  |  | 
|  | void testStackArray() { | 
|  | char buf[13]; | 
|  | memset(buf, 0, 1); // no-warning | 
|  | } | 
|  |  | 
|  | void testHeapSymbol() { | 
|  | char *buf = (char *)malloc(13); | 
|  | memset(buf, 0, 1); // no-warning | 
|  | free(buf); | 
|  | } | 
|  |  | 
|  | void testStackArrayOutOfBound() { | 
|  | char buf[1]; | 
|  | memset(buf, 0, 1024); // expected-warning {{Memory set function accesses out-of-bound array element}} | 
|  | } | 
|  |  | 
|  | void testHeapSymbolOutOfBound() { | 
|  | char *buf = (char *)malloc(1); | 
|  | memset(buf, 0, 1024); // expected-warning {{Memory set function accesses out-of-bound array element}} | 
|  | free(buf); | 
|  | } | 
|  |  | 
|  | void testStackArraySameSize() { | 
|  | char buf[1]; | 
|  | memset(buf, 0, sizeof(buf)); // no-warning | 
|  | } | 
|  |  | 
|  | void testHeapSymbolSameSize() { | 
|  | char *buf = (char *)malloc(1); | 
|  | memset(buf, 0, 1); // no-warning | 
|  | free(buf); | 
|  | } |