diff options
| author | Chandler Carruth <chandlerc@gmail.com> | 2014-07-25 23:59:20 +0000 |
|---|---|---|
| committer | Chandler Carruth <chandlerc@gmail.com> | 2014-07-25 23:59:20 +0000 |
| commit | 6da2d97a32017ac63dce84726528285f56ab3901 (patch) | |
| tree | f3d3368f5993fcb4bb71aedeb87284fa31c15230 | |
| parent | 3f02d8af670e532179f657022414207a91514af0 (diff) | |
| download | bcm5719-llvm-6da2d97a32017ac63dce84726528285f56ab3901.tar.gz bcm5719-llvm-6da2d97a32017ac63dce84726528285f56ab3901.zip | |
[x86] FileCheck-ize this test.
llvm-svn: 213988
| -rw-r--r-- | llvm/test/CodeGen/X86/pmul.ll | 69 |
1 files changed, 51 insertions, 18 deletions
diff --git a/llvm/test/CodeGen/X86/pmul.ll b/llvm/test/CodeGen/X86/pmul.ll index 7bf8a618fa7..2dfea6be403 100644 --- a/llvm/test/CodeGen/X86/pmul.ll +++ b/llvm/test/CodeGen/X86/pmul.ll @@ -1,32 +1,65 @@ -; RUN: llc < %s -march=x86 -mattr=sse4.1 -mcpu=nehalem -stack-alignment=16 > %t -; RUN: grep pmul %t | count 12 -; RUN: grep mov %t | count 14 +; RUN: llc < %s -march=x86 -mattr=sse4.1 -mcpu=nehalem -stack-alignment=16 | FileCheck %s define <4 x i32> @a(<4 x i32> %i) nounwind { - %A = mul <4 x i32> %i, < i32 117, i32 117, i32 117, i32 117 > - ret <4 x i32> %A +; CHECK-LABEL: a: +; CHECK: pmulld +; CHECK-NEXT: retl +entry: + %A = mul <4 x i32> %i, < i32 117, i32 117, i32 117, i32 117 > + ret <4 x i32> %A } + define <2 x i64> @b(<2 x i64> %i) nounwind { - %A = mul <2 x i64> %i, < i64 117, i64 117 > - ret <2 x i64> %A +; CHECK-LABEL: b: +; CHECK: pmuludq +; CHECK: pmuludq +; CHECK: pmuludq +entry: + %A = mul <2 x i64> %i, < i64 117, i64 117 > + ret <2 x i64> %A } + define <4 x i32> @c(<4 x i32> %i, <4 x i32> %j) nounwind { - %A = mul <4 x i32> %i, %j - ret <4 x i32> %A +; CHECK-LABEL: c: +; CHECK: pmulld +; CHECK-NEXT: retl +entry: + %A = mul <4 x i32> %i, %j + ret <4 x i32> %A } + define <2 x i64> @d(<2 x i64> %i, <2 x i64> %j) nounwind { - %A = mul <2 x i64> %i, %j - ret <2 x i64> %A +; CHECK-LABEL: d: +; CHECK: pmuludq +; CHECK: pmuludq +; CHECK: pmuludq +entry: + %A = mul <2 x i64> %i, %j + ret <2 x i64> %A } -; Use a call to force spills. + declare void @foo() + define <4 x i32> @e(<4 x i32> %i, <4 x i32> %j) nounwind { - call void @foo() - %A = mul <4 x i32> %i, %j - ret <4 x i32> %A +; CHECK-LABEL: e: +; CHECK: pmulld {{[0-9]+}}(%esp), %xmm +; CHECK-NEXT: addl ${{[0-9]+}}, %esp +; CHECK-NEXT: retl +entry: + ; Use a call to force spills. + call void @foo() + %A = mul <4 x i32> %i, %j + ret <4 x i32> %A } + define <2 x i64> @f(<2 x i64> %i, <2 x i64> %j) nounwind { - call void @foo() - %A = mul <2 x i64> %i, %j - ret <2 x i64> %A +; CHECK-LABEL: f: +; CHECK: pmuludq +; CHECK: pmuludq +; CHECK: pmuludq +entry: + ; Use a call to force spills. + call void @foo() + %A = mul <2 x i64> %i, %j + ret <2 x i64> %A } |

