1; RUN: llc < %s -mtriple=ve -mattr=+vpu | FileCheck %s 2 3;;; Test vector shift left arithmetic intrinsic instructions 4;;; 5;;; Note: 6;;; We test VSLA*vvl, VSLA*vvl_v, VSLA*vrl, VSLA*vrl_v, VSLA*vil, VSLA*vil_v, 7;;; VSLA*vvml_v, VSLA*vrml_v, VSLA*viml_v, PVSLA*vvl, PVSLA*vvl_v, PVSLA*vrl, 8;;; PVSLA*vrl_v, PVSLA*vvml_v, and PVSLA*vrml_v instructions. 9 10; Function Attrs: nounwind readnone 11define fastcc <256 x double> @vslawsx_vvvl(<256 x double> %0, <256 x double> %1) { 12; CHECK-LABEL: vslawsx_vvvl: 13; CHECK: # %bb.0: 14; CHECK-NEXT: lea %s0, 256 15; CHECK-NEXT: lvl %s0 16; CHECK-NEXT: vsla.w.sx %v0, %v0, %v1 17; CHECK-NEXT: b.l.t (, %s10) 18 %3 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvvl(<256 x double> %0, <256 x double> %1, i32 256) 19 ret <256 x double> %3 20} 21 22; Function Attrs: nounwind readnone 23declare <256 x double> @llvm.ve.vl.vslawsx.vvvl(<256 x double>, <256 x double>, i32) 24 25; Function Attrs: nounwind readnone 26define fastcc <256 x double> @vslawsx_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) { 27; CHECK-LABEL: vslawsx_vvvvl: 28; CHECK: # %bb.0: 29; CHECK-NEXT: lea %s0, 128 30; CHECK-NEXT: lvl %s0 31; CHECK-NEXT: vsla.w.sx %v2, %v0, %v1 32; CHECK-NEXT: lea %s16, 256 33; CHECK-NEXT: lvl %s16 34; CHECK-NEXT: vor %v0, (0)1, %v2 35; CHECK-NEXT: b.l.t (, %s10) 36 %4 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128) 37 ret <256 x double> %4 38} 39 40; Function Attrs: nounwind readnone 41declare <256 x double> @llvm.ve.vl.vslawsx.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32) 42 43; Function Attrs: nounwind readnone 44define fastcc <256 x double> @vslawsx_vvsl(<256 x double> %0, i32 signext %1) { 45; CHECK-LABEL: vslawsx_vvsl: 46; CHECK: # %bb.0: 47; CHECK-NEXT: and %s0, %s0, (32)0 48; CHECK-NEXT: lea %s1, 256 49; CHECK-NEXT: lvl %s1 50; CHECK-NEXT: vsla.w.sx %v0, %v0, %s0 51; CHECK-NEXT: b.l.t (, %s10) 52 %3 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvsl(<256 x double> %0, i32 %1, i32 256) 53 ret <256 x double> %3 54} 55 56; Function Attrs: nounwind readnone 57declare <256 x double> @llvm.ve.vl.vslawsx.vvsl(<256 x double>, i32, i32) 58 59; Function Attrs: nounwind readnone 60define fastcc <256 x double> @vslawsx_vvsvl(<256 x double> %0, i32 signext %1, <256 x double> %2) { 61; CHECK-LABEL: vslawsx_vvsvl: 62; CHECK: # %bb.0: 63; CHECK-NEXT: and %s0, %s0, (32)0 64; CHECK-NEXT: lea %s1, 128 65; CHECK-NEXT: lvl %s1 66; CHECK-NEXT: vsla.w.sx %v1, %v0, %s0 67; CHECK-NEXT: lea %s16, 256 68; CHECK-NEXT: lvl %s16 69; CHECK-NEXT: vor %v0, (0)1, %v1 70; CHECK-NEXT: b.l.t (, %s10) 71 %4 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvsvl(<256 x double> %0, i32 %1, <256 x double> %2, i32 128) 72 ret <256 x double> %4 73} 74 75; Function Attrs: nounwind readnone 76declare <256 x double> @llvm.ve.vl.vslawsx.vvsvl(<256 x double>, i32, <256 x double>, i32) 77 78; Function Attrs: nounwind readnone 79define fastcc <256 x double> @vslawsx_vvsl_imm(<256 x double> %0) { 80; CHECK-LABEL: vslawsx_vvsl_imm: 81; CHECK: # %bb.0: 82; CHECK-NEXT: lea %s0, 256 83; CHECK-NEXT: lvl %s0 84; CHECK-NEXT: vsla.w.sx %v0, %v0, 8 85; CHECK-NEXT: b.l.t (, %s10) 86 %2 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvsl(<256 x double> %0, i32 8, i32 256) 87 ret <256 x double> %2 88} 89 90; Function Attrs: nounwind readnone 91define fastcc <256 x double> @vslawsx_vvsvl_imm(<256 x double> %0, <256 x double> %1) { 92; CHECK-LABEL: vslawsx_vvsvl_imm: 93; CHECK: # %bb.0: 94; CHECK-NEXT: lea %s0, 128 95; CHECK-NEXT: lvl %s0 96; CHECK-NEXT: vsla.w.sx %v1, %v0, 8 97; CHECK-NEXT: lea %s16, 256 98; CHECK-NEXT: lvl %s16 99; CHECK-NEXT: vor %v0, (0)1, %v1 100; CHECK-NEXT: b.l.t (, %s10) 101 %3 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvsvl(<256 x double> %0, i32 8, <256 x double> %1, i32 128) 102 ret <256 x double> %3 103} 104 105; Function Attrs: nounwind readnone 106define fastcc <256 x double> @vslawsx_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) { 107; CHECK-LABEL: vslawsx_vvvmvl: 108; CHECK: # %bb.0: 109; CHECK-NEXT: lea %s0, 128 110; CHECK-NEXT: lvl %s0 111; CHECK-NEXT: vsla.w.sx %v2, %v0, %v1, %vm1 112; CHECK-NEXT: lea %s16, 256 113; CHECK-NEXT: lvl %s16 114; CHECK-NEXT: vor %v0, (0)1, %v2 115; CHECK-NEXT: b.l.t (, %s10) 116 %5 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128) 117 ret <256 x double> %5 118} 119 120; Function Attrs: nounwind readnone 121declare <256 x double> @llvm.ve.vl.vslawsx.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32) 122 123; Function Attrs: nounwind readnone 124define fastcc <256 x double> @vslawsx_vvsmvl(<256 x double> %0, i32 signext %1, <256 x i1> %2, <256 x double> %3) { 125; CHECK-LABEL: vslawsx_vvsmvl: 126; CHECK: # %bb.0: 127; CHECK-NEXT: and %s0, %s0, (32)0 128; CHECK-NEXT: lea %s1, 128 129; CHECK-NEXT: lvl %s1 130; CHECK-NEXT: vsla.w.sx %v1, %v0, %s0, %vm1 131; CHECK-NEXT: lea %s16, 256 132; CHECK-NEXT: lvl %s16 133; CHECK-NEXT: vor %v0, (0)1, %v1 134; CHECK-NEXT: b.l.t (, %s10) 135 %5 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvsmvl(<256 x double> %0, i32 %1, <256 x i1> %2, <256 x double> %3, i32 128) 136 ret <256 x double> %5 137} 138 139; Function Attrs: nounwind readnone 140declare <256 x double> @llvm.ve.vl.vslawsx.vvsmvl(<256 x double>, i32, <256 x i1>, <256 x double>, i32) 141 142; Function Attrs: nounwind readnone 143define fastcc <256 x double> @vslawsx_vvsmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) { 144; CHECK-LABEL: vslawsx_vvsmvl_imm: 145; CHECK: # %bb.0: 146; CHECK-NEXT: lea %s0, 128 147; CHECK-NEXT: lvl %s0 148; CHECK-NEXT: vsla.w.sx %v1, %v0, 8, %vm1 149; CHECK-NEXT: lea %s16, 256 150; CHECK-NEXT: lvl %s16 151; CHECK-NEXT: vor %v0, (0)1, %v1 152; CHECK-NEXT: b.l.t (, %s10) 153 %4 = tail call fast <256 x double> @llvm.ve.vl.vslawsx.vvsmvl(<256 x double> %0, i32 8, <256 x i1> %1, <256 x double> %2, i32 128) 154 ret <256 x double> %4 155} 156 157; Function Attrs: nounwind readnone 158define fastcc <256 x double> @vslawzx_vvvl(<256 x double> %0, <256 x double> %1) { 159; CHECK-LABEL: vslawzx_vvvl: 160; CHECK: # %bb.0: 161; CHECK-NEXT: lea %s0, 256 162; CHECK-NEXT: lvl %s0 163; CHECK-NEXT: vsla.w.zx %v0, %v0, %v1 164; CHECK-NEXT: b.l.t (, %s10) 165 %3 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvvl(<256 x double> %0, <256 x double> %1, i32 256) 166 ret <256 x double> %3 167} 168 169; Function Attrs: nounwind readnone 170declare <256 x double> @llvm.ve.vl.vslawzx.vvvl(<256 x double>, <256 x double>, i32) 171 172; Function Attrs: nounwind readnone 173define fastcc <256 x double> @vslawzx_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) { 174; CHECK-LABEL: vslawzx_vvvvl: 175; CHECK: # %bb.0: 176; CHECK-NEXT: lea %s0, 128 177; CHECK-NEXT: lvl %s0 178; CHECK-NEXT: vsla.w.zx %v2, %v0, %v1 179; CHECK-NEXT: lea %s16, 256 180; CHECK-NEXT: lvl %s16 181; CHECK-NEXT: vor %v0, (0)1, %v2 182; CHECK-NEXT: b.l.t (, %s10) 183 %4 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128) 184 ret <256 x double> %4 185} 186 187; Function Attrs: nounwind readnone 188declare <256 x double> @llvm.ve.vl.vslawzx.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32) 189 190; Function Attrs: nounwind readnone 191define fastcc <256 x double> @vslawzx_vvsl(<256 x double> %0, i32 signext %1) { 192; CHECK-LABEL: vslawzx_vvsl: 193; CHECK: # %bb.0: 194; CHECK-NEXT: and %s0, %s0, (32)0 195; CHECK-NEXT: lea %s1, 256 196; CHECK-NEXT: lvl %s1 197; CHECK-NEXT: vsla.w.zx %v0, %v0, %s0 198; CHECK-NEXT: b.l.t (, %s10) 199 %3 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvsl(<256 x double> %0, i32 %1, i32 256) 200 ret <256 x double> %3 201} 202 203; Function Attrs: nounwind readnone 204declare <256 x double> @llvm.ve.vl.vslawzx.vvsl(<256 x double>, i32, i32) 205 206; Function Attrs: nounwind readnone 207define fastcc <256 x double> @vslawzx_vvsvl(<256 x double> %0, i32 signext %1, <256 x double> %2) { 208; CHECK-LABEL: vslawzx_vvsvl: 209; CHECK: # %bb.0: 210; CHECK-NEXT: and %s0, %s0, (32)0 211; CHECK-NEXT: lea %s1, 128 212; CHECK-NEXT: lvl %s1 213; CHECK-NEXT: vsla.w.zx %v1, %v0, %s0 214; CHECK-NEXT: lea %s16, 256 215; CHECK-NEXT: lvl %s16 216; CHECK-NEXT: vor %v0, (0)1, %v1 217; CHECK-NEXT: b.l.t (, %s10) 218 %4 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvsvl(<256 x double> %0, i32 %1, <256 x double> %2, i32 128) 219 ret <256 x double> %4 220} 221 222; Function Attrs: nounwind readnone 223declare <256 x double> @llvm.ve.vl.vslawzx.vvsvl(<256 x double>, i32, <256 x double>, i32) 224 225; Function Attrs: nounwind readnone 226define fastcc <256 x double> @vslawzx_vvsl_imm(<256 x double> %0) { 227; CHECK-LABEL: vslawzx_vvsl_imm: 228; CHECK: # %bb.0: 229; CHECK-NEXT: lea %s0, 256 230; CHECK-NEXT: lvl %s0 231; CHECK-NEXT: vsla.w.zx %v0, %v0, 8 232; CHECK-NEXT: b.l.t (, %s10) 233 %2 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvsl(<256 x double> %0, i32 8, i32 256) 234 ret <256 x double> %2 235} 236 237; Function Attrs: nounwind readnone 238define fastcc <256 x double> @vslawzx_vvsvl_imm(<256 x double> %0, <256 x double> %1) { 239; CHECK-LABEL: vslawzx_vvsvl_imm: 240; CHECK: # %bb.0: 241; CHECK-NEXT: lea %s0, 128 242; CHECK-NEXT: lvl %s0 243; CHECK-NEXT: vsla.w.zx %v1, %v0, 8 244; CHECK-NEXT: lea %s16, 256 245; CHECK-NEXT: lvl %s16 246; CHECK-NEXT: vor %v0, (0)1, %v1 247; CHECK-NEXT: b.l.t (, %s10) 248 %3 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvsvl(<256 x double> %0, i32 8, <256 x double> %1, i32 128) 249 ret <256 x double> %3 250} 251 252; Function Attrs: nounwind readnone 253define fastcc <256 x double> @vslawzx_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) { 254; CHECK-LABEL: vslawzx_vvvmvl: 255; CHECK: # %bb.0: 256; CHECK-NEXT: lea %s0, 128 257; CHECK-NEXT: lvl %s0 258; CHECK-NEXT: vsla.w.zx %v2, %v0, %v1, %vm1 259; CHECK-NEXT: lea %s16, 256 260; CHECK-NEXT: lvl %s16 261; CHECK-NEXT: vor %v0, (0)1, %v2 262; CHECK-NEXT: b.l.t (, %s10) 263 %5 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128) 264 ret <256 x double> %5 265} 266 267; Function Attrs: nounwind readnone 268declare <256 x double> @llvm.ve.vl.vslawzx.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32) 269 270; Function Attrs: nounwind readnone 271define fastcc <256 x double> @vslawzx_vvsmvl(<256 x double> %0, i32 signext %1, <256 x i1> %2, <256 x double> %3) { 272; CHECK-LABEL: vslawzx_vvsmvl: 273; CHECK: # %bb.0: 274; CHECK-NEXT: and %s0, %s0, (32)0 275; CHECK-NEXT: lea %s1, 128 276; CHECK-NEXT: lvl %s1 277; CHECK-NEXT: vsla.w.zx %v1, %v0, %s0, %vm1 278; CHECK-NEXT: lea %s16, 256 279; CHECK-NEXT: lvl %s16 280; CHECK-NEXT: vor %v0, (0)1, %v1 281; CHECK-NEXT: b.l.t (, %s10) 282 %5 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvsmvl(<256 x double> %0, i32 %1, <256 x i1> %2, <256 x double> %3, i32 128) 283 ret <256 x double> %5 284} 285 286; Function Attrs: nounwind readnone 287declare <256 x double> @llvm.ve.vl.vslawzx.vvsmvl(<256 x double>, i32, <256 x i1>, <256 x double>, i32) 288 289; Function Attrs: nounwind readnone 290define fastcc <256 x double> @vslawzx_vvsmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) { 291; CHECK-LABEL: vslawzx_vvsmvl_imm: 292; CHECK: # %bb.0: 293; CHECK-NEXT: lea %s0, 128 294; CHECK-NEXT: lvl %s0 295; CHECK-NEXT: vsla.w.zx %v1, %v0, 8, %vm1 296; CHECK-NEXT: lea %s16, 256 297; CHECK-NEXT: lvl %s16 298; CHECK-NEXT: vor %v0, (0)1, %v1 299; CHECK-NEXT: b.l.t (, %s10) 300 %4 = tail call fast <256 x double> @llvm.ve.vl.vslawzx.vvsmvl(<256 x double> %0, i32 8, <256 x i1> %1, <256 x double> %2, i32 128) 301 ret <256 x double> %4 302} 303 304; Function Attrs: nounwind readnone 305define fastcc <256 x double> @vslal_vvvl(<256 x double> %0, <256 x double> %1) { 306; CHECK-LABEL: vslal_vvvl: 307; CHECK: # %bb.0: 308; CHECK-NEXT: lea %s0, 256 309; CHECK-NEXT: lvl %s0 310; CHECK-NEXT: vsla.l %v0, %v0, %v1 311; CHECK-NEXT: b.l.t (, %s10) 312 %3 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvvl(<256 x double> %0, <256 x double> %1, i32 256) 313 ret <256 x double> %3 314} 315 316; Function Attrs: nounwind readnone 317declare <256 x double> @llvm.ve.vl.vslal.vvvl(<256 x double>, <256 x double>, i32) 318 319; Function Attrs: nounwind readnone 320define fastcc <256 x double> @vslal_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) { 321; CHECK-LABEL: vslal_vvvvl: 322; CHECK: # %bb.0: 323; CHECK-NEXT: lea %s0, 128 324; CHECK-NEXT: lvl %s0 325; CHECK-NEXT: vsla.l %v2, %v0, %v1 326; CHECK-NEXT: lea %s16, 256 327; CHECK-NEXT: lvl %s16 328; CHECK-NEXT: vor %v0, (0)1, %v2 329; CHECK-NEXT: b.l.t (, %s10) 330 %4 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128) 331 ret <256 x double> %4 332} 333 334; Function Attrs: nounwind readnone 335declare <256 x double> @llvm.ve.vl.vslal.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32) 336 337; Function Attrs: nounwind readnone 338define fastcc <256 x double> @vslal_vvsl(<256 x double> %0, i64 %1) { 339; CHECK-LABEL: vslal_vvsl: 340; CHECK: # %bb.0: 341; CHECK-NEXT: lea %s1, 256 342; CHECK-NEXT: lvl %s1 343; CHECK-NEXT: vsla.l %v0, %v0, %s0 344; CHECK-NEXT: b.l.t (, %s10) 345 %3 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvsl(<256 x double> %0, i64 %1, i32 256) 346 ret <256 x double> %3 347} 348 349; Function Attrs: nounwind readnone 350declare <256 x double> @llvm.ve.vl.vslal.vvsl(<256 x double>, i64, i32) 351 352; Function Attrs: nounwind readnone 353define fastcc <256 x double> @vslal_vvsvl(<256 x double> %0, i64 %1, <256 x double> %2) { 354; CHECK-LABEL: vslal_vvsvl: 355; CHECK: # %bb.0: 356; CHECK-NEXT: lea %s1, 128 357; CHECK-NEXT: lvl %s1 358; CHECK-NEXT: vsla.l %v1, %v0, %s0 359; CHECK-NEXT: lea %s16, 256 360; CHECK-NEXT: lvl %s16 361; CHECK-NEXT: vor %v0, (0)1, %v1 362; CHECK-NEXT: b.l.t (, %s10) 363 %4 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvsvl(<256 x double> %0, i64 %1, <256 x double> %2, i32 128) 364 ret <256 x double> %4 365} 366 367; Function Attrs: nounwind readnone 368declare <256 x double> @llvm.ve.vl.vslal.vvsvl(<256 x double>, i64, <256 x double>, i32) 369 370; Function Attrs: nounwind readnone 371define fastcc <256 x double> @vslal_vvsl_imm(<256 x double> %0) { 372; CHECK-LABEL: vslal_vvsl_imm: 373; CHECK: # %bb.0: 374; CHECK-NEXT: lea %s0, 256 375; CHECK-NEXT: lvl %s0 376; CHECK-NEXT: vsla.l %v0, %v0, 8 377; CHECK-NEXT: b.l.t (, %s10) 378 %2 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvsl(<256 x double> %0, i64 8, i32 256) 379 ret <256 x double> %2 380} 381 382; Function Attrs: nounwind readnone 383define fastcc <256 x double> @vslal_vvsvl_imm(<256 x double> %0, <256 x double> %1) { 384; CHECK-LABEL: vslal_vvsvl_imm: 385; CHECK: # %bb.0: 386; CHECK-NEXT: lea %s0, 128 387; CHECK-NEXT: lvl %s0 388; CHECK-NEXT: vsla.l %v1, %v0, 8 389; CHECK-NEXT: lea %s16, 256 390; CHECK-NEXT: lvl %s16 391; CHECK-NEXT: vor %v0, (0)1, %v1 392; CHECK-NEXT: b.l.t (, %s10) 393 %3 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvsvl(<256 x double> %0, i64 8, <256 x double> %1, i32 128) 394 ret <256 x double> %3 395} 396 397; Function Attrs: nounwind readnone 398define fastcc <256 x double> @vslal_vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3) { 399; CHECK-LABEL: vslal_vvvmvl: 400; CHECK: # %bb.0: 401; CHECK-NEXT: lea %s0, 128 402; CHECK-NEXT: lvl %s0 403; CHECK-NEXT: vsla.l %v2, %v0, %v1, %vm1 404; CHECK-NEXT: lea %s16, 256 405; CHECK-NEXT: lvl %s16 406; CHECK-NEXT: vor %v0, (0)1, %v2 407; CHECK-NEXT: b.l.t (, %s10) 408 %5 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvvmvl(<256 x double> %0, <256 x double> %1, <256 x i1> %2, <256 x double> %3, i32 128) 409 ret <256 x double> %5 410} 411 412; Function Attrs: nounwind readnone 413declare <256 x double> @llvm.ve.vl.vslal.vvvmvl(<256 x double>, <256 x double>, <256 x i1>, <256 x double>, i32) 414 415; Function Attrs: nounwind readnone 416define fastcc <256 x double> @vslal_vvsmvl(<256 x double> %0, i64 %1, <256 x i1> %2, <256 x double> %3) { 417; CHECK-LABEL: vslal_vvsmvl: 418; CHECK: # %bb.0: 419; CHECK-NEXT: lea %s1, 128 420; CHECK-NEXT: lvl %s1 421; CHECK-NEXT: vsla.l %v1, %v0, %s0, %vm1 422; CHECK-NEXT: lea %s16, 256 423; CHECK-NEXT: lvl %s16 424; CHECK-NEXT: vor %v0, (0)1, %v1 425; CHECK-NEXT: b.l.t (, %s10) 426 %5 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvsmvl(<256 x double> %0, i64 %1, <256 x i1> %2, <256 x double> %3, i32 128) 427 ret <256 x double> %5 428} 429 430; Function Attrs: nounwind readnone 431declare <256 x double> @llvm.ve.vl.vslal.vvsmvl(<256 x double>, i64, <256 x i1>, <256 x double>, i32) 432 433; Function Attrs: nounwind readnone 434define fastcc <256 x double> @vslal_vvsmvl_imm(<256 x double> %0, <256 x i1> %1, <256 x double> %2) { 435; CHECK-LABEL: vslal_vvsmvl_imm: 436; CHECK: # %bb.0: 437; CHECK-NEXT: lea %s0, 128 438; CHECK-NEXT: lvl %s0 439; CHECK-NEXT: vsla.l %v1, %v0, 8, %vm1 440; CHECK-NEXT: lea %s16, 256 441; CHECK-NEXT: lvl %s16 442; CHECK-NEXT: vor %v0, (0)1, %v1 443; CHECK-NEXT: b.l.t (, %s10) 444 %4 = tail call fast <256 x double> @llvm.ve.vl.vslal.vvsmvl(<256 x double> %0, i64 8, <256 x i1> %1, <256 x double> %2, i32 128) 445 ret <256 x double> %4 446} 447 448; Function Attrs: nounwind readnone 449define fastcc <256 x double> @pvsla_vvvl(<256 x double> %0, <256 x double> %1) { 450; CHECK-LABEL: pvsla_vvvl: 451; CHECK: # %bb.0: 452; CHECK-NEXT: lea %s0, 256 453; CHECK-NEXT: lvl %s0 454; CHECK-NEXT: pvsla %v0, %v0, %v1 455; CHECK-NEXT: b.l.t (, %s10) 456 %3 = tail call fast <256 x double> @llvm.ve.vl.pvsla.vvvl(<256 x double> %0, <256 x double> %1, i32 256) 457 ret <256 x double> %3 458} 459 460; Function Attrs: nounwind readnone 461declare <256 x double> @llvm.ve.vl.pvsla.vvvl(<256 x double>, <256 x double>, i32) 462 463; Function Attrs: nounwind readnone 464define fastcc <256 x double> @pvsla_vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2) { 465; CHECK-LABEL: pvsla_vvvvl: 466; CHECK: # %bb.0: 467; CHECK-NEXT: lea %s0, 128 468; CHECK-NEXT: lvl %s0 469; CHECK-NEXT: pvsla %v2, %v0, %v1 470; CHECK-NEXT: lea %s16, 256 471; CHECK-NEXT: lvl %s16 472; CHECK-NEXT: vor %v0, (0)1, %v2 473; CHECK-NEXT: b.l.t (, %s10) 474 %4 = tail call fast <256 x double> @llvm.ve.vl.pvsla.vvvvl(<256 x double> %0, <256 x double> %1, <256 x double> %2, i32 128) 475 ret <256 x double> %4 476} 477 478; Function Attrs: nounwind readnone 479declare <256 x double> @llvm.ve.vl.pvsla.vvvvl(<256 x double>, <256 x double>, <256 x double>, i32) 480 481; Function Attrs: nounwind readnone 482define fastcc <256 x double> @pvsla_vvsl(<256 x double> %0, i64 %1) { 483; CHECK-LABEL: pvsla_vvsl: 484; CHECK: # %bb.0: 485; CHECK-NEXT: lea %s1, 256 486; CHECK-NEXT: lvl %s1 487; CHECK-NEXT: pvsla %v0, %v0, %s0 488; CHECK-NEXT: b.l.t (, %s10) 489 %3 = tail call fast <256 x double> @llvm.ve.vl.pvsla.vvsl(<256 x double> %0, i64 %1, i32 256) 490 ret <256 x double> %3 491} 492 493; Function Attrs: nounwind readnone 494declare <256 x double> @llvm.ve.vl.pvsla.vvsl(<256 x double>, i64, i32) 495 496; Function Attrs: nounwind readnone 497define fastcc <256 x double> @pvsla_vvsvl(<256 x double> %0, i64 %1, <256 x double> %2) { 498; CHECK-LABEL: pvsla_vvsvl: 499; CHECK: # %bb.0: 500; CHECK-NEXT: lea %s1, 128 501; CHECK-NEXT: lvl %s1 502; CHECK-NEXT: pvsla %v1, %v0, %s0 503; CHECK-NEXT: lea %s16, 256 504; CHECK-NEXT: lvl %s16 505; CHECK-NEXT: vor %v0, (0)1, %v1 506; CHECK-NEXT: b.l.t (, %s10) 507 %4 = tail call fast <256 x double> @llvm.ve.vl.pvsla.vvsvl(<256 x double> %0, i64 %1, <256 x double> %2, i32 128) 508 ret <256 x double> %4 509} 510 511; Function Attrs: nounwind readnone 512declare <256 x double> @llvm.ve.vl.pvsla.vvsvl(<256 x double>, i64, <256 x double>, i32) 513 514; Function Attrs: nounwind readnone 515define fastcc <256 x double> @pvsla_vvvMvl(<256 x double> %0, <256 x double> %1, <512 x i1> %2, <256 x double> %3) { 516; CHECK-LABEL: pvsla_vvvMvl: 517; CHECK: # %bb.0: 518; CHECK-NEXT: lea %s0, 128 519; CHECK-NEXT: lvl %s0 520; CHECK-NEXT: pvsla %v2, %v0, %v1, %vm2 521; CHECK-NEXT: lea %s16, 256 522; CHECK-NEXT: lvl %s16 523; CHECK-NEXT: vor %v0, (0)1, %v2 524; CHECK-NEXT: b.l.t (, %s10) 525 %5 = tail call fast <256 x double> @llvm.ve.vl.pvsla.vvvMvl(<256 x double> %0, <256 x double> %1, <512 x i1> %2, <256 x double> %3, i32 128) 526 ret <256 x double> %5 527} 528 529; Function Attrs: nounwind readnone 530declare <256 x double> @llvm.ve.vl.pvsla.vvvMvl(<256 x double>, <256 x double>, <512 x i1>, <256 x double>, i32) 531 532; Function Attrs: nounwind readnone 533define fastcc <256 x double> @pvsla_vvsMvl(<256 x double> %0, i64 %1, <512 x i1> %2, <256 x double> %3) { 534; CHECK-LABEL: pvsla_vvsMvl: 535; CHECK: # %bb.0: 536; CHECK-NEXT: lea %s1, 128 537; CHECK-NEXT: lvl %s1 538; CHECK-NEXT: pvsla %v1, %v0, %s0, %vm2 539; CHECK-NEXT: lea %s16, 256 540; CHECK-NEXT: lvl %s16 541; CHECK-NEXT: vor %v0, (0)1, %v1 542; CHECK-NEXT: b.l.t (, %s10) 543 %5 = tail call fast <256 x double> @llvm.ve.vl.pvsla.vvsMvl(<256 x double> %0, i64 %1, <512 x i1> %2, <256 x double> %3, i32 128) 544 ret <256 x double> %5 545} 546 547; Function Attrs: nounwind readnone 548declare <256 x double> @llvm.ve.vl.pvsla.vvsMvl(<256 x double>, i64, <512 x i1>, <256 x double>, i32) 549