1; RUN: llc -march=mipsel -relocation-model=pic -O0 -fast-isel-abort=3 -mcpu=mips32r2 \ 2; RUN: -verify-machineinstrs < %s | FileCheck %s 3; RUN: llc -march=mipsel -relocation-model=pic -O0 -fast-isel-abort=3 -mcpu=mips32 \ 4; RUN: -verify-machineinstrs < %s | FileCheck %s 5 6@f1 = common global float 0.000000e+00, align 4 7@f2 = common global float 0.000000e+00, align 4 8@b1 = common global i32 0, align 4 9@d1 = common global double 0.000000e+00, align 8 10@d2 = common global double 0.000000e+00, align 8 11 12; Function Attrs: nounwind 13define void @feq1() { 14entry: 15 %0 = load float, float* @f1, align 4 16 %1 = load float, float* @f2, align 4 17 %cmp = fcmp oeq float %0, %1 18; CHECK-LABEL: feq1: 19; CHECK-DAG: lw $[[REG_F2_GOT:[0-9]+]], %got(f2)(${{[0-9]+}}) 20; CHECK-DAG: lw $[[REG_F1_GOT:[0-9]+]], %got(f1)(${{[0-9]+}}) 21; CHECK-DAG: lwc1 $f[[REG_F2:[0-9]+]], 0($[[REG_F2_GOT]]) 22; CHECK-DAG: lwc1 $f[[REG_F1:[0-9]+]], 0($[[REG_F1_GOT]]) 23; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 24; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 25; CHECK: c.eq.s $f[[REG_F1]], $f[[REG_F2]] 26; CHECK: movt $[[REG_ZERO]], $[[REG_ONE]], $fcc0 27 28 %conv = zext i1 %cmp to i32 29 store i32 %conv, i32* @b1, align 4 30 ret void 31} 32 33; Function Attrs: nounwind 34define void @fne1() { 35entry: 36 %0 = load float, float* @f1, align 4 37 %1 = load float, float* @f2, align 4 38 %cmp = fcmp une float %0, %1 39; CHECK-LABEL: fne1: 40; CHECK-DAG: lw $[[REG_F2_GOT:[0-9]+]], %got(f2)(${{[0-9]+}}) 41; CHECK-DAG: lw $[[REG_F1_GOT:[0-9]+]], %got(f1)(${{[0-9]+}}) 42; CHECK-DAG: lwc1 $f[[REG_F2:[0-9]+]], 0($[[REG_F2_GOT]]) 43; CHECK-DAG: lwc1 $f[[REG_F1:[0-9]+]], 0($[[REG_F1_GOT]]) 44; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 45; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 46; CHECK: c.eq.s $f[[REG_F1]], $f[[REG_F2]] 47; CHECK: movf $[[REG_ZERO]], $[[REG_ONE]], $fcc0 48 %conv = zext i1 %cmp to i32 49 store i32 %conv, i32* @b1, align 4 50 ret void 51} 52 53; Function Attrs: nounwind 54define void @flt1() { 55entry: 56 %0 = load float, float* @f1, align 4 57 %1 = load float, float* @f2, align 4 58 %cmp = fcmp olt float %0, %1 59; CHECK-LABEL: flt1: 60; CHECK-DAG: lw $[[REG_F2_GOT:[0-9]+]], %got(f2)(${{[0-9]+}}) 61; CHECK-DAG: lw $[[REG_F1_GOT:[0-9]+]], %got(f1)(${{[0-9]+}}) 62; CHECK-DAG: lwc1 $f[[REG_F2:[0-9]+]], 0($[[REG_F2_GOT]]) 63; CHECK-DAG: lwc1 $f[[REG_F1:[0-9]+]], 0($[[REG_F1_GOT]]) 64; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 65; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 66; CHECK: c.olt.s $f[[REG_F1]], $f[[REG_F2]] 67; CHECK: movt $[[REG_ZERO]], $[[REG_ONE]], $fcc0 68 69 %conv = zext i1 %cmp to i32 70 store i32 %conv, i32* @b1, align 4 71 ret void 72} 73 74; Function Attrs: nounwind 75define void @fgt1() { 76entry: 77 %0 = load float, float* @f1, align 4 78 %1 = load float, float* @f2, align 4 79 %cmp = fcmp ogt float %0, %1 80; CHECK-LABEL: fgt1: 81; CHECK-DAG: lw $[[REG_F2_GOT:[0-9]+]], %got(f2)(${{[0-9]+}}) 82; CHECK-DAG: lw $[[REG_F1_GOT:[0-9]+]], %got(f1)(${{[0-9]+}}) 83; CHECK-DAG: lwc1 $f[[REG_F2:[0-9]+]], 0($[[REG_F2_GOT]]) 84; CHECK-DAG: lwc1 $f[[REG_F1:[0-9]+]], 0($[[REG_F1_GOT]]) 85; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 86; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 87; CHECK: c.ule.s $f[[REG_F1]], $f[[REG_F2]] 88; CHECK: movf $[[REG_ZERO]], $[[REG_ONE]], $fcc0 89 %conv = zext i1 %cmp to i32 90 store i32 %conv, i32* @b1, align 4 91 ret void 92} 93 94; Function Attrs: nounwind 95define void @fle1() { 96entry: 97 %0 = load float, float* @f1, align 4 98 %1 = load float, float* @f2, align 4 99 %cmp = fcmp ole float %0, %1 100; CHECK-LABEL: fle1: 101; CHECK-DAG: lw $[[REG_F2_GOT:[0-9]+]], %got(f2)(${{[0-9]+}}) 102; CHECK-DAG: lw $[[REG_F1_GOT:[0-9]+]], %got(f1)(${{[0-9]+}}) 103; CHECK-DAG: lwc1 $f[[REG_F2:[0-9]+]], 0($[[REG_F2_GOT]]) 104; CHECK-DAG: lwc1 $f[[REG_F1:[0-9]+]], 0($[[REG_F1_GOT]]) 105; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 106; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 107; CHECK: c.ole.s $f[[REG_F1]], $f[[REG_F2]] 108; CHECK: movt $[[REG_ZERO]], $[[REG_ONE]], $fcc0 109 %conv = zext i1 %cmp to i32 110 store i32 %conv, i32* @b1, align 4 111 ret void 112} 113 114; Function Attrs: nounwind 115define void @fge1() { 116entry: 117 %0 = load float, float* @f1, align 4 118 %1 = load float, float* @f2, align 4 119 %cmp = fcmp oge float %0, %1 120; CHECK-LABEL: fge1: 121; CHECK-DAG: lw $[[REG_F2_GOT:[0-9]+]], %got(f2)(${{[0-9]+}}) 122; CHECK-DAG: lw $[[REG_F1_GOT:[0-9]+]], %got(f1)(${{[0-9]+}}) 123; CHECK-DAG: lwc1 $f[[REG_F2:[0-9]+]], 0($[[REG_F2_GOT]]) 124; CHECK-DAG: lwc1 $f[[REG_F1:[0-9]+]], 0($[[REG_F1_GOT]]) 125; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 126; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 127; CHECK: c.ult.s $f[[REG_F1]], $f[[REG_F2]] 128; CHECK: movf $[[REG_ZERO]], $[[REG_ONE]], $fcc0 129 %conv = zext i1 %cmp to i32 130 store i32 %conv, i32* @b1, align 4 131 ret void 132} 133 134; Function Attrs: nounwind 135define void @deq1() { 136entry: 137 %0 = load double, double* @d1, align 8 138 %1 = load double, double* @d2, align 8 139 %cmp = fcmp oeq double %0, %1 140; CHECK-LABEL: deq1: 141; CHECK-DAG: lw $[[REG_D2_GOT:[0-9]+]], %got(d2)(${{[0-9]+}}) 142; CHECK-DAG: lw $[[REG_D1_GOT:[0-9]+]], %got(d1)(${{[0-9]+}}) 143; CHECK-DAG: ldc1 $f[[REG_D2:[0-9]+]], 0($[[REG_D2_GOT]]) 144; CHECK-DAG: ldc1 $f[[REG_D1:[0-9]+]], 0($[[REG_D1_GOT]]) 145; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 146; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 147; CHECK: c.eq.d $f[[REG_D1]], $f[[REG_D2]] 148; CHECK: movt $[[REG_ZERO]], $[[REG_ONE]], $fcc0 149 %conv = zext i1 %cmp to i32 150 store i32 %conv, i32* @b1, align 4 151 ret void 152} 153 154; Function Attrs: nounwind 155define void @dne1() { 156entry: 157 %0 = load double, double* @d1, align 8 158 %1 = load double, double* @d2, align 8 159 %cmp = fcmp une double %0, %1 160; CHECK-LABEL: dne1: 161; CHECK-DAG: lw $[[REG_D2_GOT:[0-9]+]], %got(d2)(${{[0-9]+}}) 162; CHECK-DAG: lw $[[REG_D1_GOT:[0-9]+]], %got(d1)(${{[0-9]+}}) 163; CHECK-DAG: ldc1 $f[[REG_D2:[0-9]+]], 0($[[REG_D2_GOT]]) 164; CHECK-DAG: ldc1 $f[[REG_D1:[0-9]+]], 0($[[REG_D1_GOT]]) 165; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 166; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 167; CHECK: c.eq.d $f[[REG_D1]], $f[[REG_D2]] 168; CHECK: movf $[[REG_ZERO]], $[[REG_ONE]], $fcc0 169 %conv = zext i1 %cmp to i32 170 store i32 %conv, i32* @b1, align 4 171 ret void 172} 173 174; Function Attrs: nounwind 175define void @dlt1() { 176entry: 177 %0 = load double, double* @d1, align 8 178 %1 = load double, double* @d2, align 8 179 %cmp = fcmp olt double %0, %1 180; CHECK-LABEL: dlt1: 181; CHECK-DAG: lw $[[REG_D2_GOT:[0-9]+]], %got(d2)(${{[0-9]+}}) 182; CHECK-DAG: lw $[[REG_D1_GOT:[0-9]+]], %got(d1)(${{[0-9]+}}) 183; CHECK-DAG: ldc1 $f[[REG_D2:[0-9]+]], 0($[[REG_D2_GOT]]) 184; CHECK-DAG: ldc1 $f[[REG_D1:[0-9]+]], 0($[[REG_D1_GOT]]) 185; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 186; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 187; CHECK: c.olt.d $f[[REG_D1]], $f[[REG_D2]] 188; CHECK: movt $[[REG_ZERO]], $[[REG_ONE]], $fcc0 189 %conv = zext i1 %cmp to i32 190 store i32 %conv, i32* @b1, align 4 191 ret void 192} 193 194; Function Attrs: nounwind 195define void @dgt1() { 196entry: 197 %0 = load double, double* @d1, align 8 198 %1 = load double, double* @d2, align 8 199 %cmp = fcmp ogt double %0, %1 200; CHECK-LABEL: dgt1: 201; CHECK-DAG: lw $[[REG_D2_GOT:[0-9]+]], %got(d2)(${{[0-9]+}}) 202; CHECK-DAG: lw $[[REG_D1_GOT:[0-9]+]], %got(d1)(${{[0-9]+}}) 203; CHECK-DAG: ldc1 $f[[REG_D2:[0-9]+]], 0($[[REG_D2_GOT]]) 204; CHECK-DAG: ldc1 $f[[REG_D1:[0-9]+]], 0($[[REG_D1_GOT]]) 205; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 206; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 207; CHECK: c.ule.d $f[[REG_D1]], $f[[REG_D2]] 208; CHECK: movf $[[REG_ZERO]], $[[REG_ONE]], $fcc0 209 %conv = zext i1 %cmp to i32 210 store i32 %conv, i32* @b1, align 4 211 ret void 212} 213 214; Function Attrs: nounwind 215define void @dle1() { 216entry: 217 %0 = load double, double* @d1, align 8 218 %1 = load double, double* @d2, align 8 219 %cmp = fcmp ole double %0, %1 220; CHECK-LABEL: dle1: 221; CHECK-DAG: lw $[[REG_D2_GOT:[0-9]+]], %got(d2)(${{[0-9]+}}) 222; CHECK-DAG: lw $[[REG_D1_GOT:[0-9]+]], %got(d1)(${{[0-9]+}}) 223; CHECK-DAG: ldc1 $f[[REG_D2:[0-9]+]], 0($[[REG_D2_GOT]]) 224; CHECK-DAG: ldc1 $f[[REG_D1:[0-9]+]], 0($[[REG_D1_GOT]]) 225; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 226; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 227; CHECK: c.ole.d $f[[REG_D1]], $f[[REG_D2]] 228; CHECK: movt $[[REG_ZERO]], $[[REG_ONE]], $fcc0 229 %conv = zext i1 %cmp to i32 230 store i32 %conv, i32* @b1, align 4 231 ret void 232} 233 234; Function Attrs: nounwind 235define void @dge1() { 236entry: 237 %0 = load double, double* @d1, align 8 238 %1 = load double, double* @d2, align 8 239 %cmp = fcmp oge double %0, %1 240; CHECK-LABEL: dge1: 241; CHECK-DAG: lw $[[REG_D2_GOT:[0-9]+]], %got(d2)(${{[0-9]+}}) 242; CHECK-DAG: lw $[[REG_D1_GOT:[0-9]+]], %got(d1)(${{[0-9]+}}) 243; CHECK-DAG: ldc1 $f[[REG_D2:[0-9]+]], 0($[[REG_D2_GOT]]) 244; CHECK-DAG: ldc1 $f[[REG_D1:[0-9]+]], 0($[[REG_D1_GOT]]) 245; CHECK-DAG: addiu $[[REG_ZERO:[0-9]+]], $zero, 0 246; CHECK-DAG: addiu $[[REG_ONE:[0-9]+]], $zero, 1 247; CHECK: c.ult.d $f[[REG_D1]], $f[[REG_D2]] 248; CHECK: movf $[[REG_ZERO]], $[[REG_ONE]], $fcc0 249 %conv = zext i1 %cmp to i32 250 store i32 %conv, i32* @b1, align 4 251 ret void 252} 253 254 255