[InstCombine] Signed saturation patterns
[llvm-core.git] / test / CodeGen / X86 / vector-intrinsics.ll
blob436644e9f9cc5cdf53acd5b0d0c2faa681da59eb
1 ; RUN: llc < %s -mtriple=x86_64-- | grep call | count 43
3 declare <4 x double> @llvm.sin.v4f64(<4 x double> %p)
4 declare <4 x double> @llvm.cos.v4f64(<4 x double> %p)
5 declare <4 x double> @llvm.pow.v4f64(<4 x double> %p, <4 x double> %q)
6 declare <4 x double> @llvm.powi.v4f64(<4 x double> %p, i32)
8 define <4 x double> @foo(<4 x double> %p)
10   %t = call <4 x double> @llvm.sin.v4f64(<4 x double> %p)
11   ret <4 x double> %t
13 define <4 x double> @goo(<4 x double> %p)
15   %t = call <4 x double> @llvm.cos.v4f64(<4 x double> %p)
16   ret <4 x double> %t
18 define <4 x double> @moo(<4 x double> %p, <4 x double> %q)
20   %t = call <4 x double> @llvm.pow.v4f64(<4 x double> %p, <4 x double> %q)
21   ret <4 x double> %t
23 define <4 x double> @zoo(<4 x double> %p, i32 %q)
25   %t = call <4 x double> @llvm.powi.v4f64(<4 x double> %p, i32 %q)
26   ret <4 x double> %t
30 declare <9 x double> @llvm.exp.v9f64(<9 x double> %a)
31 declare <9 x double> @llvm.pow.v9f64(<9 x double> %a, <9 x double> %b)
32 declare <9 x double> @llvm.powi.v9f64(<9 x double> %a, i32)
34 define void @a(<9 x double>* %p) nounwind {
35   %a = load <9 x double>, <9 x double>* %p
36   %r = call <9 x double> @llvm.exp.v9f64(<9 x double> %a)
37   store <9 x double> %r, <9 x double>* %p
38   ret void
40 define void @b(<9 x double>* %p, <9 x double>* %q) nounwind {
41   %a = load <9 x double>, <9 x double>* %p
42   %b = load <9 x double>, <9 x double>* %q
43   %r = call <9 x double> @llvm.pow.v9f64(<9 x double> %a, <9 x double> %b)
44   store <9 x double> %r, <9 x double>* %p
45   ret void
47 define void @c(<9 x double>* %p, i32 %n) nounwind {
48   %a = load <9 x double>, <9 x double>* %p
49   %r = call <9 x double> @llvm.powi.v9f64(<9 x double> %a, i32 %n)
50   store <9 x double> %r, <9 x double>* %p
51   ret void