mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 17:39:16 +00:00
verify that double is returned in XMM0 if the function is fastcc.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@34591 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4dfccf4b48
commit
113296ba51
@ -1,6 +1,7 @@
|
||||
; RUN: llvm-as < %s | llc -mtriple=i686-apple-darwin8 -march=x86 | grep fldl &&
|
||||
; RUN: llvm-as < %s | llc -mtriple=i686-apple-darwin8 -march=x86 | not grep xmm &&
|
||||
; RUN: llvm-as < %s | llc -mtriple=i686-apple-darwin8 -march=x86 | not grep 'sub.*esp'
|
||||
; RUN: llvm-as < %s | llc -mtriple=i686-apple-darwin8 -mcpu=yonah -march=x86 > %t &&
|
||||
; RUN: grep fldl %t | wc -l | grep 1 &&
|
||||
; RUN: not grep xmm %t &&
|
||||
; RUN: grep 'sub.*esp' %t | wc -l | grep 1
|
||||
|
||||
; These testcases shouldn't require loading into an XMM register then storing
|
||||
; to memory, then reloading into an FPStack reg.
|
||||
@ -10,3 +11,15 @@ define double @test1(double *%P) {
|
||||
ret double %A
|
||||
}
|
||||
|
||||
; fastcc should return a value
|
||||
define fastcc double @test2(<2 x double> %A) {
|
||||
%B = extractelement <2 x double> %A, i32 0
|
||||
ret double %B
|
||||
}
|
||||
|
||||
define fastcc double @test3(<4 x float> %A) {
|
||||
%B = bitcast <4 x float> %A to <2 x double>
|
||||
%C = call fastcc double @test2(<2 x double> %B)
|
||||
ret double %C
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user