blob: a2771499def662983c5da838b81653f07d4f33ca [file] [log] [blame]
Bruno Cardoso Lopes29e9daa2010-07-20 07:58:51 +00001; RUN: llc < %s -march=mips -relocation-model=static | FileCheck %s
2; Fix PR7473
3
4define i32 @main() nounwind readnone {
5entry:
6 %a = alloca i32, align 4 ; <i32*> [#uses=2]
7 %c = alloca i32, align 4 ; <i32*> [#uses=2]
8 volatile store i32 1, i32* %a, align 4
9 volatile store i32 0, i32* %c, align 4
10 %0 = volatile load i32* %a, align 4 ; <i32> [#uses=1]
11 %1 = icmp eq i32 %0, 0 ; <i1> [#uses=1]
Akira Hatanaka1d6b38d2011-03-31 18:26:17 +000012; CHECK: addiu $4, $zero, 0
Bruno Cardoso Lopes29e9daa2010-07-20 07:58:51 +000013 %iftmp.0.0 = select i1 %1, i32 3, i32 0 ; <i32> [#uses=1]
14 %2 = volatile load i32* %c, align 4 ; <i32> [#uses=1]
15 %3 = icmp eq i32 %2, 0 ; <i1> [#uses=1]
Akira Hatanaka1d6b38d2011-03-31 18:26:17 +000016; CHECK: addiu $4, $zero, 3
17; CHECK: addu $2, $3, $4
Bruno Cardoso Lopes29e9daa2010-07-20 07:58:51 +000018 %iftmp.2.0 = select i1 %3, i32 0, i32 5 ; <i32> [#uses=1]
19 %4 = add nsw i32 %iftmp.2.0, %iftmp.0.0 ; <i32> [#uses=1]
20 ret i32 %4
21}