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