blob: d4012794d5c723b06f515caa85c891bc3f31068a [file] [log] [blame]
Ted Kremenek722398f2012-08-24 20:39:55 +00001// RUN: %clang_cc1 -analyze -analyzer-checker=core,alpha.core,alpha.unix,alpha.security.ArrayBound -analyzer-store=region -verify %s
Jordan Rose97d2c9c2014-02-18 17:06:30 +00002// expected-no-diagnostics
Ted Kremenek3fcf6282009-07-10 21:48:10 +00003
4//===----------------------------------------------------------------------===//
5// This file tests cases where we should not flag out-of-bounds warnings.
6//===----------------------------------------------------------------------===//
Ted Kremenek238d0b62009-05-04 14:31:19 +00007
Ted Kremenek758fda42009-05-04 07:04:36 +00008void f() {
9 long x = 0;
10 char *y = (char*) &x;
11 char c = y[0] + y[1] + y[2]; // no-warning
Zhongxing Xu640aad72010-04-01 08:20:27 +000012 short *z = (short*) &x;
13 short s = z[0] + z[1]; // no-warning
Ted Kremenek758fda42009-05-04 07:04:36 +000014}
Jordy Rosec3bcc362010-06-25 23:23:04 +000015
16void g() {
17 int a[2];
18 char *b = (char*)a;
19 b[3] = 'c'; // no-warning
20}
Jordy Rose674bd552010-07-04 00:00:41 +000021
22typedef typeof(sizeof(int)) size_t;
23void *malloc(size_t);
24void free(void *);
25
26void field() {
27 struct vec { size_t len; int data[0]; };
Jordan Rose97d2c9c2014-02-18 17:06:30 +000028 struct vec *a = malloc(sizeof(struct vec) + 10*sizeof(int));
Jordy Rose674bd552010-07-04 00:00:41 +000029 a->len = 10;
30 a->data[1] = 5; // no-warning
Argyrios Kyrtzidis183f0fb2011-02-28 01:26:35 +000031 free(a);
Jordy Rose674bd552010-07-04 00:00:41 +000032}