1; RUN: not opt -S < %s 2>&1 | FileCheck %s 2 3; CHECK: Intrinsic has incorrect return type! 4; CHECK-NEXT: float (double, <2 x double>)* @llvm.vector.reduce.fadd.f32.f64.v2f64 5define float @fadd_invalid_scalar_res(double %acc, <2 x double> %in) { 6 %res = call float @llvm.vector.reduce.fadd.f32.f64.v2f64(double %acc, <2 x double> %in) 7 ret float %res 8} 9 10; CHECK: Intrinsic has incorrect argument type! 11; CHECK-NEXT: double (float, <2 x double>)* @llvm.vector.reduce.fadd.f64.f32.v2f64 12define double @fadd_invalid_scalar_start(float %acc, <2 x double> %in) { 13 %res = call double @llvm.vector.reduce.fadd.f64.f32.v2f64(float %acc, <2 x double> %in) 14 ret double %res 15} 16 17; CHECK: Intrinsic has incorrect return type! 18; CHECK-NEXT: <2 x double> (double, <2 x double>)* @llvm.vector.reduce.fadd.v2f64.f64.v2f64 19define <2 x double> @fadd_invalid_vector_res(double %acc, <2 x double> %in) { 20 %res = call <2 x double> @llvm.vector.reduce.fadd.v2f64.f64.v2f64(double %acc, <2 x double> %in) 21 ret <2 x double> %res 22} 23 24; CHECK: Intrinsic has incorrect argument type! 25; CHECK-NEXT: double (<2 x double>, <2 x double>)* @llvm.vector.reduce.fadd.f64.v2f64.v2f64 26define double @fadd_invalid_vector_start(<2 x double> %in, <2 x double> %acc) { 27 %res = call double @llvm.vector.reduce.fadd.f64.v2f64.v2f64(<2 x double> %acc, <2 x double> %in) 28 ret double %res 29} 30 31declare float @llvm.vector.reduce.fadd.f32.f64.v2f64(double %acc, <2 x double> %in) 32declare double @llvm.vector.reduce.fadd.f64.f32.v2f64(float %acc, <2 x double> %in) 33declare double @llvm.vector.reduce.fadd.f64.v2f64.v2f64(<2 x double> %acc, <2 x double> %in) 34declare <2 x double> @llvm.vector.reduce.fadd.v2f64.f64.v2f64(double %acc, <2 x double> %in) 35