xref: /llvm-project/llvm/test/CodeGen/ARM/scalarize-assert-zext.ll (revision ab9a80a3ad78f611fd06cd6f7215bd828809310c)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
2; RUN: llc -mtriple=armv7-unknown-linux-musleabihf -mattr=-neon %s -o - | FileCheck %s
3
4declare fastcc noundef range(i16 0, 256) <4 x i16> @other()
5
6define void @test(ptr %0) #0 {
7; CHECK-LABEL: test:
8; CHECK:       @ %bb.0: @ %entry
9; CHECK-NEXT:    .save {r4, lr}
10; CHECK-NEXT:    push {r4, lr}
11; CHECK-NEXT:    mov r4, r0
12; CHECK-NEXT:    bl other
13; CHECK-NEXT:    uxth r3, r3
14; CHECK-NEXT:    uxth r2, r2
15; CHECK-NEXT:    uxth r1, r1
16; CHECK-NEXT:    uxth r0, r0
17; CHECK-NEXT:    strb r3, [r4, #3]
18; CHECK-NEXT:    strb r2, [r4, #2]
19; CHECK-NEXT:    strb r1, [r4, #1]
20; CHECK-NEXT:    strb r0, [r4]
21; CHECK-NEXT:    pop {r4, pc}
22entry:
23  %call = call fastcc <4 x i16> @other()
24  %t = trunc <4 x i16> %call to <4 x i8>
25  store <4 x i8> %t, ptr %0, align 1
26  ret void
27}
28
29define <4 x i16> @test2() #0 {
30; CHECK-LABEL: test2:
31; CHECK:       @ %bb.0: @ %entry
32; CHECK-NEXT:    .save {r11, lr}
33; CHECK-NEXT:    push {r11, lr}
34; CHECK-NEXT:    bl other
35; CHECK-NEXT:    movw r1, #65408
36; CHECK-NEXT:    and r0, r0, r1
37; CHECK-NEXT:    and r2, r2, r1
38; CHECK-NEXT:    mov r1, #0
39; CHECK-NEXT:    mov r3, #0
40; CHECK-NEXT:    pop {r11, pc}
41entry:
42  %call = call fastcc <4 x i16> @other()
43  %a = and <4 x i16> %call, <i16 u0x80, i16 u0x100, i16 u0x80, i16 u0x100>
44  ret <4 x i16> %a
45}
46
47