Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / ARM / legalize-bitcast.ll
blob5b989a099c815164c45137be4a44d5c4f538ad9d
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -O0 -mtriple=armebv7 -target-abi apcs -o - %s | FileCheck %s
4 @vec6_p = external global <6 x i16>
6 define i32 @vec_to_int() {
7 ; CHECK-LABEL: vec_to_int:
8 ; CHECK:       @ %bb.0: @ %bb.0
9 ; CHECK-NEXT:    push {r4}
10 ; CHECK-NEXT:    sub sp, sp, #28
11 ; CHECK-NEXT:    movw r0, :lower16:vec6_p
12 ; CHECK-NEXT:    movt r0, :upper16:vec6_p
13 ; CHECK-NEXT:    vld1.8 {d16}, [r0]!
14 ; CHECK-NEXT:    ldr r0, [r0]
15 ; CHECK-NEXT:    @ implicit-def: $d17
16 ; CHECK-NEXT:    vmov.32 d17[0], r0
17 ; CHECK-NEXT:    vrev32.16 d18, d17
18 ; CHECK-NEXT:    vrev16.8 d16, d16
19 ; CHECK-NEXT:    @ kill: def $d16 killed $d16 def $q8
20 ; CHECK-NEXT:    vmov.f64 d17, d18
21 ; CHECK-NEXT:    vstmia sp, {d16, d17} @ 16-byte Spill
22 ; CHECK-NEXT:    b .LBB0_1
23 ; CHECK-NEXT:  .LBB0_1: @ %bb.1
24 ; CHECK-NEXT:    vldmia sp, {d16, d17} @ 16-byte Reload
25 ; CHECK-NEXT:    vrev32.16 q8, q8
26 ; CHECK-NEXT:    vmov.f64 d16, d17
27 ; CHECK-NEXT:    vmov.32 r0, d16[0]
28 ; CHECK-NEXT:    add sp, sp, #28
29 ; CHECK-NEXT:    pop {r4}
30 ; CHECK-NEXT:    bx lr
31 bb.0:
32   %vec6 = load <6 x i16>, ptr @vec6_p, align 1
33   br label %bb.1
35 bb.1:
36   %0 = bitcast <6 x i16> %vec6 to i96
37   %1 = trunc i96 %0 to i32
38   ret i32 %1
41 define i16 @int_to_vec(i80 %in) {
42 ; CHECK-LABEL: int_to_vec:
43 ; CHECK:       @ %bb.0:
44 ; CHECK-NEXT:    @ kill: def $r2 killed $r1
45 ; CHECK-NEXT:    @ kill: def $r2 killed $r0
46 ; CHECK-NEXT:    lsl r0, r0, #16
47 ; CHECK-NEXT:    orr r0, r0, r1, lsr #16
48 ; CHECK-NEXT:    @ implicit-def: $d18
49 ; CHECK-NEXT:    vmov.32 d18[0], r0
50 ; CHECK-NEXT:    @ implicit-def: $q8
51 ; CHECK-NEXT:    vmov.f64 d16, d18
52 ; CHECK-NEXT:    vrev32.16 q8, q8
53 ; CHECK-NEXT:    @ kill: def $d16 killed $d16 killed $q8
54 ; CHECK-NEXT:    vmov.u16 r0, d16[0]
55 ; CHECK-NEXT:    bx lr
56   %vec = bitcast i80 %in to <5 x i16>
57   %e0 = extractelement <5 x i16> %vec, i32 0
58   ret i16 %e0