mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-06 20:32:19 +00:00
On Darwin targets, only use vfma etc. if the source use fma() intrinsic explicitly.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@154689 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d6bf201fa2
commit
7ece9539c2
@ -219,8 +219,11 @@ def UseFPVMLx : Predicate<"Subtarget->useFPVMLx()">;
|
|||||||
|
|
||||||
// Prefer fused MAC for fp mul + add over fp VMLA / VMLS if they are available.
|
// Prefer fused MAC for fp mul + add over fp VMLA / VMLS if they are available.
|
||||||
// But only select them if more precision in FP computation is allowed.
|
// But only select them if more precision in FP computation is allowed.
|
||||||
def UseFusedMAC : Predicate<"!TM.Options.NoExcessFPPrecision">;
|
// Do not use them for Darwin platforms.
|
||||||
def DontUseFusedMAC : Predicate<"!Subtarget->hasVFP4()">;
|
def UseFusedMAC : Predicate<"!TM.Options.NoExcessFPPrecision && "
|
||||||
|
"!Subtarget->isTargetDarwin()">;
|
||||||
|
def DontUseFusedMAC : Predicate<"!Subtarget->hasVFP4() || "
|
||||||
|
"Subtarget->isTargetDarwin()">;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// ARM Flag Definitions.
|
// ARM Flag Definitions.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
; RUN: llc < %s -march=arm -mattr=+neon,+vfp4 | FileCheck %s
|
; RUN: llc < %s -mtriple=armv7-eabi -mattr=+neon,+vfp4 | FileCheck %s
|
||||||
; Check generated fused MAC and MLS.
|
; Check generated fused MAC and MLS.
|
||||||
|
|
||||||
define double @fusedMACTest1(double %d1, double %d2, double %d3) {
|
define double @fusedMACTest1(double %d1, double %d2, double %d3) {
|
||||||
|
Loading…
Reference in New Issue
Block a user