diff options
author | Nadav Rotem <nrotem@apple.com> | 2012-12-02 17:14:09 +0000 |
---|---|---|
committer | Nadav Rotem <nrotem@apple.com> | 2012-12-02 17:14:09 +0000 |
commit | 1157e1410c833b5a167807370a68c073961c6f5c (patch) | |
tree | c68f531893198f2477bbb53f2ff5d9b759a4ce38 /llvm/test/CodeGen/X86/2012-12-1-merge-multiple.ll | |
parent | 65e7c6626a85280aa75127e5b65070ae19f75f46 (diff) | |
download | bcm5719-llvm-1157e1410c833b5a167807370a68c073961c6f5c.tar.gz bcm5719-llvm-1157e1410c833b5a167807370a68c073961c6f5c.zip |
Allow merging multiple store sequences on the same chain.
llvm-svn: 169111
Diffstat (limited to 'llvm/test/CodeGen/X86/2012-12-1-merge-multiple.ll')
-rw-r--r-- | llvm/test/CodeGen/X86/2012-12-1-merge-multiple.ll | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/2012-12-1-merge-multiple.ll b/llvm/test/CodeGen/X86/2012-12-1-merge-multiple.ll new file mode 100644 index 00000000000..5931c3d27be --- /dev/null +++ b/llvm/test/CodeGen/X86/2012-12-1-merge-multiple.ll @@ -0,0 +1,31 @@ +; RUN: llc < %s -march=x86-64 -mcpu=corei7 -mtriple=x86_64-pc-win64 | FileCheck %s + +; CHECK: multiple_stores_on_chain +; CHECK: movabsq +; CHECK: movq +; CHECK: movabsq +; CHECK: movq +; CHECK: ret +define void @multiple_stores_on_chain(i16 * %A) { +entry: + %a0 = getelementptr inbounds i16* %A, i64 0 + %a1 = getelementptr inbounds i16* %A, i64 1 + %a2 = getelementptr inbounds i16* %A, i64 2 + %a3 = getelementptr inbounds i16* %A, i64 3 + %a4 = getelementptr inbounds i16* %A, i64 4 + %a5 = getelementptr inbounds i16* %A, i64 5 + %a6 = getelementptr inbounds i16* %A, i64 6 + %a7 = getelementptr inbounds i16* %A, i64 7 + + store i16 0, i16* %a0 + store i16 1, i16* %a1 + store i16 2, i16* %a2 + store i16 3, i16* %a3 + store i16 4, i16* %a4 + store i16 5, i16* %a5 + store i16 6, i16* %a6 + store i16 7, i16* %a7 + + ret void +} + |