| ; Tests if we can read select instructions. |
| |
| ; RUN: %p2i -i %s --insts | FileCheck %s |
| ; RUN: %p2i -i %s --args -notranslate -timing | \ |
| ; RUN: FileCheck --check-prefix=NOIR %s |
| |
| define internal void @Seli1(i32 %p) { |
| entry: |
| %vc = trunc i32 %p to i1 |
| %vt = trunc i32 %p to i1 |
| %ve = trunc i32 %p to i1 |
| %r = select i1 %vc, i1 %vt, i1 %ve |
| ret void |
| } |
| |
| ; CHECK: define internal void @Seli1(i32 %p) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %p to i1 |
| ; CHECK-NEXT: %vt = trunc i32 %p to i1 |
| ; CHECK-NEXT: %ve = trunc i32 %p to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, i1 %vt, i1 %ve |
| ; CHECK-NEXT: ret void |
| ; CHECK-NEXT: } |
| |
| define internal void @Seli8(i32 %p) { |
| entry: |
| %vc = trunc i32 %p to i1 |
| %vt = trunc i32 %p to i8 |
| %ve = trunc i32 %p to i8 |
| %r = select i1 %vc, i8 %vt, i8 %ve |
| ret void |
| } |
| |
| ; CHECK-NEXT: define internal void @Seli8(i32 %p) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %p to i1 |
| ; CHECK-NEXT: %vt = trunc i32 %p to i8 |
| ; CHECK-NEXT: %ve = trunc i32 %p to i8 |
| ; CHECK-NEXT: %r = select i1 %vc, i8 %vt, i8 %ve |
| ; CHECK-NEXT: ret void |
| ; CHECK-NEXT: } |
| |
| define internal void @Seli16(i32 %p) { |
| entry: |
| %vc = trunc i32 %p to i1 |
| %vt = trunc i32 %p to i16 |
| %ve = trunc i32 %p to i16 |
| %r = select i1 %vc, i16 %vt, i16 %ve |
| ret void |
| } |
| |
| ; CHECK-NEXT: define internal void @Seli16(i32 %p) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %p to i1 |
| ; CHECK-NEXT: %vt = trunc i32 %p to i16 |
| ; CHECK-NEXT: %ve = trunc i32 %p to i16 |
| ; CHECK-NEXT: %r = select i1 %vc, i16 %vt, i16 %ve |
| ; CHECK-NEXT: ret void |
| ; CHECK-NEXT: } |
| |
| define internal i32 @Seli32(i32 %pc, i32 %pt, i32 %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, i32 %pt, i32 %pe |
| ret i32 %r |
| } |
| |
| ; CHECK-NEXT: define internal i32 @Seli32(i32 %pc, i32 %pt, i32 %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, i32 %pt, i32 %pe |
| ; CHECK-NEXT: ret i32 %r |
| ; CHECK-NEXT: } |
| |
| define internal i64 @Seli64(i64 %pc, i64 %pt, i64 %pe) { |
| entry: |
| %vc = trunc i64 %pc to i1 |
| %r = select i1 %vc, i64 %pt, i64 %pe |
| ret i64 %r |
| } |
| |
| ; CHECK-NEXT: define internal i64 @Seli64(i64 %pc, i64 %pt, i64 %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i64 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, i64 %pt, i64 %pe |
| ; CHECK-NEXT: ret i64 %r |
| ; CHECK-NEXT: } |
| |
| define internal float @SelFloat(i32 %pc, float %pt, float %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, float %pt, float %pe |
| ret float %r |
| } |
| |
| ; CHECK-NEXT: define internal float @SelFloat(i32 %pc, float %pt, float %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, float %pt, float %pe |
| ; CHECK-NEXT: ret float %r |
| ; CHECK-NEXT: } |
| |
| define internal double @SelDouble(i32 %pc, double %pt, double %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, double %pt, double %pe |
| ret double %r |
| } |
| |
| ; CHECK-NEXT: define internal double @SelDouble(i32 %pc, double %pt, double %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, double %pt, double %pe |
| ; CHECK-NEXT: ret double %r |
| ; CHECK-NEXT: } |
| |
| define internal <16 x i1> @SelV16x1(i32 %pc, <16 x i1> %pt, <16 x i1> %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, <16 x i1> %pt, <16 x i1> %pe |
| ret <16 x i1> %r |
| } |
| |
| ; CHECK-NEXT: define internal <16 x i1> @SelV16x1(i32 %pc, <16 x i1> %pt, <16 x i1> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, <16 x i1> %pt, <16 x i1> %pe |
| ; CHECK-NEXT: ret <16 x i1> %r |
| ; CHECK-NEXT: } |
| |
| define internal <8 x i1> @SelV8x1(i32 %pc, <8 x i1> %pt, <8 x i1> %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, <8 x i1> %pt, <8 x i1> %pe |
| ret <8 x i1> %r |
| } |
| |
| ; CHECK-NEXT: define internal <8 x i1> @SelV8x1(i32 %pc, <8 x i1> %pt, <8 x i1> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, <8 x i1> %pt, <8 x i1> %pe |
| ; CHECK-NEXT: ret <8 x i1> %r |
| ; CHECK-NEXT: } |
| |
| define internal <4 x i1> @SelV4x1(i32 %pc, <4 x i1> %pt, <4 x i1> %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, <4 x i1> %pt, <4 x i1> %pe |
| ret <4 x i1> %r |
| } |
| |
| ; CHECK-NEXT: define internal <4 x i1> @SelV4x1(i32 %pc, <4 x i1> %pt, <4 x i1> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, <4 x i1> %pt, <4 x i1> %pe |
| ; CHECK-NEXT: ret <4 x i1> %r |
| ; CHECK-NEXT: } |
| |
| define internal <16 x i8> @SelV16x8(i32 %pc, <16 x i8> %pt, <16 x i8> %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, <16 x i8> %pt, <16 x i8> %pe |
| ret <16 x i8> %r |
| } |
| |
| ; CHECK-NEXT: define internal <16 x i8> @SelV16x8(i32 %pc, <16 x i8> %pt, <16 x i8> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, <16 x i8> %pt, <16 x i8> %pe |
| ; CHECK-NEXT: ret <16 x i8> %r |
| ; CHECK-NEXT: } |
| |
| define internal <8 x i16> @SelV8x16(i32 %pc, <8 x i16> %pt, <8 x i16> %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, <8 x i16> %pt, <8 x i16> %pe |
| ret <8 x i16> %r |
| } |
| |
| ; CHECK-NEXT: define internal <8 x i16> @SelV8x16(i32 %pc, <8 x i16> %pt, <8 x i16> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, <8 x i16> %pt, <8 x i16> %pe |
| ; CHECK-NEXT: ret <8 x i16> %r |
| ; CHECK-NEXT: } |
| |
| define internal <4 x i32> @SelV4x32(i32 %pc, <4 x i32> %pt, <4 x i32> %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, <4 x i32> %pt, <4 x i32> %pe |
| ret <4 x i32> %r |
| } |
| |
| ; CHECK-NEXT: define internal <4 x i32> @SelV4x32(i32 %pc, <4 x i32> %pt, <4 x i32> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, <4 x i32> %pt, <4 x i32> %pe |
| ; CHECK-NEXT: ret <4 x i32> %r |
| ; CHECK-NEXT: } |
| |
| define internal <4 x float> @SelV4xfloat(i32 %pc, <4 x float> %pt, <4 x float> %pe) { |
| entry: |
| %vc = trunc i32 %pc to i1 |
| %r = select i1 %vc, <4 x float> %pt, <4 x float> %pe |
| ret <4 x float> %r |
| } |
| |
| ; CHECK-NEXT: define internal <4 x float> @SelV4xfloat(i32 %pc, <4 x float> %pt, <4 x float> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %vc = trunc i32 %pc to i1 |
| ; CHECK-NEXT: %r = select i1 %vc, <4 x float> %pt, <4 x float> %pe |
| ; CHECK-NEXT: ret <4 x float> %r |
| ; CHECK-NEXT: } |
| |
| define internal <16 x i1> @SelV16x1Vcond(<16 x i1> %pc, <16 x i1> %pt, <16 x i1> %pe) { |
| entry: |
| %r = select <16 x i1> %pc, <16 x i1> %pt, <16 x i1> %pe |
| ret <16 x i1> %r |
| } |
| |
| ; CHECK-NEXT: define internal <16 x i1> @SelV16x1Vcond(<16 x i1> %pc, <16 x i1> %pt, <16 x i1> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %r = select <16 x i1> %pc, <16 x i1> %pt, <16 x i1> %pe |
| ; CHECK-NEXT: ret <16 x i1> %r |
| ; CHECK-NEXT: } |
| |
| define internal <8 x i1> @SelV8x1Vcond(<8 x i1> %pc, <8 x i1> %pt, <8 x i1> %pe) { |
| entry: |
| %r = select <8 x i1> %pc, <8 x i1> %pt, <8 x i1> %pe |
| ret <8 x i1> %r |
| } |
| |
| ; CHECK-NEXT: define internal <8 x i1> @SelV8x1Vcond(<8 x i1> %pc, <8 x i1> %pt, <8 x i1> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %r = select <8 x i1> %pc, <8 x i1> %pt, <8 x i1> %pe |
| ; CHECK-NEXT: ret <8 x i1> %r |
| ; CHECK-NEXT: } |
| |
| define internal <4 x i1> @SelV4x1Vcond(<4 x i1> %pc, <4 x i1> %pt, <4 x i1> %pe) { |
| entry: |
| %r = select <4 x i1> %pc, <4 x i1> %pt, <4 x i1> %pe |
| ret <4 x i1> %r |
| } |
| |
| ; CHECK-NEXT: define internal <4 x i1> @SelV4x1Vcond(<4 x i1> %pc, <4 x i1> %pt, <4 x i1> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %r = select <4 x i1> %pc, <4 x i1> %pt, <4 x i1> %pe |
| ; CHECK-NEXT: ret <4 x i1> %r |
| ; CHECK-NEXT: } |
| |
| define internal <16 x i8> @SelV16x8Vcond(<16 x i1> %pc, <16 x i8> %pt, <16 x i8> %pe) { |
| entry: |
| %r = select <16 x i1> %pc, <16 x i8> %pt, <16 x i8> %pe |
| ret <16 x i8> %r |
| } |
| |
| ; CHECK-NEXT: define internal <16 x i8> @SelV16x8Vcond(<16 x i1> %pc, <16 x i8> %pt, <16 x i8> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %r = select <16 x i1> %pc, <16 x i8> %pt, <16 x i8> %pe |
| ; CHECK-NEXT: ret <16 x i8> %r |
| ; CHECK-NEXT: } |
| |
| define internal <8 x i16> @SelV8x16Vcond(<8 x i1> %pc, <8 x i16> %pt, <8 x i16> %pe) { |
| entry: |
| %r = select <8 x i1> %pc, <8 x i16> %pt, <8 x i16> %pe |
| ret <8 x i16> %r |
| } |
| |
| ; CHECK-NEXT: define internal <8 x i16> @SelV8x16Vcond(<8 x i1> %pc, <8 x i16> %pt, <8 x i16> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %r = select <8 x i1> %pc, <8 x i16> %pt, <8 x i16> %pe |
| ; CHECK-NEXT: ret <8 x i16> %r |
| ; CHECK-NEXT: } |
| |
| define internal <4 x i32> @SelV4x32Vcond(<4 x i1> %pc, <4 x i32> %pt, <4 x i32> %pe) { |
| entry: |
| %r = select <4 x i1> %pc, <4 x i32> %pt, <4 x i32> %pe |
| ret <4 x i32> %r |
| } |
| |
| ; CHECK-NEXT: define internal <4 x i32> @SelV4x32Vcond(<4 x i1> %pc, <4 x i32> %pt, <4 x i32> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %r = select <4 x i1> %pc, <4 x i32> %pt, <4 x i32> %pe |
| ; CHECK-NEXT: ret <4 x i32> %r |
| ; CHECK-NEXT: } |
| |
| define internal <4 x float> @SelV4xfloatVcond(<4 x i1> %pc, <4 x float> %pt, <4 x float> %pe) { |
| entry: |
| %r = select <4 x i1> %pc, <4 x float> %pt, <4 x float> %pe |
| ret <4 x float> %r |
| } |
| |
| ; CHECK-NEXT: define internal <4 x float> @SelV4xfloatVcond(<4 x i1> %pc, <4 x float> %pt, <4 x float> %pe) { |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: %r = select <4 x i1> %pc, <4 x float> %pt, <4 x float> %pe |
| ; CHECK-NEXT: ret <4 x float> %r |
| ; CHECK-NEXT: } |
| |
| ; NOIR: Total across all functions |