summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/v2f32.ll
blob: 0b83ff81f455299a2b7cab44e981ac69456076f4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
; RUN: llc < %s -march=x86-64 -asm-verbose=0 -o - | FileCheck %s -check-prefix=X64
; RUN: llc < %s -march=x86 -asm-verbose=0 -o - | FileCheck %s -check-prefix=X32

; PR7518
define void @test1(<2 x float> %Q, float *%P2) nounwind {
  %a = extractelement <2 x float> %Q, i32 0
  %b = extractelement <2 x float> %Q, i32 1
  %c = fadd float %a, %b

  store float %c, float* %P2
  ret void
; X64: test1:
; X64-NEXT: addss	%xmm1, %xmm0
; X64-NEXT: movss	%xmm0, (%rdi)
; X64-NEXT: ret

; X32: test1:
; X32-NEXT: movss	4(%esp), %xmm0
; X32-NEXT: addss	8(%esp), %xmm0
; X32-NEXT: movl	12(%esp), %eax
; X32-NEXT: movss	%xmm0, (%eax)
; X32-NEXT: ret
}