[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / CodeGen / Mips / addi.ll
blobf1db843caf64214f9f85ccc38ca4d5ddea9219e7
1 ; RUN: llc -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=16
3 @i = global i32 6, align 4
4 @j = global i32 12, align 4
5 @k = global i32 15, align 4
6 @l = global i32 20, align 4
7 @.str = private unnamed_addr constant [13 x i8] c"%i %i %i %i\0A\00", align 1
9 define void @foo() nounwind {
10 entry:
11   %0 = load i32, i32* @i, align 4
12   %add = add nsw i32 %0, 5
13   store i32 %add, i32* @i, align 4
14   %1 = load i32, i32* @j, align 4
15   %sub = sub nsw i32 %1, 5
16   store i32 %sub, i32* @j, align 4
17   %2 = load i32, i32* @k, align 4
18   %add1 = add nsw i32 %2, 10000
19   store i32 %add1, i32* @k, align 4
20   %3 = load i32, i32* @l, align 4
21   %sub2 = sub nsw i32 %3, 10000
22   store i32 %sub2, i32* @l, align 4
23 ; 16:   addiu   ${{[0-9]+}}, 5  # 16 bit inst
24 ; 16:   addiu   ${{[0-9]+}}, -5 # 16 bit inst
25 ; 16:   addiu   ${{[0-9]+}}, 10000
26 ; 16:   addiu   ${{[0-9]+}}, -10000
27   ret void