Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / Mips / GlobalISel / llvm-ir / zextLoad_and_sextLoad.ll
blob44d351fd194c9228731983328a4b0c0ddc3f7821
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc  -O0 -mtriple=mipsel-linux-gnu -global-isel  -verify-machineinstrs %s -o -| FileCheck %s -check-prefixes=MIPS32
4 define i32 @load1_s8_to_zextLoad1_s32(ptr %px) {
5 ; MIPS32-LABEL: load1_s8_to_zextLoad1_s32:
6 ; MIPS32:       # %bb.0: # %entry
7 ; MIPS32-NEXT:    lbu $2, 0($4)
8 ; MIPS32-NEXT:    jr $ra
9 ; MIPS32-NEXT:    nop
10 entry:
11   %0 = load i8, ptr %px
12   %conv = zext i8 %0 to i32
13   ret i32 %conv
16 define i32 @load2_s16_to_zextLoad2_s32(ptr %px) {
17 ; MIPS32-LABEL: load2_s16_to_zextLoad2_s32:
18 ; MIPS32:       # %bb.0: # %entry
19 ; MIPS32-NEXT:    lhu $2, 0($4)
20 ; MIPS32-NEXT:    jr $ra
21 ; MIPS32-NEXT:    nop
22 entry:
23   %0 = load i16, ptr %px
24   %conv = zext i16 %0 to i32
25   ret i32 %conv
28 define i16 @load1_s8_to_zextLoad1_s16(ptr %px) {
29 ; MIPS32-LABEL: load1_s8_to_zextLoad1_s16:
30 ; MIPS32:       # %bb.0: # %entry
31 ; MIPS32-NEXT:    lbu $2, 0($4)
32 ; MIPS32-NEXT:    jr $ra
33 ; MIPS32-NEXT:    nop
34 entry:
35   %0 = load i8, ptr %px
36   %conv = zext i8 %0 to i16
37   ret i16 %conv
40 define zeroext i16 @load1_s8_to_zextLoad1_s16_to_zextLoad1_s32(ptr %px) {
41 ; MIPS32-LABEL: load1_s8_to_zextLoad1_s16_to_zextLoad1_s32:
42 ; MIPS32:       # %bb.0: # %entry
43 ; MIPS32-NEXT:    lbu $2, 0($4)
44 ; MIPS32-NEXT:    jr $ra
45 ; MIPS32-NEXT:    nop
46 entry:
47   %0 = load i8, ptr %px
48   %conv = zext i8 %0 to i16
49   ret i16 %conv
52 define i64 @load4_s32_to_zextLoad4_s64(ptr %px) {
53 ; MIPS32-LABEL: load4_s32_to_zextLoad4_s64:
54 ; MIPS32:       # %bb.0: # %entry
55 ; MIPS32-NEXT:    lw $2, 0($4)
56 ; MIPS32-NEXT:    ori $3, $zero, 0
57 ; MIPS32-NEXT:    jr $ra
58 ; MIPS32-NEXT:    nop
59 entry:
60   %0 = load i32, ptr %px
61   %conv = zext i32 %0 to i64
62   ret i64 %conv
65 define i32 @load1_s8_to_sextLoad1_s32(ptr %px) {
66 ; MIPS32-LABEL: load1_s8_to_sextLoad1_s32:
67 ; MIPS32:       # %bb.0: # %entry
68 ; MIPS32-NEXT:    lb $2, 0($4)
69 ; MIPS32-NEXT:    jr $ra
70 ; MIPS32-NEXT:    nop
71 entry:
72   %0 = load i8, ptr %px
73   %conv = sext i8 %0 to i32
74   ret i32 %conv
77 define i32 @load2_s16_to_sextLoad2_s32(ptr %px) {
78 ; MIPS32-LABEL: load2_s16_to_sextLoad2_s32:
79 ; MIPS32:       # %bb.0: # %entry
80 ; MIPS32-NEXT:    lh $2, 0($4)
81 ; MIPS32-NEXT:    jr $ra
82 ; MIPS32-NEXT:    nop
83 entry:
84   %0 = load i16, ptr %px
85   %conv = sext i16 %0 to i32
86   ret i32 %conv
89 define i16 @load1_s8_to_sextLoad1_s16(ptr %px) {
90 ; MIPS32-LABEL: load1_s8_to_sextLoad1_s16:
91 ; MIPS32:       # %bb.0: # %entry
92 ; MIPS32-NEXT:    lb $2, 0($4)
93 ; MIPS32-NEXT:    jr $ra
94 ; MIPS32-NEXT:    nop
95 entry:
96   %0 = load i8, ptr %px
97   %conv = sext i8 %0 to i16
98   ret i16 %conv
101 define signext i16 @load1_s8_to_sextLoad1_s16_to_sextLoad1_s32(ptr %px) {
102 ; MIPS32-LABEL: load1_s8_to_sextLoad1_s16_to_sextLoad1_s32:
103 ; MIPS32:       # %bb.0: # %entry
104 ; MIPS32-NEXT:    lb $2, 0($4)
105 ; MIPS32-NEXT:    jr $ra
106 ; MIPS32-NEXT:    nop
107 entry:
108   %0 = load i8, ptr %px
109   %conv = sext i8 %0 to i16
110   ret i16 %conv
113 define i64 @load4_s32_to_sextLoad4_s64(ptr %px) {
114 ; MIPS32-LABEL: load4_s32_to_sextLoad4_s64:
115 ; MIPS32:       # %bb.0: # %entry
116 ; MIPS32-NEXT:    lw $2, 0($4)
117 ; MIPS32-NEXT:    sra $3, $2, 31
118 ; MIPS32-NEXT:    jr $ra
119 ; MIPS32-NEXT:    nop
120 entry:
121   %0 = load i32, ptr %px
122   %conv = sext i32 %0 to i64
123   ret i64 %conv