From: Chandler Carruth Date: Fri, 25 Jul 2014 23:59:20 +0000 (+0000) Subject: [x86] FileCheck-ize this test. X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=6da2d97a32017ac63dce84726528285f56ab3901;p=platform%2Fupstream%2Fllvm.git [x86] FileCheck-ize this test. llvm-svn: 213988 --- diff --git a/llvm/test/CodeGen/X86/pmul.ll b/llvm/test/CodeGen/X86/pmul.ll index 7bf8a61..2dfea6b 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 }