summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/test/CodeGen')
-rw-r--r--llvm/test/CodeGen/X86/memcpy-struct-by-value.ll18
1 files changed, 10 insertions, 8 deletions
diff --git a/llvm/test/CodeGen/X86/memcpy-struct-by-value.ll b/llvm/test/CodeGen/X86/memcpy-struct-by-value.ll
index 3c01adbb83f..18161cc892a 100644
--- a/llvm/test/CodeGen/X86/memcpy-struct-by-value.ll
+++ b/llvm/test/CodeGen/X86/memcpy-struct-by-value.ll
@@ -1,7 +1,12 @@
; RUN: llc -mtriple=x86_64-linux-gnu -mattr=-ermsb < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=NOFAST
; RUN: llc -mtriple=x86_64-linux-gnu -mattr=+ermsb < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=FAST
-; RUN: llc -mtriple=x86_64-linux-gnu -mcpu=haswell < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=HASWELL
-; RUN: llc -mtriple=x86_64-linux-gnu -mcpu=generic < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=GENERIC
+; RUN: llc -mtriple=i686-linux-gnu -mattr=-ermsb < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=NOFAST32
+; RUN: llc -mtriple=i686-linux-gnu -mattr=+ermsb < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=FAST
+; RUN: llc -mtriple=x86_64-linux-gnu -mcpu=generic < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=NOFAST
+; RUN: llc -mtriple=x86_64-linux-gnu -mcpu=haswell < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=FAST
+; FIXME: The documentation stes that ivybridge has ermsb, but this is not
+; enabled right now since I coud not confirm by testing.
+; RUN: llc -mtriple=x86_64-linux-gnu -mcpu=ivybridge < %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=NOFAST
%struct.large = type { [4096 x i8] }
@@ -13,9 +18,8 @@ define void @test1(%struct.large* nocapture %x) nounwind {
; ALL-LABEL: test1:
; NOFAST: rep;movsq
-; GENERIC: rep;movsq
+; NOFAST32: rep;movsl
; FAST: rep;movsb
-; HASWELL: rep;movsb
}
define void @test2(%struct.large* nocapture %x) nounwind minsize {
@@ -24,9 +28,8 @@ define void @test2(%struct.large* nocapture %x) nounwind minsize {
; ALL-LABEL: test2:
; NOFAST: rep;movsq
-; GENERIC: rep;movsq
+; NOFAST32: rep;movsl
; FAST: rep;movsb
-; HASWELL: rep;movsb
}
%struct.large_oddsize = type { [4095 x i8] }
@@ -39,7 +42,6 @@ define void @test3(%struct.large_oddsize* nocapture %x) nounwind minsize {
; ALL-LABEL: test3:
; NOFAST: rep;movsb
-; GENERIC: rep;movsb
+; NOFAST32: rep;movsb
; FAST: rep;movsb
-; HASWELL: rep;movsb
}
OpenPOWER on IntegriCloud