2019-05-20 17:54:06 +08:00
|
|
|
; RUN: not opt -S < %s 2>&1 | FileCheck %s
|
|
|
|
|
|
|
|
; CHECK: Intrinsic has incorrect argument type!
|
2019-06-11 16:22:10 +08:00
|
|
|
; CHECK-NEXT: float (double, <2 x double>)* @llvm.experimental.vector.reduce.v2.fadd.f32.f64.v2f64
|
2019-05-20 17:54:06 +08:00
|
|
|
define float @fadd_invalid_scalar_res(double %acc, <2 x double> %in) {
|
2019-06-11 16:22:10 +08:00
|
|
|
%res = call float @llvm.experimental.vector.reduce.v2.fadd.f32.f64.v2f64(double %acc, <2 x double> %in)
|
2019-05-20 17:54:06 +08:00
|
|
|
ret float %res
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK: Intrinsic has incorrect argument type!
|
2019-06-11 16:22:10 +08:00
|
|
|
; CHECK-NEXT: double (float, <2 x double>)* @llvm.experimental.vector.reduce.v2.fadd.f64.f32.v2f64
|
2019-05-20 17:54:06 +08:00
|
|
|
define double @fadd_invalid_scalar_start(float %acc, <2 x double> %in) {
|
2019-06-11 16:22:10 +08:00
|
|
|
%res = call double @llvm.experimental.vector.reduce.v2.fadd.f64.f32.v2f64(float %acc, <2 x double> %in)
|
2019-05-20 17:54:06 +08:00
|
|
|
ret double %res
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK: Intrinsic has incorrect argument type!
|
2019-06-11 16:22:10 +08:00
|
|
|
; CHECK-NEXT: <2 x double> (double, <2 x double>)* @llvm.experimental.vector.reduce.v2.fadd.v2f64.f64.v2f64
|
2019-05-20 17:54:06 +08:00
|
|
|
define <2 x double> @fadd_invalid_vector_res(double %acc, <2 x double> %in) {
|
2019-06-11 16:22:10 +08:00
|
|
|
%res = call <2 x double> @llvm.experimental.vector.reduce.v2.fadd.v2f64.f64.v2f64(double %acc, <2 x double> %in)
|
2019-05-20 17:54:06 +08:00
|
|
|
ret <2 x double> %res
|
|
|
|
}
|
|
|
|
|
|
|
|
; CHECK: Intrinsic has incorrect argument type!
|
2019-06-11 16:22:10 +08:00
|
|
|
; CHECK-NEXT: double (<2 x double>, <2 x double>)* @llvm.experimental.vector.reduce.v2.fadd.f64.v2f64.v2f64
|
2019-05-20 17:54:06 +08:00
|
|
|
define double @fadd_invalid_vector_start(<2 x double> %in, <2 x double> %acc) {
|
2019-06-11 16:22:10 +08:00
|
|
|
%res = call double @llvm.experimental.vector.reduce.v2.fadd.f64.v2f64.v2f64(<2 x double> %acc, <2 x double> %in)
|
2019-05-20 17:54:06 +08:00
|
|
|
ret double %res
|
|
|
|
}
|
|
|
|
|
2019-06-11 16:22:10 +08:00
|
|
|
declare float @llvm.experimental.vector.reduce.v2.fadd.f32.f64.v2f64(double %acc, <2 x double> %in)
|
|
|
|
declare double @llvm.experimental.vector.reduce.v2.fadd.f64.f32.v2f64(float %acc, <2 x double> %in)
|
|
|
|
declare double @llvm.experimental.vector.reduce.v2.fadd.f64.v2f64.v2f64(<2 x double> %acc, <2 x double> %in)
|
|
|
|
declare <2 x double> @llvm.experimental.vector.reduce.v2.fadd.v2f64.f64.v2f64(double %acc, <2 x double> %in)
|