2014-07-14 22:57:27 +00:00
|
|
|
; RUN: llc < %s -mtriple=x86_64-linux -mcpu=corei7 | FileCheck %s --check-prefix=COMMON --check-prefix=LINUX
|
|
|
|
; RUN: llc < %s -mtriple=x86_64-win32 -mcpu=corei7 | FileCheck %s --check-prefix=COMMON --check-prefix=MSVC
|
2009-10-28 01:12:16 +00:00
|
|
|
|
|
|
|
; llc should share constant pool entries between this integer vector
|
|
|
|
; and this floating-point vector since they have the same encoding.
|
|
|
|
|
2014-07-14 22:57:27 +00:00
|
|
|
; LINUX: LCPI0_0(%rip), %xmm0
|
|
|
|
; MSVC: __xmm@40000000400000004000000040000000(%rip), %xmm0
|
|
|
|
; COMMON: movaps %xmm0, ({{%rdi|%rcx}})
|
|
|
|
; COMMON: movaps %xmm0, ({{%rsi|%rdx}})
|
2009-10-28 01:12:16 +00:00
|
|
|
|
|
|
|
define void @foo(<4 x i32>* %p, <4 x float>* %q, i1 %t) nounwind {
|
|
|
|
entry:
|
|
|
|
br label %loop
|
|
|
|
loop:
|
|
|
|
store <4 x i32><i32 1073741824, i32 1073741824, i32 1073741824, i32 1073741824>, <4 x i32>* %p
|
|
|
|
store <4 x float><float 2.0, float 2.0, float 2.0, float 2.0>, <4 x float>* %q
|
|
|
|
br i1 %t, label %loop, label %ret
|
|
|
|
ret:
|
|
|
|
ret void
|
|
|
|
}
|