| ; Test that we handle select on vectors. |
| |
| ; REQUIRES: allow_dump |
| |
| ; Compile using standalone assembler. |
| ; RUN: %p2i --filetype=asm -i %s --target=arm32 --args -O2 \ |
| ; RUN: | FileCheck %s --check-prefix=ASM |
| |
| ; Show bytes in assembled standalone code. |
| ; RUN: %p2i --filetype=asm -i %s --target=arm32 --assemble --disassemble \ |
| ; RUN: --args -O2 --reg-use=s20 | FileCheck %s --check-prefix=DIS |
| |
| ; Compile using integrated assembler. |
| ; RUN: %p2i --filetype=iasm -i %s --target=arm32 --args -O2 \ |
| ; RUN: --reg-use=s20 \ |
| ; RUN: | FileCheck %s --check-prefix=IASM |
| |
| ; Show bytes in assembled integrated code. |
| ; RUN: %p2i --filetype=iasm -i %s --target=arm32 --assemble --disassemble \ |
| ; RUN: --args -O2 --reg-use=s20 | FileCheck %s --check-prefix=DIS |
| |
| define internal <4 x float> @select4float(<4 x i1> %s, <4 x float> %a, |
| <4 x float> %b) { |
| ; ASM-LABEL:select4float: |
| ; DIS-LABEL:00000000 <select4float>: |
| ; IASM-LABEL:select4float: |
| |
| entry: |
| %res = select <4 x i1> %s, <4 x float> %a, <4 x float> %b |
| |
| ; ASM: vshl.u32 [[M:.*]], {{.*}}, #31 |
| ; ASM-NEXT: vshr.s32 [[M:.*]], {{.*}}, #31 |
| ; ASM-NEXT: vbsl.i32 [[M]], {{.*}} |
| ; DIS: 0: f2bf0550 |
| ; DIS-NEXT: 4: f2a10050 |
| ; DIS-NEXT: 8: f3120154 |
| ; IASM-NOT: vshl |
| ; IASM-NOT: vshr |
| ; IASM-NOT: vbsl |
| |
| ret <4 x float> %res |
| } |
| |
| define internal <4 x i32> @select4i32(<4 x i1> %s, <4 x i32> %a, <4 x i32> %b) { |
| ; ASM-LABEL:select4i32: |
| ; DIS-LABEL:00000010 <select4i32>: |
| ; IASM-LABEL:select4i32: |
| |
| entry: |
| %res = select <4 x i1> %s, <4 x i32> %a, <4 x i32> %b |
| |
| ; ASM: vshl.u32 [[M:.*]], {{.*}}, #31 |
| ; ASM-NEXT: vshr.s32 [[M:.*]], {{.*}}, #31 |
| ; ASM-NEXT: vbsl.i32 [[M]], {{.*}} |
| ; DIS: 10: f2bf0550 |
| ; DIS-NEXT: 14: f2a10050 |
| ; DIS_NEXT: 18: f3120154 |
| ; IASM-NOT: vshl |
| ; IASM-NOT: vshr |
| ; IASM-NOT: vbsl |
| |
| ret <4 x i32> %res |
| } |
| |
| define internal <8 x i16> @select8i16(<8 x i1> %s, <8 x i16> %a, <8 x i16> %b) { |
| ; ASM-LABEL:select8i16: |
| ; DIS-LABEL:00000020 <select8i16>: |
| ; IASM-LABEL:select8i16: |
| |
| entry: |
| %res = select <8 x i1> %s, <8 x i16> %a, <8 x i16> %b |
| |
| ; ASM: vshl.u16 [[M:.*]], {{.*}}, #15 |
| ; ASM-NEXT: vshr.s16 [[M:.*]], {{.*}}, #15 |
| ; ASM-NEXT: vbsl.i16 [[M]], {{.*}} |
| ; DIS: 20: f29f0550 |
| ; DIS-NEXT: 24: f2910050 |
| ; DIS-NEXT: 28: f3120154 |
| ; IASM-NOT: vshl |
| ; IASM-NOT: vshr |
| ; IASM-NOT: vbsl |
| |
| ret <8 x i16> %res |
| } |
| |
| define internal <16 x i8> @select16i8(<16 x i1> %s, <16 x i8> %a, |
| <16 x i8> %b) { |
| ; ASM-LABEL:select16i8: |
| ; DIS-LABEL:00000030 <select16i8>: |
| ; IASM-LABEL:select16i8: |
| |
| entry: |
| %res = select <16 x i1> %s, <16 x i8> %a, <16 x i8> %b |
| |
| ; ASM: vshl.u8 [[M:.*]], {{.*}}, #7 |
| ; ASM-NEXT: vshr.s8 [[M:.*]], {{.*}}, #7 |
| ; ASM-NEXT: vbsl.i8 [[M]], {{.*}} |
| ; DIS: 30: f28f0550 |
| ; DIS-NEXT: 34: f2890050 |
| ; DIS-NEXT: 38: f3120154 |
| ; IASM-NOT: vshl |
| ; IASM-NOT: vshr |
| ; IASM-NOT: vbsl |
| |
| ret <16 x i8> %res |
| } |