2404 lines
		
	
	
		
			76 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			2404 lines
		
	
	
		
			76 KiB
		
	
	
	
		
			LLVM
		
	
	
	
; RUN: opt < %s -cost-model -analyze -mtriple=systemz-unknown -mcpu=z13 | FileCheck %s
 | 
						|
;
 | 
						|
 | 
						|
define i8 @fun0(i8 %val1, i8 %val2) {
 | 
						|
  %cmp = icmp eq i8 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun0
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i8 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun1(i8 %val1, i8 %val2) {
 | 
						|
  %cmp = icmp eq i8 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun1
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i8 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun2(i8 %val1, i8 %val2) {
 | 
						|
  %cmp = icmp eq i8 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun2
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i8 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun3(i8 %val1, i8 %val2) {
 | 
						|
  %cmp = icmp eq i8 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun3
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i8 %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun4(i16 %val1, i16 %val2) {
 | 
						|
  %cmp = icmp eq i16 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun4
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i16 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun5(i16 %val1, i16 %val2) {
 | 
						|
  %cmp = icmp eq i16 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun5
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i16 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun6(i16 %val1, i16 %val2) {
 | 
						|
  %cmp = icmp eq i16 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun6
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i16 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun7(i16 %val1, i16 %val2) {
 | 
						|
  %cmp = icmp eq i16 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun7
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i16 %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun8(i32 %val1, i32 %val2) {
 | 
						|
  %cmp = icmp eq i32 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun8
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i32 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun9(i32 %val1, i32 %val2) {
 | 
						|
  %cmp = icmp eq i32 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun9
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i32 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun10(i32 %val1, i32 %val2) {
 | 
						|
  %cmp = icmp eq i32 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun10
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i32 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun11(i32 %val1, i32 %val2) {
 | 
						|
  %cmp = icmp eq i32 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun11
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i32 %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun12(i64 %val1, i64 %val2) {
 | 
						|
  %cmp = icmp eq i64 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun12
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i64 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun13(i64 %val1, i64 %val2) {
 | 
						|
  %cmp = icmp eq i64 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun13
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i64 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun14(i64 %val1, i64 %val2) {
 | 
						|
  %cmp = icmp eq i64 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun14
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i64 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun15(i64 %val1, i64 %val2) {
 | 
						|
  %cmp = icmp eq i64 %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun15
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i64 %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun16(float %val1, float %val2) {
 | 
						|
  %cmp = fcmp ogt float %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun16
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt float %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun17(float %val1, float %val2) {
 | 
						|
  %cmp = fcmp ogt float %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun17
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt float %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun18(float %val1, float %val2) {
 | 
						|
  %cmp = fcmp ogt float %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun18
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt float %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun19(float %val1, float %val2) {
 | 
						|
  %cmp = fcmp ogt float %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun19
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt float %val1, %val2
 | 
						|
; CHECK: cost of 5 for instruction:   %v = sext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun20(double %val1, double %val2) {
 | 
						|
  %cmp = fcmp ogt double %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun20
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt double %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun21(double %val1, double %val2) {
 | 
						|
  %cmp = fcmp ogt double %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun21
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt double %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun22(double %val1, double %val2) {
 | 
						|
  %cmp = fcmp ogt double %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun22
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt double %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun23(double %val1, double %val2) {
 | 
						|
  %cmp = fcmp ogt double %val1, %val2
 | 
						|
  %v = sext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun23
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt double %val1, %val2
 | 
						|
; CHECK: cost of 5 for instruction:   %v = sext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun24(<2 x i8> %val1, <2 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun24
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun25(<2 x i8> %val1, <2 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun25
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun26(<2 x i8> %val1, <2 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun26
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun27(<2 x i8> %val1, <2 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun27
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun28(<2 x i16> %val1, <2 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun28
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun29(<2 x i16> %val1, <2 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun29
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun30(<2 x i16> %val1, <2 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun30
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun31(<2 x i16> %val1, <2 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun31
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun32(<2 x i32> %val1, <2 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun32
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun33(<2 x i32> %val1, <2 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun33
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun34(<2 x i32> %val1, <2 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun34
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun35(<2 x i32> %val1, <2 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun35
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun36(<2 x i64> %val1, <2 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun36
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun37(<2 x i64> %val1, <2 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun37
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun38(<2 x i64> %val1, <2 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun38
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun39(<2 x i64> %val1, <2 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun39
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun40(<2 x float> %val1, <2 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun40
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun41(<2 x float> %val1, <2 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun41
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun42(<2 x float> %val1, <2 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun42
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun43(<2 x float> %val1, <2 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun43
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun44(<2 x double> %val1, <2 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun44
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun45(<2 x double> %val1, <2 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun45
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun46(<2 x double> %val1, <2 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun46
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun47(<2 x double> %val1, <2 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
  %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun47
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun48(<4 x i8> %val1, <4 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun48
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun49(<4 x i8> %val1, <4 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun49
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun50(<4 x i8> %val1, <4 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun50
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun51(<4 x i8> %val1, <4 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun51
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 7 for instruction:   %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun52(<4 x i16> %val1, <4 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun52
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun53(<4 x i16> %val1, <4 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun53
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun54(<4 x i16> %val1, <4 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun54
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun55(<4 x i16> %val1, <4 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun55
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 5 for instruction:   %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun56(<4 x i32> %val1, <4 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun56
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun57(<4 x i32> %val1, <4 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun57
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun58(<4 x i32> %val1, <4 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun58
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun59(<4 x i32> %val1, <4 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun59
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun60(<4 x i64> %val1, <4 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun60
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun61(<4 x i64> %val1, <4 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun61
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun62(<4 x i64> %val1, <4 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun62
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun63(<4 x i64> %val1, <4 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun63
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun64(<4 x float> %val1, <4 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun64
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun65(<4 x float> %val1, <4 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun65
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun66(<4 x float> %val1, <4 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun66
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun67(<4 x float> %val1, <4 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun67
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun68(<4 x double> %val1, <4 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun68
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun69(<4 x double> %val1, <4 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun69
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun70(<4 x double> %val1, <4 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun70
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun71(<4 x double> %val1, <4 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
  %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun71
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun72(<8 x i8> %val1, <8 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun72
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun73(<8 x i8> %val1, <8 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun73
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun74(<8 x i8> %val1, <8 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun74
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 5 for instruction:   %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun75(<8 x i8> %val1, <8 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun75
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 15 for instruction:   %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun76(<8 x i16> %val1, <8 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun76
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun77(<8 x i16> %val1, <8 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun77
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun78(<8 x i16> %val1, <8 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun78
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun79(<8 x i16> %val1, <8 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun79
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 11 for instruction:   %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun80(<8 x i32> %val1, <8 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun80
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun81(<8 x i32> %val1, <8 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun81
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun82(<8 x i32> %val1, <8 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun82
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun83(<8 x i32> %val1, <8 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun83
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 7 for instruction:   %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun84(<8 x i64> %val1, <8 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun84
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun85(<8 x i64> %val1, <8 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun85
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun86(<8 x i64> %val1, <8 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun86
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun87(<8 x i64> %val1, <8 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun87
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun88(<8 x float> %val1, <8 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun88
 | 
						|
; CHECK: cost of 20 for instruction:   %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun89(<8 x float> %val1, <8 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun89
 | 
						|
; CHECK: cost of 20 for instruction:   %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun90(<8 x float> %val1, <8 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun90
 | 
						|
; CHECK: cost of 20 for instruction:   %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun91(<8 x float> %val1, <8 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun91
 | 
						|
; CHECK: cost of 20 for instruction:   %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
; CHECK: cost of 7 for instruction:   %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun92(<8 x double> %val1, <8 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun92
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun93(<8 x double> %val1, <8 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun93
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun94(<8 x double> %val1, <8 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun94
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = sext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun95(<8 x double> %val1, <8 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
  %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun95
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun96(<16 x i8> %val1, <16 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun96
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun97(<16 x i8> %val1, <16 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun97
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun98(<16 x i8> %val1, <16 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun98
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 11 for instruction:   %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun99(<16 x i8> %val1, <16 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun99
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 31 for instruction:   %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun100(<16 x i16> %val1, <16 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun100
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun101(<16 x i16> %val1, <16 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun101
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun102(<16 x i16> %val1, <16 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun102
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 7 for instruction:   %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun103(<16 x i16> %val1, <16 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun103
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 23 for instruction:   %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun104(<16 x i32> %val1, <16 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun104
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun105(<16 x i32> %val1, <16 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun105
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun106(<16 x i32> %val1, <16 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun106
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun107(<16 x i32> %val1, <16 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun107
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 15 for instruction:   %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun108(<16 x i64> %val1, <16 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun108
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 7 for instruction:   %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun109(<16 x i64> %val1, <16 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun109
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 6 for instruction:   %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun110(<16 x i64> %val1, <16 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun110
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun111(<16 x i64> %val1, <16 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun111
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun112(<16 x float> %val1, <16 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun112
 | 
						|
; CHECK: cost of 40 for instruction:   %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun113(<16 x float> %val1, <16 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun113
 | 
						|
; CHECK: cost of 40 for instruction:   %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun114(<16 x float> %val1, <16 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun114
 | 
						|
; CHECK: cost of 40 for instruction:   %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun115(<16 x float> %val1, <16 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun115
 | 
						|
; CHECK: cost of 40 for instruction:   %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
; CHECK: cost of 15 for instruction:   %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun116(<16 x double> %val1, <16 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun116
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
; CHECK: cost of 7 for instruction:   %v = sext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun117(<16 x double> %val1, <16 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun117
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
; CHECK: cost of 6 for instruction:   %v = sext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun118(<16 x double> %val1, <16 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun118
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = sext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun119(<16 x double> %val1, <16 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
  %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun119
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
; CHECK: cost of 0 for instruction:   %v = sext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun120(i8 %val1, i8 %val2) {
 | 
						|
  %cmp = icmp eq i8 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun120
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i8 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun121(i8 %val1, i8 %val2) {
 | 
						|
  %cmp = icmp eq i8 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun121
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i8 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun122(i8 %val1, i8 %val2) {
 | 
						|
  %cmp = icmp eq i8 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun122
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i8 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun123(i8 %val1, i8 %val2) {
 | 
						|
  %cmp = icmp eq i8 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun123
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i8 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun124(i16 %val1, i16 %val2) {
 | 
						|
  %cmp = icmp eq i16 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun124
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i16 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun125(i16 %val1, i16 %val2) {
 | 
						|
  %cmp = icmp eq i16 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun125
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i16 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun126(i16 %val1, i16 %val2) {
 | 
						|
  %cmp = icmp eq i16 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun126
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i16 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun127(i16 %val1, i16 %val2) {
 | 
						|
  %cmp = icmp eq i16 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun127
 | 
						|
; CHECK: cost of 3 for instruction:   %cmp = icmp eq i16 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun128(i32 %val1, i32 %val2) {
 | 
						|
  %cmp = icmp eq i32 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun128
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i32 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun129(i32 %val1, i32 %val2) {
 | 
						|
  %cmp = icmp eq i32 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun129
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i32 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun130(i32 %val1, i32 %val2) {
 | 
						|
  %cmp = icmp eq i32 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun130
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i32 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun131(i32 %val1, i32 %val2) {
 | 
						|
  %cmp = icmp eq i32 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun131
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i32 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun132(i64 %val1, i64 %val2) {
 | 
						|
  %cmp = icmp eq i64 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun132
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i64 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun133(i64 %val1, i64 %val2) {
 | 
						|
  %cmp = icmp eq i64 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun133
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i64 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun134(i64 %val1, i64 %val2) {
 | 
						|
  %cmp = icmp eq i64 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun134
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i64 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun135(i64 %val1, i64 %val2) {
 | 
						|
  %cmp = icmp eq i64 %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun135
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq i64 %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun136(float %val1, float %val2) {
 | 
						|
  %cmp = fcmp ogt float %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun136
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt float %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun137(float %val1, float %val2) {
 | 
						|
  %cmp = fcmp ogt float %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun137
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt float %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun138(float %val1, float %val2) {
 | 
						|
  %cmp = fcmp ogt float %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun138
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt float %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun139(float %val1, float %val2) {
 | 
						|
  %cmp = fcmp ogt float %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun139
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt float %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define i8 @fun140(double %val1, double %val2) {
 | 
						|
  %cmp = fcmp ogt double %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i8
 | 
						|
  ret i8 %v
 | 
						|
 | 
						|
; CHECK: fun140
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt double %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext i1 %cmp to i8
 | 
						|
}
 | 
						|
 | 
						|
define i16 @fun141(double %val1, double %val2) {
 | 
						|
  %cmp = fcmp ogt double %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i16
 | 
						|
  ret i16 %v
 | 
						|
 | 
						|
; CHECK: fun141
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt double %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext i1 %cmp to i16
 | 
						|
}
 | 
						|
 | 
						|
define i32 @fun142(double %val1, double %val2) {
 | 
						|
  %cmp = fcmp ogt double %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i32
 | 
						|
  ret i32 %v
 | 
						|
 | 
						|
; CHECK: fun142
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt double %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext i1 %cmp to i32
 | 
						|
}
 | 
						|
 | 
						|
define i64 @fun143(double %val1, double %val2) {
 | 
						|
  %cmp = fcmp ogt double %val1, %val2
 | 
						|
  %v = zext i1 %cmp to i64
 | 
						|
  ret i64 %v
 | 
						|
 | 
						|
; CHECK: fun143
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt double %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext i1 %cmp to i64
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun144(<2 x i8> %val1, <2 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun144
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun145(<2 x i8> %val1, <2 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun145
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun146(<2 x i8> %val1, <2 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun146
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun147(<2 x i8> %val1, <2 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun147
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun148(<2 x i16> %val1, <2 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun148
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun149(<2 x i16> %val1, <2 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun149
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun150(<2 x i16> %val1, <2 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun150
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun151(<2 x i16> %val1, <2 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun151
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun152(<2 x i32> %val1, <2 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun152
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun153(<2 x i32> %val1, <2 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun153
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun154(<2 x i32> %val1, <2 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun154
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun155(<2 x i32> %val1, <2 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun155
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun156(<2 x i64> %val1, <2 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun156
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun157(<2 x i64> %val1, <2 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun157
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun158(<2 x i64> %val1, <2 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun158
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun159(<2 x i64> %val1, <2 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun159
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <2 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun160(<2 x float> %val1, <2 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun160
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun161(<2 x float> %val1, <2 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun161
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun162(<2 x float> %val1, <2 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun162
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun163(<2 x float> %val1, <2 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun163
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <2 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i8> @fun164(<2 x double> %val1, <2 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
  ret <2 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun164
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i16> @fun165(<2 x double> %val1, <2 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
  ret <2 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun165
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i32> @fun166(<2 x double> %val1, <2 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
  ret <2 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun166
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <2 x i1> %cmp to <2 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <2 x i64> @fun167(<2 x double> %val1, <2 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
  %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
  ret <2 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun167
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = fcmp ogt <2 x double> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <2 x i1> %cmp to <2 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun168(<4 x i8> %val1, <4 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun168
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun169(<4 x i8> %val1, <4 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun169
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun170(<4 x i8> %val1, <4 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun170
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 3 for instruction:   %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun171(<4 x i8> %val1, <4 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun171
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 9 for instruction:   %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun172(<4 x i16> %val1, <4 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun172
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun173(<4 x i16> %val1, <4 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun173
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun174(<4 x i16> %val1, <4 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun174
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun175(<4 x i16> %val1, <4 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun175
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 7 for instruction:   %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun176(<4 x i32> %val1, <4 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun176
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun177(<4 x i32> %val1, <4 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun177
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun178(<4 x i32> %val1, <4 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun178
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun179(<4 x i32> %val1, <4 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun179
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <4 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 5 for instruction:   %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun180(<4 x i64> %val1, <4 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun180
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun181(<4 x i64> %val1, <4 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun181
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun182(<4 x i64> %val1, <4 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun182
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun183(<4 x i64> %val1, <4 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun183
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <4 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun184(<4 x float> %val1, <4 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun184
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun185(<4 x float> %val1, <4 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun185
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun186(<4 x float> %val1, <4 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun186
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun187(<4 x float> %val1, <4 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun187
 | 
						|
; CHECK: cost of 10 for instruction:   %cmp = fcmp ogt <4 x float> %val1, %val2
 | 
						|
; CHECK: cost of 5 for instruction:   %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i8> @fun188(<4 x double> %val1, <4 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
  ret <4 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun188
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i16> @fun189(<4 x double> %val1, <4 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
  ret <4 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun189
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i32> @fun190(<4 x double> %val1, <4 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
  ret <4 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun190
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <4 x i64> @fun191(<4 x double> %val1, <4 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
  %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
  ret <4 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun191
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = fcmp ogt <4 x double> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <4 x i1> %cmp to <4 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun192(<8 x i8> %val1, <8 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun192
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun193(<8 x i8> %val1, <8 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun193
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun194(<8 x i8> %val1, <8 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun194
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 7 for instruction:   %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun195(<8 x i8> %val1, <8 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun195
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 19 for instruction:   %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun196(<8 x i16> %val1, <8 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun196
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun197(<8 x i16> %val1, <8 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun197
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun198(<8 x i16> %val1, <8 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun198
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 5 for instruction:   %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun199(<8 x i16> %val1, <8 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun199
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <8 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 15 for instruction:   %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun200(<8 x i32> %val1, <8 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun200
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun201(<8 x i32> %val1, <8 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun201
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun202(<8 x i32> %val1, <8 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun202
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun203(<8 x i32> %val1, <8 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun203
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <8 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 11 for instruction:   %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun204(<8 x i64> %val1, <8 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun204
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun205(<8 x i64> %val1, <8 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun205
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun206(<8 x i64> %val1, <8 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun206
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun207(<8 x i64> %val1, <8 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun207
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <8 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun208(<8 x float> %val1, <8 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun208
 | 
						|
; CHECK: cost of 20 for instruction:   %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun209(<8 x float> %val1, <8 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun209
 | 
						|
; CHECK: cost of 20 for instruction:   %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun210(<8 x float> %val1, <8 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun210
 | 
						|
; CHECK: cost of 20 for instruction:   %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun211(<8 x float> %val1, <8 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun211
 | 
						|
; CHECK: cost of 20 for instruction:   %cmp = fcmp ogt <8 x float> %val1, %val2
 | 
						|
; CHECK: cost of 11 for instruction:   %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i8> @fun212(<8 x double> %val1, <8 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
  ret <8 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun212
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <8 x i1> %cmp to <8 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i16> @fun213(<8 x double> %val1, <8 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
  ret <8 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun213
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <8 x i1> %cmp to <8 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i32> @fun214(<8 x double> %val1, <8 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
  ret <8 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun214
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <8 x i1> %cmp to <8 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <8 x i64> @fun215(<8 x double> %val1, <8 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
  %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
  ret <8 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun215
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = fcmp ogt <8 x double> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <8 x i1> %cmp to <8 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun216(<16 x i8> %val1, <16 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun216
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 1 for instruction:   %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun217(<16 x i8> %val1, <16 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun217
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 5 for instruction:   %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun218(<16 x i8> %val1, <16 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun218
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 15 for instruction:   %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun219(<16 x i8> %val1, <16 x i8> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun219
 | 
						|
; CHECK: cost of 1 for instruction:   %cmp = icmp eq <16 x i8> %val1, %val2
 | 
						|
; CHECK: cost of 39 for instruction:   %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun220(<16 x i16> %val1, <16 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun220
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun221(<16 x i16> %val1, <16 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun221
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 2 for instruction:   %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun222(<16 x i16> %val1, <16 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun222
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 11 for instruction:   %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun223(<16 x i16> %val1, <16 x i16> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun223
 | 
						|
; CHECK: cost of 2 for instruction:   %cmp = icmp eq <16 x i16> %val1, %val2
 | 
						|
; CHECK: cost of 31 for instruction:   %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun224(<16 x i32> %val1, <16 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun224
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun225(<16 x i32> %val1, <16 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun225
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun226(<16 x i32> %val1, <16 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun226
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun227(<16 x i32> %val1, <16 x i32> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun227
 | 
						|
; CHECK: cost of 4 for instruction:   %cmp = icmp eq <16 x i32> %val1, %val2
 | 
						|
; CHECK: cost of 23 for instruction:   %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun228(<16 x i64> %val1, <16 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun228
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 8 for instruction:   %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun229(<16 x i64> %val1, <16 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun229
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 8 for instruction:   %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun230(<16 x i64> %val1, <16 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun230
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 8 for instruction:   %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun231(<16 x i64> %val1, <16 x i64> %val2) {
 | 
						|
  %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun231
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = icmp eq <16 x i64> %val1, %val2
 | 
						|
; CHECK: cost of 8 for instruction:   %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun232(<16 x float> %val1, <16 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun232
 | 
						|
; CHECK: cost of 40 for instruction:   %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun233(<16 x float> %val1, <16 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun233
 | 
						|
; CHECK: cost of 40 for instruction:   %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun234(<16 x float> %val1, <16 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun234
 | 
						|
; CHECK: cost of 40 for instruction:   %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
; CHECK: cost of 4 for instruction:   %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun235(<16 x float> %val1, <16 x float> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun235
 | 
						|
; CHECK: cost of 40 for instruction:   %cmp = fcmp ogt <16 x float> %val1, %val2
 | 
						|
; CHECK: cost of 23 for instruction:   %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i8> @fun236(<16 x double> %val1, <16 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
  ret <16 x i8> %v
 | 
						|
 | 
						|
; CHECK: fun236
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
; CHECK: cost of 8 for instruction:   %v = zext <16 x i1> %cmp to <16 x i8>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i16> @fun237(<16 x double> %val1, <16 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
  ret <16 x i16> %v
 | 
						|
 | 
						|
; CHECK: fun237
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
; CHECK: cost of 8 for instruction:   %v = zext <16 x i1> %cmp to <16 x i16>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i32> @fun238(<16 x double> %val1, <16 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
  ret <16 x i32> %v
 | 
						|
 | 
						|
; CHECK: fun238
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
; CHECK: cost of 8 for instruction:   %v = zext <16 x i1> %cmp to <16 x i32>
 | 
						|
}
 | 
						|
 | 
						|
define <16 x i64> @fun239(<16 x double> %val1, <16 x double> %val2) {
 | 
						|
  %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
  %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
  ret <16 x i64> %v
 | 
						|
 | 
						|
; CHECK: fun239
 | 
						|
; CHECK: cost of 8 for instruction:   %cmp = fcmp ogt <16 x double> %val1, %val2
 | 
						|
; CHECK: cost of 8 for instruction:   %v = zext <16 x i1> %cmp to <16 x i64>
 | 
						|
}
 | 
						|
 |