llvm/llvm/test/CodeGen/X86/pr15309.ll

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=i686-linux-pc | FileCheck %s

define void @test_convert_float2_ulong2(ptr nocapture %src, ptr nocapture %dest) nounwind {
; CHECK-LABEL: test_convert_float2_ulong2:
; CHECK:       # %bb.0:
; CHECK-NEXT:    pushl %edi
; CHECK-NEXT:    pushl %esi
; CHECK-NEXT:    subl $20, %esp
; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %eax
; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %ecx
; CHECK-NEXT:    movl 168(%ecx), %edx
; CHECK-NEXT:    movl 172(%ecx), %esi
; CHECK-NEXT:    movl 160(%ecx), %edi
; CHECK-NEXT:    movl 164(%ecx), %ecx
; CHECK-NEXT:    movl %ecx, {{[0-9]+}}(%esp)
; CHECK-NEXT:    movl %edi, (%esp)
; CHECK-NEXT:    movl %esi, {{[0-9]+}}(%esp)
; CHECK-NEXT:    movl %edx, {{[0-9]+}}(%esp)
; CHECK-NEXT:    shrl $31, %ecx
; CHECK-NEXT:    fildll (%esp)
; CHECK-NEXT:    fadds {{\.?LCPI[0-9]+_[0-9]+}}(,%ecx,4)
; CHECK-NEXT:    shrl $31, %esi
; CHECK-NEXT:    fildll {{[0-9]+}}(%esp)
; CHECK-NEXT:    fadds {{\.?LCPI[0-9]+_[0-9]+}}(,%esi,4)
; CHECK-NEXT:    fstps 84(%eax)
; CHECK-NEXT:    fstps 80(%eax)
; CHECK-NEXT:    addl $20, %esp
; CHECK-NEXT:    popl %esi
; CHECK-NEXT:    popl %edi
; CHECK-NEXT:    retl
  %t0 = getelementptr <2 x i64>, ptr %src, i32 10
  %t1 = load <2 x i64>, ptr %t0, align 16
  %t2 = uitofp <2 x i64> %t1 to <2 x float>
  %t3 = getelementptr <2 x float>, ptr %dest, i32 10
  store <2 x float> %t2, ptr %t3, align 8
  ret void
}