blob: e5114a5b0db9aa53fdce51f5a1c33d305f8cec2d [file] [log] [blame]
Argyrios Kyrtzidis981b6fd2010-11-09 01:30:48 +00001// RUN: %clang_cc1 -triple i386-unknown-unknown %s -emit-llvm -o - | FileCheck %s
Eli Friedman8f39f5e2008-12-20 23:11:59 +00002
3int b(char* x);
4
5// Extremely basic VLA test
6void a(int x) {
7 char arry[x];
8 arry[0] = 10;
9 b(arry);
10}
Anders Carlssonb50525b2008-12-21 03:33:21 +000011
Anders Carlsson02697092008-12-21 03:40:32 +000012int c(int n)
Anders Carlssonb50525b2008-12-21 03:33:21 +000013{
Anders Carlsson02697092008-12-21 03:40:32 +000014 return sizeof(int[n]);
Anders Carlssonb50525b2008-12-21 03:33:21 +000015}
Anders Carlssonc756a8e2009-02-09 21:48:07 +000016
17int f0(int x) {
18 int vla[x];
19 return vla[x-1];
20}
Anders Carlsson22ab8d82009-02-10 22:50:24 +000021
22void
23f(int count)
24{
25 int a[count];
26
27 do { } while (0);
28
29 if (a[0] != 3) {
30 }
31}
Eli Friedmanbdad6b62009-05-29 19:23:46 +000032
33void g(int count) {
34 // Make sure we emit sizes correctly in some obscure cases
35 int (*a[5])[count];
36 int (*b)[][count];
37}
Argyrios Kyrtzidis4ada2ca2010-09-14 00:42:34 +000038
39// rdar://8403108
40// CHECK: define void @f_8403108
41void f_8403108(unsigned x) {
42 // CHECK: call i8* @llvm.stacksave()
43 char s1[x];
44 while (1) {
45 // CHECK: call i8* @llvm.stacksave()
46 char s2[x];
47 if (1)
48 break;
49 // CHECK: call void @llvm.stackrestore(i8*
50 }
51 // CHECK: call void @llvm.stackrestore(i8*
52}
Fariborz Jahanianf4435702010-09-21 22:53:33 +000053
54// pr7827
Fariborz Jahanian745da3a2010-09-24 17:30:16 +000055void function(short width, int data[][width]) {} // expected-note {{passing argument to parameter 'data' here}}
Fariborz Jahanianf4435702010-09-21 22:53:33 +000056
57void test() {
Fariborz Jahanian745da3a2010-09-24 17:30:16 +000058 int bork[4][13];
Fariborz Jahanianf4435702010-09-21 22:53:33 +000059 // CHECK: call void @function(i16 signext 1, i32* null)
60 function(1, 0);
Fariborz Jahanian745da3a2010-09-24 17:30:16 +000061 // CHECK: call void @function(i16 signext 1, i32* inttoptr
62 function(1, 0xbadbeef); // expected-warning {{incompatible integer to pointer conversion passing}}
63 // CHECK: call void @function(i16 signext 1, i32* {{.*}})
64 function(1, bork);
65}
66
67void function1(short width, int data[][width][width]) {}
68void test1() {
69 int bork[4][13][15];
70 // CHECK: call void @function1(i16 signext 1, i32* {{.*}})
71 function1(1, bork);
72 // CHECK: call void @function(i16 signext 1, i32* {{.*}})
73 function(1, bork[2]);
Fariborz Jahanianf4435702010-09-21 22:53:33 +000074}
75
Fariborz Jahanianc5be7b02010-09-28 20:42:35 +000076// rdar://8476159
77static int GLOB;
78int test2(int n)
79{
80 GLOB = 0;
81 char b[1][n+3]; /* Variable length array. */
82 // CHECK: [[tmp_1:%.*]] = load i32* @GLOB, align 4
83 // CHECK-NEXT: add nsw i32 [[tmp_1]], 1
84 __typeof__(b[GLOB++]) c;
85 return GLOB;
86}
87
Argyrios Kyrtzidis981b6fd2010-11-09 01:30:48 +000088// http://llvm.org/PR8567
89// CHECK: define double @test_PR8567
90double test_PR8567(int n, double (*p)[n][5]) {
91 // CHECK: store [[vla_type:.*]] %p,
Argyrios Kyrtzidis46728792010-11-09 03:43:49 +000092 // CHECK: load i32*
Argyrios Kyrtzidis981b6fd2010-11-09 01:30:48 +000093 // CHECK-NEXT: mul i32 40
94 // CHECK-NEXT: [[byte_idx:%.*]] = mul i32 1
95 // CHECK-NEXT: [[tmp_1:%.*]] = load [[vla_type]]*
96 // CHECK-NEXT: [[tmp_2:%.*]] = bitcast [[vla_type]] [[tmp_1]] to i8*
97 // CHECK-NEXT: [[idx:%.*]] = getelementptr inbounds i8* [[tmp_2]], i32 [[byte_idx]]
98 // CHECK-NEXT: bitcast i8* [[idx]] to [[vla_type]]
99 return p[1][2][3];
100}