[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / AArch64 / urem-seteq-illegal-types.ll
blob4e10b50ba57c399d2973afb44f4b663d4092869f
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=aarch64-unknown-linux-gnu < %s | FileCheck %s
4 define i1 @test_urem_odd(i13 %X) nounwind {
5 ; CHECK-LABEL: test_urem_odd:
6 ; CHECK:       // %bb.0:
7 ; CHECK-NEXT:    mov w8, #3277
8 ; CHECK-NEXT:    mul w8, w0, w8
9 ; CHECK-NEXT:    and w8, w8, #0x1fff
10 ; CHECK-NEXT:    cmp w8, #1639
11 ; CHECK-NEXT:    cset w0, lo
12 ; CHECK-NEXT:    ret
13   %urem = urem i13 %X, 5
14   %cmp = icmp eq i13 %urem, 0
15   ret i1 %cmp
18 define i1 @test_urem_even(i27 %X) nounwind {
19 ; CHECK-LABEL: test_urem_even:
20 ; CHECK:       // %bb.0:
21 ; CHECK-NEXT:    mov w8, #28087
22 ; CHECK-NEXT:    movk w8, #1755, lsl #16
23 ; CHECK-NEXT:    mul w8, w0, w8
24 ; CHECK-NEXT:    lsl w9, w8, #26
25 ; CHECK-NEXT:    bfxil w9, w8, #1, #26
26 ; CHECK-NEXT:    and w8, w9, #0x7ffffff
27 ; CHECK-NEXT:    mov w9, #18725
28 ; CHECK-NEXT:    movk w9, #146, lsl #16
29 ; CHECK-NEXT:    cmp w8, w9
30 ; CHECK-NEXT:    cset w0, lo
31 ; CHECK-NEXT:    ret
32   %urem = urem i27 %X, 14
33   %cmp = icmp eq i27 %urem, 0
34   ret i1 %cmp
37 define i1 @test_urem_odd_setne(i4 %X) nounwind {
38 ; CHECK-LABEL: test_urem_odd_setne:
39 ; CHECK:       // %bb.0:
40 ; CHECK-NEXT:    mov w8, #13
41 ; CHECK-NEXT:    mul w8, w0, w8
42 ; CHECK-NEXT:    and w8, w8, #0xf
43 ; CHECK-NEXT:    cmp w8, #3
44 ; CHECK-NEXT:    cset w0, hi
45 ; CHECK-NEXT:    ret
46   %urem = urem i4 %X, 5
47   %cmp = icmp ne i4 %urem, 0
48   ret i1 %cmp
51 define i1 @test_urem_negative_odd(i9 %X) nounwind {
52 ; CHECK-LABEL: test_urem_negative_odd:
53 ; CHECK:       // %bb.0:
54 ; CHECK-NEXT:    mov w8, #307
55 ; CHECK-NEXT:    mul w8, w0, w8
56 ; CHECK-NEXT:    and w8, w8, #0x1ff
57 ; CHECK-NEXT:    cmp w8, #1
58 ; CHECK-NEXT:    cset w0, hi
59 ; CHECK-NEXT:    ret
60   %urem = urem i9 %X, -5
61   %cmp = icmp ne i9 %urem, 0
62   ret i1 %cmp
65 define <3 x i1> @test_urem_vec(<3 x i11> %X) nounwind {
66 ; CHECK-LABEL: test_urem_vec:
67 ; CHECK:       // %bb.0:
68 ; CHECK-NEXT:    adrp x8, .LCPI4_0
69 ; CHECK-NEXT:    ldr d1, [x8, :lo12:.LCPI4_0]
70 ; CHECK-NEXT:    fmov s0, w0
71 ; CHECK-NEXT:    adrp x9, .LCPI4_1
72 ; CHECK-NEXT:    mov v0.h[1], w1
73 ; CHECK-NEXT:    ldr d3, [x9, :lo12:.LCPI4_1]
74 ; CHECK-NEXT:    adrp x8, .LCPI4_2
75 ; CHECK-NEXT:    mov v0.h[2], w2
76 ; CHECK-NEXT:    sub v0.4h, v0.4h, v1.4h
77 ; CHECK-NEXT:    ldr d1, [x8, :lo12:.LCPI4_2]
78 ; CHECK-NEXT:    mul v0.4h, v0.4h, v3.4h
79 ; CHECK-NEXT:    adrp x8, .LCPI4_3
80 ; CHECK-NEXT:    shl v3.4h, v0.4h, #1
81 ; CHECK-NEXT:    movi d2, #0x0000000000ffff
82 ; CHECK-NEXT:    ushl v1.4h, v3.4h, v1.4h
83 ; CHECK-NEXT:    ldr d3, [x8, :lo12:.LCPI4_3]
84 ; CHECK-NEXT:    bic v0.4h, #248, lsl #8
85 ; CHECK-NEXT:    ushl v0.4h, v0.4h, v2.4h
86 ; CHECK-NEXT:    orr v0.8b, v0.8b, v1.8b
87 ; CHECK-NEXT:    bic v0.4h, #248, lsl #8
88 ; CHECK-NEXT:    cmhi v0.4h, v0.4h, v3.4h
89 ; CHECK-NEXT:    umov w0, v0.h[0]
90 ; CHECK-NEXT:    umov w1, v0.h[1]
91 ; CHECK-NEXT:    umov w2, v0.h[2]
92 ; CHECK-NEXT:    ret
93   %urem = urem <3 x i11> %X, <i11 6, i11 7, i11 -5>
94   %cmp = icmp ne <3 x i11> %urem, <i11 0, i11 1, i11 2>
95   ret <3 x i1> %cmp