comparison test/Other/lint.ll @ 3:9ad51c7bc036

1st commit. remove git dir and add all files.
author Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
date Wed, 15 May 2013 06:43:32 +0900
parents
children afa8332a0e37
comparison
equal deleted inserted replaced
-1:000000000000 3:9ad51c7bc036
1 ; RUN: opt -basicaa -lint -disable-output < %s 2>&1 | FileCheck %s
2 target datalayout = "e-p:64:64:64"
3
4 declare fastcc void @bar()
5 declare void @llvm.stackrestore(i8*)
6 declare void @llvm.memcpy.p0i8.p0i8.i64(i8* nocapture, i8* nocapture, i64, i32, i1) nounwind
7 declare void @has_sret(i8* sret %p)
8 declare void @has_noaliases(i32* noalias %p, i32* %q)
9 declare void @one_arg(i32)
10
11 @CG = constant i32 7
12 @E = external global i8
13
14 define i32 @foo() noreturn {
15 %buf = alloca i8
16 %buf2 = alloca {i8, i8}, align 2
17 ; CHECK: Caller and callee calling convention differ
18 call void @bar()
19 ; CHECK: Null pointer dereference
20 store i32 0, i32* null
21 ; CHECK: Null pointer dereference
22 %t = load i32* null
23 ; CHECK: Undef pointer dereference
24 store i32 0, i32* undef
25 ; CHECK: Undef pointer dereference
26 %u = load i32* undef
27 ; CHECK: All-ones pointer dereference
28 store i32 0, i32* inttoptr (i64 -1 to i32*)
29 ; CHECK: Address one pointer dereference
30 store i32 0, i32* inttoptr (i64 1 to i32*)
31 ; CHECK: Memory reference address is misaligned
32 store i8 0, i8* %buf, align 2
33 ; CHECK: Memory reference address is misaligned
34 %gep = getelementptr {i8, i8}* %buf2, i32 0, i32 1
35 store i8 0, i8* %gep, align 2
36 ; CHECK: Division by zero
37 %sd = sdiv i32 2, 0
38 ; CHECK: Division by zero
39 %ud = udiv i32 2, 0
40 ; CHECK: Division by zero
41 %sr = srem i32 2, 0
42 ; CHECK: Division by zero
43 %ur = urem i32 2, 0
44 ; CHECK: extractelement index out of range
45 %ee = extractelement <4 x i32> zeroinitializer, i32 4
46 ; CHECK: insertelement index out of range
47 %ie = insertelement <4 x i32> zeroinitializer, i32 0, i32 4
48 ; CHECK: Shift count out of range
49 %r = lshr i32 0, 32
50 ; CHECK: Shift count out of range
51 %q = ashr i32 0, 32
52 ; CHECK: Shift count out of range
53 %l = shl i32 0, 32
54 ; CHECK: xor(undef, undef)
55 %xx = xor i32 undef, undef
56 ; CHECK: sub(undef, undef)
57 %xs = sub i32 undef, undef
58
59 ; CHECK: Write to read-only memory
60 store i32 8, i32* @CG
61 ; CHECK: Write to text section
62 store i32 8, i32* bitcast (i32()* @foo to i32*)
63 ; CHECK: Load from block address
64 %lb = load i32* bitcast (i8* blockaddress(@foo, %next) to i32*)
65 ; CHECK: Call to block address
66 call void()* bitcast (i8* blockaddress(@foo, %next) to void()*)()
67 ; CHECK: Undefined behavior: Null pointer dereference
68 call void @llvm.stackrestore(i8* null)
69 ; CHECK: Undefined behavior: Null pointer dereference
70 call void @has_sret(i8* null)
71 ; CHECK: Unusual: noalias argument aliases another argument
72 call void @has_noaliases(i32* @CG, i32* @CG)
73 ; CHECK: Call argument count mismatches callee argument count
74 call void (i32, i32)* bitcast (void (i32)* @one_arg to void (i32, i32)*)(i32 0, i32 0)
75 ; CHECK: Call argument count mismatches callee argument count
76 call void ()* bitcast (void (i32)* @one_arg to void ()*)()
77 ; CHECK: Call argument type mismatches callee parameter type
78 call void (float)* bitcast (void (i32)* @one_arg to void (float)*)(float 0.0)
79
80 ; CHECK: Write to read-only memory
81 call void @llvm.memcpy.p0i8.p0i8.i64(i8* bitcast (i32* @CG to i8*), i8* bitcast (i32* @CG to i8*), i64 1, i32 1, i1 0)
82
83 ; CHECK: Undefined behavior: Buffer overflow
84 %wider = bitcast i8* %buf to i16*
85 store i16 0, i16* %wider
86 ; CHECK: Undefined behavior: Buffer overflow
87 %inner = getelementptr {i8, i8}* %buf2, i32 0, i32 1
88 %wider2 = bitcast i8* %inner to i16*
89 store i16 0, i16* %wider2
90 ; CHECK: Undefined behavior: Buffer overflow
91 %before = getelementptr i8* %buf, i32 -1
92 %wider3 = bitcast i8* %before to i16*
93 store i16 0, i16* %wider3
94
95 br label %next
96
97 next:
98 ; CHECK: Static alloca outside of entry block
99 %a = alloca i32
100 ; CHECK: Return statement in function with noreturn attribute
101 ret i32 0
102
103 foo:
104 ; CHECK-NOT: Undefined behavior: Buffer overflow
105 ; CHECK-NOT: Memory reference address is misaligned
106 %e = bitcast i8* @E to i64*
107 store i64 0, i64* %e
108 %z = add i32 0, 0
109 ; CHECK: unreachable immediately preceded by instruction without side effects
110 unreachable
111 }
112
113 ; CHECK: Unnamed function with non-local linkage
114 define void @0() nounwind {
115 ret void
116 }
117
118 ; CHECK: va_start called in a non-varargs function
119 declare void @llvm.va_start(i8*)
120 define void @not_vararg(i8* %p) nounwind {
121 call void @llvm.va_start(i8* %p)
122 ret void
123 }
124
125 ; CHECK: Undefined behavior: Branch to non-blockaddress
126 define void @use_indbr() {
127 indirectbr i8* bitcast (i32()* @foo to i8*), [label %block]
128 block:
129 unreachable
130 }
131
132 ; CHECK: Undefined behavior: Call with "tail" keyword references alloca
133 declare void @tailcallee(i8*)
134 define void @use_tail(i8* %valist) {
135 %t = alloca i8
136 tail call void @tailcallee(i8* %t)
137 ret void
138 }
139
140 ; CHECK: Unusual: Returning alloca value
141 define i8* @return_local(i32 %n, i32 %m) {
142 %t = alloca i8, i32 %n
143 %s = getelementptr i8* %t, i32 %m
144 ret i8* %s
145 }
146
147 ; CHECK: Unusual: Returning alloca value
148 define i32* @return_obscured_local() {
149 entry:
150 %retval = alloca i32*
151 %x = alloca i32
152 store i32* %x, i32** %retval
153 br label %next
154 next:
155 %t0 = load i32** %retval
156 %t1 = insertvalue { i32, i32, i32* } zeroinitializer, i32* %t0, 2
157 %t2 = extractvalue { i32, i32, i32* } %t1, 2
158 br label %exit
159 exit:
160 %t3 = phi i32* [ %t2, %next ]
161 %t4 = bitcast i32* %t3 to i32*
162 %t5 = ptrtoint i32* %t4 to i64
163 %t6 = add i64 %t5, 0
164 %t7 = inttoptr i64 %t6 to i32*
165 ret i32* %t7
166 }
167
168 ; CHECK: Undefined behavior: Undef pointer dereference
169 define i32* @self_reference() {
170 entry:
171 unreachable
172 exit:
173 %t3 = phi i32* [ %t4, %exit ]
174 %t4 = bitcast i32* %t3 to i32*
175 %x = load volatile i32* %t3
176 br label %exit
177 }
178
179 ; CHECK: Call return type mismatches callee return type
180 %struct = type { double, double }
181 declare i32 @nonstruct_callee() nounwind
182 define void @struct_caller() nounwind {
183 entry:
184 call %struct bitcast (i32 ()* @foo to %struct ()*)()
185
186 ; CHECK: Undefined behavior: indirectbr with no destinations
187 indirectbr i8* null, []
188 }