1 ; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort=1 -mcpu=mips32r2 \ 2 ; RUN: < %s | FileCheck %s 3 ; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort=1 -mcpu=mips32 \ 4 ; RUN: < %s | FileCheck %s 5 ; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort=1 -mcpu=mips32r2 \ 6 ; RUN: < %s | FileCheck %s -check-prefix=mips32r2 7 ; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort=1 -mcpu=mips32 \ 8 ; RUN: < %s | FileCheck %s -check-prefix=mips32 9 10 @b2 = global i8 0, align 1 11 @b1 = global i8 1, align 1 12 @uc1 = global i8 0, align 1 13 @uc2 = global i8 -1, align 1 14 @sc1 = global i8 -128, align 1 15 @sc2 = global i8 127, align 1 16 @ss1 = global i16 -32768, align 2 17 @ss2 = global i16 32767, align 2 18 @us1 = global i16 0, align 2 19 @us2 = global i16 -1, align 2 20 @ssi = global i16 0, align 2 21 @ssj = global i16 0, align 2 22 @i = global i32 0, align 4 23 @j = global i32 0, align 4 24 @.str = private unnamed_addr constant [4 x i8] c"%i\0A\00", align 1 25 @.str1 = private unnamed_addr constant [7 x i8] c"%i %i\0A\00", align 1 26 27 ; Function Attrs: nounwind 28 define void @_Z3b_iv() { 29 entry: 30 ; CHECK-LABEL: .ent _Z3b_iv 31 %0 = load i8, i8* @b1, align 1 32 %tobool = trunc i8 %0 to i1 33 %frombool = zext i1 %tobool to i8 34 store i8 %frombool, i8* @b2, align 1 35 %1 = load i8, i8* @b2, align 1 36 %tobool1 = trunc i8 %1 to i1 37 %conv = zext i1 %tobool1 to i32 38 store i32 %conv, i32* @i, align 4 39 ; CHECK: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 40 ; CHECK: andi $[[REG2:[0-9]+]], $[[REG1]], 1 41 ; CHECK: sb $[[REG2]], 0(${{[0-9]+}}) 42 43 44 45 ret void 46 ; CHECK: .end _Z3b_iv 47 } 48 49 ; Function Attrs: nounwind 50 define void @_Z4uc_iv() { 51 entry: 52 ; CHECK-LABEL: .ent _Z4uc_iv 53 54 %0 = load i8, i8* @uc1, align 1 55 %conv = zext i8 %0 to i32 56 store i32 %conv, i32* @i, align 4 57 %1 = load i8, i8* @uc2, align 1 58 %conv1 = zext i8 %1 to i32 59 ; CHECK: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 60 ; CHECK: andi ${{[0-9]+}}, $[[REG1]], 255 61 62 store i32 %conv1, i32* @j, align 4 63 ret void 64 ; CHECK: .end _Z4uc_iv 65 66 } 67 68 ; Function Attrs: nounwind 69 define void @_Z4sc_iv() { 70 entry: 71 ; mips32r2-LABEL: .ent _Z4sc_iv 72 ; mips32-LABEL: .ent _Z4sc_iv 73 74 %0 = load i8, i8* @sc1, align 1 75 %conv = sext i8 %0 to i32 76 store i32 %conv, i32* @i, align 4 77 %1 = load i8, i8* @sc2, align 1 78 %conv1 = sext i8 %1 to i32 79 store i32 %conv1, i32* @j, align 4 80 ; mips32r2: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 81 ; mips32r2: seb ${{[0-9]+}}, $[[REG1]] 82 ; mips32: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 83 ; mips32: sll $[[REG2:[0-9]+]], $[[REG1]], 24 84 ; mips32: sra ${{[0-9]+}}, $[[REG2]], 24 85 86 ret void 87 ; CHECK: .end _Z4sc_iv 88 } 89 90 ; Function Attrs: nounwind 91 define void @_Z4us_iv() { 92 entry: 93 ; CHECK-LABEL: .ent _Z4us_iv 94 %0 = load i16, i16* @us1, align 2 95 %conv = zext i16 %0 to i32 96 store i32 %conv, i32* @i, align 4 97 %1 = load i16, i16* @us2, align 2 98 %conv1 = zext i16 %1 to i32 99 store i32 %conv1, i32* @j, align 4 100 ret void 101 ; CHECK: lhu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 102 ; CHECK: andi ${{[0-9]+}}, $[[REG1]], 65535 103 ; CHECK: .end _Z4us_iv 104 } 105 106 ; Function Attrs: nounwind 107 define void @_Z4ss_iv() { 108 entry: 109 ; mips32r2-LABEL: .ent _Z4ss_iv 110 ; mips32=LABEL: .ent _Z4ss_iv 111 112 %0 = load i16, i16* @ss1, align 2 113 %conv = sext i16 %0 to i32 114 store i32 %conv, i32* @i, align 4 115 %1 = load i16, i16* @ss2, align 2 116 %conv1 = sext i16 %1 to i32 117 store i32 %conv1, i32* @j, align 4 118 ; mips32r2: lhu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 119 ; mips32r2: seh ${{[0-9]+}}, $[[REG1]] 120 ; mips32: lhu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 121 ; mips32: sll $[[REG2:[0-9]+]], $[[REG1]], 16 122 ; mips32: sra ${{[0-9]+}}, $[[REG2]], 16 123 124 ret void 125 ; CHECK: .end _Z4ss_iv 126 } 127 128 ; Function Attrs: nounwind 129 define void @_Z4b_ssv() { 130 entry: 131 ; CHECK-LABEL: .ent _Z4b_ssv 132 %0 = load i8, i8* @b2, align 1 133 %tobool = trunc i8 %0 to i1 134 %conv = zext i1 %tobool to i16 135 store i16 %conv, i16* @ssi, align 2 136 ret void 137 ; CHECK: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 138 ; CHECK: andi ${{[0-9]+}}, $[[REG1]], 1 139 ; CHECK: .end _Z4b_ssv 140 } 141 142 ; Function Attrs: nounwind 143 define void @_Z5uc_ssv() { 144 entry: 145 ; CHECK-LABEL: .ent _Z5uc_ssv 146 %0 = load i8, i8* @uc1, align 1 147 %conv = zext i8 %0 to i16 148 store i16 %conv, i16* @ssi, align 2 149 %1 = load i8, i8* @uc2, align 1 150 %conv1 = zext i8 %1 to i16 151 ; CHECK: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 152 ; CHECK: andi ${{[0-9]+}}, $[[REG1]], 255 153 154 store i16 %conv1, i16* @ssj, align 2 155 ret void 156 ; CHECK: .end _Z5uc_ssv 157 } 158 159 ; Function Attrs: nounwind 160 define void @_Z5sc_ssv() { 161 entry: 162 ; mips32r2-LABEL: .ent _Z5sc_ssv 163 ; mips32-LABEL: .ent _Z5sc_ssv 164 %0 = load i8, i8* @sc1, align 1 165 %conv = sext i8 %0 to i16 166 store i16 %conv, i16* @ssi, align 2 167 %1 = load i8, i8* @sc2, align 1 168 %conv1 = sext i8 %1 to i16 169 store i16 %conv1, i16* @ssj, align 2 170 ; mips32r2: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 171 ; mips32r2: seb ${{[0-9]+}}, $[[REG1]] 172 ; mips32: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}}) 173 ; mips32: sll $[[REG2:[0-9]+]], $[[REG1]], 24 174 ; mips32: sra ${{[0-9]+}}, $[[REG2]], 24 175 176 ret void 177 ; CHECK: .end _Z5sc_ssv 178 } 179 180