blob: ed0eafcfc328b487bc271a4ed3b97340918fc972 [file]
; RUN: opt -S -scalarizer -dxil-op-lower < %s | FileCheck %s
target datalayout = "e-m:e-p:32:32-i1:32-i8:8-i16:16-i32:32-i64:64-f16:16-f32:32-f64:64"
target triple = "dxil-pc-shadermodel6.7-library"
; CHECK-LABEL: define double @fma_double(
; CHECK: call double @dx.op.tertiary.f64(i32 47, double %{{.*}}, double %{{.*}}, double %{{.*}}) #[[#ATTR:]]
define double @fma_double(double %a, double %b, double %c) {
%r = call double @llvm.fma.f64(double %a, double %b, double %c)
ret double %r
}
; CHECK-LABEL: define <2 x double> @fma_v2f64(
; CHECK: extractelement <2 x double> %a, i64 0
; CHECK: extractelement <2 x double> %b, i64 0
; CHECK: extractelement <2 x double> %c, i64 0
; CHECK: call double @dx.op.tertiary.f64(i32 47, double %{{.*}}, double %{{.*}}, double %{{.*}}) #[[#ATTR]]
; CHECK: extractelement <2 x double> %a, i64 1
; CHECK: extractelement <2 x double> %b, i64 1
; CHECK: extractelement <2 x double> %c, i64 1
; CHECK: call double @dx.op.tertiary.f64(i32 47, double %{{.*}}, double %{{.*}}, double %{{.*}}) #[[#ATTR]]
; CHECK: insertelement <2 x double> poison, double %{{.*}}, i64 0
; CHECK: insertelement <2 x double> %{{.*}}, double %{{.*}}, i64 1
define <2 x double> @fma_v2f64(<2 x double> %a, <2 x double> %b,
<2 x double> %c) {
%r = call <2 x double> @llvm.fma.v2f64(<2 x double> %a, <2 x double> %b,
<2 x double> %c)
ret <2 x double> %r
}
; CHECK-LABEL: define <16 x double> @fma_v16f64(
; CHECK: extractelement <16 x double> %a, i64 0
; CHECK: extractelement <16 x double> %b, i64 0
; CHECK: extractelement <16 x double> %c, i64 0
; CHECK: call double @dx.op.tertiary.f64(i32 47, double %{{.*}}, double %{{.*}}, double %{{.*}}) #[[#ATTR]]
; CHECK: extractelement <16 x double> %a, i64 15
; CHECK: extractelement <16 x double> %b, i64 15
; CHECK: extractelement <16 x double> %c, i64 15
; CHECK: call double @dx.op.tertiary.f64(i32 47, double %{{.*}}, double %{{.*}}, double %{{.*}}) #[[#ATTR]]
; CHECK: insertelement <16 x double> poison, double %{{.*}}, i64 0
; CHECK: insertelement <16 x double> %{{.*}}, double %{{.*}}, i64 15
define <16 x double> @fma_v16f64(<16 x double> %a, <16 x double> %b,
<16 x double> %c) {
%r = call <16 x double> @llvm.fma.v16f64(<16 x double> %a, <16 x double> %b,
<16 x double> %c)
ret <16 x double> %r
}
declare double @llvm.fma.f64(double, double, double)
declare <2 x double> @llvm.fma.v2f64(<2 x double>, <2 x double>, <2 x double>)
declare <16 x double> @llvm.fma.v16f64(<16 x double>, <16 x double>, <16 x double>)
; CHECK: attributes #[[#ATTR]] = { memory(none) }