|  | ; 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 | 
|  | } |