llvm-project/llvm/test/CodeGen/X86/2012-12-1-merge-multiple.ll

34 lines
1.1 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=x86_64-unknown-unknown | FileCheck %s
define void @multiple_stores_on_chain(i16 * %A) {
; CHECK-LABEL: multiple_stores_on_chain:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: movabsq $844433520132096, %rax # imm = 0x3000200010000
; CHECK-NEXT: movq %rax, (%rdi)
; CHECK-NEXT: movabsq $1970350607106052, %rax # imm = 0x7000600050004
; CHECK-NEXT: movq %rax, 8(%rdi)
; CHECK-NEXT: retq
entry:
%a0 = getelementptr inbounds i16, i16* %A, i64 0
%a1 = getelementptr inbounds i16, i16* %A, i64 1
%a2 = getelementptr inbounds i16, i16* %A, i64 2
%a3 = getelementptr inbounds i16, i16* %A, i64 3
%a4 = getelementptr inbounds i16, i16* %A, i64 4
%a5 = getelementptr inbounds i16, i16* %A, i64 5
%a6 = getelementptr inbounds i16, i16* %A, i64 6
%a7 = getelementptr inbounds i16, 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
}