mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
0edd83bfff
Like V_SET0, these instructions are expanded by ExpandPostRA to xorps / vxorps so they can participate in execution domain swizzling. This also makes the AVX variants redundant. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@145440 91177308-0d34-0410-b5e6-96231b3b80d8
41 lines
752 B
LLVM
41 lines
752 B
LLVM
; RUN: llc < %s -march=x86-64 | FileCheck %s --check-prefix=CHECK-64
|
|
; RUN: llc < %s -march=x86-64 -o /dev/null -stats -info-output-file - | grep asm-printer | grep 12
|
|
; RUN: llc < %s -march=x86 | FileCheck %s --check-prefix=CHECK-32
|
|
|
|
declare void @bar(double %x)
|
|
declare void @barf(float %x)
|
|
|
|
define double @foo() nounwind {
|
|
|
|
call void @bar(double 0.0)
|
|
ret double 0.0
|
|
|
|
;CHECK-32: foo:
|
|
;CHECK-32: call
|
|
;CHECK-32: fldz
|
|
;CHECK-32: ret
|
|
|
|
;CHECK-64: foo:
|
|
;CHECK-64: xorps
|
|
;CHECK-64: call
|
|
;CHECK-64: xorps
|
|
;CHECK-64: ret
|
|
}
|
|
|
|
|
|
define float @foof() nounwind {
|
|
call void @barf(float 0.0)
|
|
ret float 0.0
|
|
|
|
;CHECK-32: foof:
|
|
;CHECK-32: call
|
|
;CHECK-32: fldz
|
|
;CHECK-32: ret
|
|
|
|
;CHECK-64: foof:
|
|
;CHECK-64: xorps
|
|
;CHECK-64: call
|
|
;CHECK-64: xorps
|
|
;CHECK-64: ret
|
|
}
|