Compiler projects using llvm
; RUN: opt < %s -passes='print<cost-model>' 2>&1 -disable-output -mtriple=systemz-unknown -mcpu=z13 | FileCheck %s
; RUN: opt < %s -passes='print<cost-model>' 2>&1 -disable-output -mtriple=systemz-unknown -mcpu=zEC12 \
; RUN:  | FileCheck %s --check-prefix=IPMSQ
;
; TODO: add more tests for differing operand types of the two compares.

define i8 @fun0(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun0
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun1(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                 i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun1
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun2(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                 i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun2
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun3(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                 i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun3
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun4(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                   float %val5, float %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun4
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun5(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                    double %val5, double %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun5
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun6(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun6
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun7(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                 i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun7
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun8(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                 i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun8
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun9(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                 i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun9
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun10(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun10
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun11(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun11
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun12(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun12
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun13(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun13
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun14(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun14
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun15(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun15
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun16(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun16
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun17(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun17
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun18(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun18
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun19(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun19
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun20(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun20
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun21(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun21
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun22(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun22
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun23(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun23
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun24(float %val1, float %val2, float %val3, float %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun24
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun25(float %val1, float %val2, float %val3, float %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun25
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun26(float %val1, float %val2, float %val3, float %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun26
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun27(float %val1, float %val2, float %val3, float %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun27
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun28(float %val1, float %val2, float %val3, float %val4,
                    float %val5, float %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun28
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun29(float %val1, float %val2, float %val3, float %val4,
                     double %val5, double %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun29
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun30(double %val1, double %val2, double %val3, double %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun30
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun31(double %val1, double %val2, double %val3, double %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun31
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun32(double %val1, double %val2, double %val3, double %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun32
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun33(double %val1, double %val2, double %val3, double %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun33
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun34(double %val1, double %val2, double %val3, double %val4,
                    float %val5, float %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun34
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun35(double %val1, double %val2, double %val3, double %val4,
                     double %val5, double %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = and i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun35
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = and i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun36(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun36
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun37(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun37
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun38(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun38
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun39(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun39
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun40(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun40
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun41(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun41
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun42(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun42
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun43(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun43
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun44(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun44
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun45(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun45
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun46(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun46
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun47(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun47
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun48(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun48
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun49(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun49
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun50(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun50
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun51(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun51
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun52(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun52
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun53(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun53
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun54(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun54
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun55(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun55
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun56(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun56
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun57(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun57
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun58(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun58
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun59(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun59
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun60(float %val1, float %val2, float %val3, float %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun60
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun61(float %val1, float %val2, float %val3, float %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun61
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun62(float %val1, float %val2, float %val3, float %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun62
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun63(float %val1, float %val2, float %val3, float %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun63
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun64(float %val1, float %val2, float %val3, float %val4,
                    float %val5, float %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun64
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun65(float %val1, float %val2, float %val3, float %val4,
                     double %val5, double %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun65
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun66(double %val1, double %val2, double %val3, double %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun66
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun67(double %val1, double %val2, double %val3, double %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun67
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun68(double %val1, double %val2, double %val3, double %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun68
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun69(double %val1, double %val2, double %val3, double %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun69
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun70(double %val1, double %val2, double %val3, double %val4,
                    float %val5, float %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun70
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun71(double %val1, double %val2, double %val3, double %val4,
                     double %val5, double %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = or i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun71
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 1 for instruction:   %and = or i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun72(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun72
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun73(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun73
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun74(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun74
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun75(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun75
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun76(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun76
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun77(i8 %val1, i8 %val2, i8 %val3, i8 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i8 %val1, %val2
  %cmp1 = icmp eq i8 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun77
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i8 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i8 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun78(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun78
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun79(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun79
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun80(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun80
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun81(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun81
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun82(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun82
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun83(i16 %val1, i16 %val2, i16 %val3, i16 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i16 %val1, %val2
  %cmp1 = icmp eq i16 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun83
; CHECK: cost of 3 for instruction:   %cmp0 = icmp eq i16 %val1, %val2
; CHECK: cost of 3 for instruction:   %cmp1 = icmp eq i16 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun84(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun84
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun85(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun85
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun86(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun86
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun87(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun87
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun88(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun88
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun89(i32 %val1, i32 %val2, i32 %val3, i32 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i32 %val1, %val2
  %cmp1 = icmp eq i32 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun89
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i32 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i32 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun90(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun90
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun91(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun91
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun92(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun92
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun93(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun93
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun94(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                    float %val5, float %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun94
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun95(i64 %val1, i64 %val2, i64 %val3, i64 %val4,
                     double %val5, double %val6) {
  %cmp0 = icmp eq i64 %val1, %val2
  %cmp1 = icmp eq i64 %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun95
; CHECK: cost of 1 for instruction:   %cmp0 = icmp eq i64 %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = icmp eq i64 %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun96(float %val1, float %val2, float %val3, float %val4,
                 i8 %val5, i8 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun96
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun97(float %val1, float %val2, float %val3, float %val4,
                  i16 %val5, i16 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun97
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun98(float %val1, float %val2, float %val3, float %val4,
                  i32 %val5, i32 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun98
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun99(float %val1, float %val2, float %val3, float %val4,
                  i64 %val5, i64 %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun99
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun100(float %val1, float %val2, float %val3, float %val4,
                     float %val5, float %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun100
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun101(float %val1, float %val2, float %val3, float %val4,
                      double %val5, double %val6) {
  %cmp0 = fcmp ogt float %val1, %val2
  %cmp1 = fcmp ogt float %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun101
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt float %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt float %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}

define i8 @fun102(double %val1, double %val2, double %val3, double %val4,
                  i8 %val5, i8 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i8 %val5, i8 %val6
  ret i8 %sel

; CHECK: fun102
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i8 %val5, i8 %val6
}

define i16 @fun103(double %val1, double %val2, double %val3, double %val4,
                   i16 %val5, i16 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i16 %val5, i16 %val6
  ret i16 %sel

; CHECK: fun103
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i16 %val5, i16 %val6
}

define i32 @fun104(double %val1, double %val2, double %val3, double %val4,
                   i32 %val5, i32 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i32 %val5, i32 %val6
  ret i32 %sel

; CHECK: fun104
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i32 %val5, i32 %val6
}

define i64 @fun105(double %val1, double %val2, double %val3, double %val4,
                   i64 %val5, i64 %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, i64 %val5, i64 %val6
  ret i64 %sel

; CHECK: fun105
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 1 for instruction:   %sel = select i1 %and, i64 %val5, i64 %val6
}

define float @fun106(double %val1, double %val2, double %val3, double %val4,
                     float %val5, float %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, float %val5, float %val6
  ret float %sel

; CHECK: fun106
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, float %val5, float %val6
}

define double @fun107(double %val1, double %val2, double %val3, double %val4,
                      double %val5, double %val6) {
  %cmp0 = fcmp ogt double %val1, %val2
  %cmp1 = fcmp ogt double %val3, %val4
  %and = xor i1 %cmp0, %cmp1
  %sel = select i1 %and, double %val5, double %val6
  ret double %sel

; CHECK: fun107
; CHECK: cost of 1 for instruction:   %cmp0 = fcmp ogt double %val1, %val2
; CHECK: cost of 1 for instruction:   %cmp1 = fcmp ogt double %val3, %val4
; CHECK: cost of 5 for instruction:   %and = xor i1 %cmp0, %cmp1
; IPMSQ: cost of 7 for instruction:   %and = xor i1 %cmp0, %cmp1
; CHECK: cost of 4 for instruction:   %sel = select i1 %and, double %val5, double %val6
}