Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / AArch64 / typepromotion-signed.ll
blob212f02d86850b858471c69c43591fed7e623506a
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=aarch64 %s -o - | FileCheck %s
4 define i16 @test_signed_load(ptr nocapture readonly %ptr) {
5 ; CHECK-LABEL: test_signed_load:
6 ; CHECK:       // %bb.0:
7 ; CHECK-NEXT:    ldrsh w8, [x0]
8 ; CHECK-NEXT:    tst w8, #0xffff0000
9 ; CHECK-NEXT:    cset w0, eq
10 ; CHECK-NEXT:    ret
11   %load = load i16, ptr %ptr, align 2
12   %conv0 = zext i16 %load to i32
13   %conv1 = sext i16 %load to i32
14   %cmp = icmp eq i32 %conv0, %conv1
15   %conv2 = zext i1 %cmp to i16
16   ret i16 %conv2
19 define i16 @test_ashr(i16 zeroext %arg) local_unnamed_addr #1 {
20 ; CHECK-LABEL: test_ashr:
21 ; CHECK:       // %bb.0:
22 ; CHECK-NEXT:    cmp w0, #2
23 ; CHECK-NEXT:    cset w0, lo
24 ; CHECK-NEXT:    ret
25   %cmp = icmp ult i16 %arg, 2
26   %conv = zext i1 %cmp to i16
27   ret i16 %conv
30 define i16 @test_sdiv(i16 zeroext %arg) local_unnamed_addr #1 {
31 ; CHECK-LABEL: test_sdiv:
32 ; CHECK:       // %bb.0:
33 ; CHECK-NEXT:    add w8, w0, #1
34 ; CHECK-NEXT:    and w8, w8, #0xffff
35 ; CHECK-NEXT:    cmp w8, #2
36 ; CHECK-NEXT:    cset w0, hi
37 ; CHECK-NEXT:    ret
38   %arg.off = add i16 %arg, 1
39   %1 = icmp ugt i16 %arg.off, 2
40   %conv = zext i1 %1 to i16
41   ret i16 %conv
44 define i16 @test_srem(i16 zeroext %arg) local_unnamed_addr #1 {
45 ; CHECK-LABEL: test_srem:
46 ; CHECK:       // %bb.0:
47 ; CHECK-NEXT:    tst w0, #0x3
48 ; CHECK-NEXT:    cset w0, ne
49 ; CHECK-NEXT:    ret
50   %1 = and i16 %arg, 3
51   %cmp = icmp ne i16 %1, 0
52   %conv = zext i1 %cmp to i16
53   ret i16 %conv
56 define i32 @test_signext_b(ptr nocapture readonly %ptr, i8 signext %arg) {
57 ; CHECK-LABEL: test_signext_b:
58 ; CHECK:       // %bb.0: // %entry
59 ; CHECK-NEXT:    ldrb w9, [x0]
60 ; CHECK-NEXT:    mov w8, #20894 // =0x519e
61 ; CHECK-NEXT:    add w9, w9, w1
62 ; CHECK-NEXT:    sxtb w9, w9
63 ; CHECK-NEXT:    cmp w9, #0
64 ; CHECK-NEXT:    mov w9, #42 // =0x2a
65 ; CHECK-NEXT:    csel w0, w9, w8, ge
66 ; CHECK-NEXT:    ret
67 entry:
68   %0 = load i8, ptr %ptr, align 1
69   %1 = add nuw nsw i8 %0, %arg
70   %cmp = icmp sgt i8 %1, -1
71   %res = select i1 %cmp, i32 42, i32 20894
72   ret i32 %res
75 define i32 @test_signext_b_ult_slt(ptr nocapture readonly %ptr, i8 signext %arg) {
76 ; CHECK-LABEL: test_signext_b_ult_slt:
77 ; CHECK:       // %bb.0: // %entry
78 ; CHECK-NEXT:    ldrb w9, [x0]
79 ; CHECK-NEXT:    mov w8, #57 // =0x39
80 ; CHECK-NEXT:    add w10, w9, w1, uxtb
81 ; CHECK-NEXT:    cmp w10, #127
82 ; CHECK-NEXT:    ccmp w9, #0, #0, ne
83 ; CHECK-NEXT:    mov w9, #42 // =0x2a
84 ; CHECK-NEXT:    csel w0, w9, w8, eq
85 ; CHECK-NEXT:    ret
86 entry:
87   %0 = load i8, ptr %ptr, align 1
88   %1 = add nuw nsw i8 %0, %arg
89   %cmp = icmp ne i8 %1, 127
90   %cmp.1 = icmp eq i8 %0, 0
91   %or = and i1 %cmp.1, %cmp
92   %res = select i1 %or, i32 42, i32 57
93   ret i32 %res
96 define i32 @test_signext_h(ptr nocapture readonly %ptr, i16 signext %arg) {
97 ; CHECK-LABEL: test_signext_h:
98 ; CHECK:       // %bb.0: // %entry
99 ; CHECK-NEXT:    ldrh w9, [x0]
100 ; CHECK-NEXT:    mov w8, #20894 // =0x519e
101 ; CHECK-NEXT:    add w9, w9, w1
102 ; CHECK-NEXT:    sxth w9, w9
103 ; CHECK-NEXT:    cmp w9, #0
104 ; CHECK-NEXT:    mov w9, #42 // =0x2a
105 ; CHECK-NEXT:    csel w0, w9, w8, ge
106 ; CHECK-NEXT:    ret
107 entry:
108   %0 = load i16, ptr %ptr, align 1
109   %1 = add nuw nsw i16 %0, %arg
110   %cmp = icmp sgt i16 %1, -1
111   %res = select i1 %cmp, i32 42, i32 20894
112   ret i32 %res