mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
reapply my previous patch (r66358) with a tweak to set the
alignment of the generated constant pool entry to the desired alignment of a type. If we don't do this, we end up trying to do movsd from 4-byte alignment memory. This fixes 450.soplex and 456.hmmer. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66641 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
1362f97018
commit
600fec3cea
@ -14,8 +14,10 @@
|
||||
|
||||
#define DEBUG_TYPE "dagcombine"
|
||||
#include "llvm/CodeGen/SelectionDAG.h"
|
||||
#include "llvm/DerivedTypes.h"
|
||||
#include "llvm/CodeGen/MachineFunction.h"
|
||||
#include "llvm/CodeGen/MachineFrameInfo.h"
|
||||
#include "llvm/CodeGen/PseudoSourceValue.h"
|
||||
#include "llvm/Analysis/AliasAnalysis.h"
|
||||
#include "llvm/Target/TargetData.h"
|
||||
#include "llvm/Target/TargetFrameInfo.h"
|
||||
@ -2891,8 +2893,7 @@ SDValue DAGCombiner::visitSELECT(SDNode *N) {
|
||||
return DAG.getNode(ISD::SELECT_CC, N->getDebugLoc(), VT,
|
||||
N0.getOperand(0), N0.getOperand(1),
|
||||
N1, N2, N0.getOperand(2));
|
||||
else
|
||||
return SimplifySelect(N->getDebugLoc(), N0, N1, N2);
|
||||
return SimplifySelect(N->getDebugLoc(), N0, N1, N2);
|
||||
}
|
||||
|
||||
return SDValue();
|
||||
@ -5675,9 +5676,14 @@ bool DAGCombiner::SimplifySelectOps(SDNode *TheSelect, SDValue LHS,
|
||||
return false;
|
||||
}
|
||||
|
||||
/// SimplifySelectCC - Simplify an expression of the form (N0 cond N1) ? N2 : N3
|
||||
/// where 'cond' is the comparison specified by CC.
|
||||
SDValue DAGCombiner::SimplifySelectCC(DebugLoc DL, SDValue N0, SDValue N1,
|
||||
SDValue N2, SDValue N3,
|
||||
ISD::CondCode CC, bool NotExtCompare) {
|
||||
// (x ? y : y) -> y.
|
||||
if (N2 == N3) return N2;
|
||||
|
||||
MVT VT = N2.getValueType();
|
||||
ConstantSDNode *N1C = dyn_cast<ConstantSDNode>(N1.getNode());
|
||||
ConstantSDNode *N2C = dyn_cast<ConstantSDNode>(N2.getNode());
|
||||
@ -5713,6 +5719,53 @@ SDValue DAGCombiner::SimplifySelectCC(DebugLoc DL, SDValue N0, SDValue N1,
|
||||
return DAG.getNode(ISD::FABS, DL, VT, N3);
|
||||
}
|
||||
}
|
||||
|
||||
// Turn "(a cond b) ? 1.0f : 2.0f" into "load (tmp + ((a cond b) ? 0 : 4)"
|
||||
// where "tmp" is a constant pool entry containing an array with 1.0 and 2.0
|
||||
// in it. This is a win when the constant is not otherwise available because
|
||||
// it replaces two constant pool loads with one. We only do this if the FP
|
||||
// type is known to be legal, because if it isn't, then we are before legalize
|
||||
// types an we want the other legalization to happen first (e.g. to avoid
|
||||
// messing with soft float).
|
||||
if (ConstantFPSDNode *TV = dyn_cast<ConstantFPSDNode>(N2))
|
||||
if (ConstantFPSDNode *FV = dyn_cast<ConstantFPSDNode>(N3)) {
|
||||
if (TLI.isTypeLegal(N2.getValueType()) &&
|
||||
// If both constants have multiple uses, then we won't need to do an
|
||||
// extra load, they are likely around in registers for other users.
|
||||
(TV->hasOneUse() || FV->hasOneUse())) {
|
||||
Constant *Elts[] = {
|
||||
const_cast<ConstantFP*>(FV->getConstantFPValue()),
|
||||
const_cast<ConstantFP*>(TV->getConstantFPValue())
|
||||
};
|
||||
const Type *FPTy = Elts[0]->getType();
|
||||
const TargetData &TD = *TLI.getTargetData();
|
||||
|
||||
// Create a ConstantArray of the two constants.
|
||||
Constant *CA = ConstantArray::get(ArrayType::get(FPTy, 2), Elts, 2);
|
||||
SDValue CPIdx = DAG.getConstantPool(CA, TLI.getPointerTy(),
|
||||
TD.getPrefTypeAlignment(FPTy));
|
||||
unsigned Alignment =
|
||||
1 << cast<ConstantPoolSDNode>(CPIdx)->getAlignment();
|
||||
|
||||
// Get the offsets to the 0 and 1 element of the array so that we can
|
||||
// select between them.
|
||||
SDValue Zero = DAG.getIntPtrConstant(0);
|
||||
unsigned EltSize = (unsigned)TD.getTypePaddedSize(Elts[0]->getType());
|
||||
SDValue One = DAG.getIntPtrConstant(EltSize);
|
||||
|
||||
SDValue Cond = DAG.getSetCC(DL,
|
||||
TLI.getSetCCResultType(N0.getValueType()),
|
||||
N0, N1, CC);
|
||||
SDValue CstOffset = DAG.getNode(ISD::SELECT, DL, Zero.getValueType(),
|
||||
Cond, One, Zero);
|
||||
CPIdx = DAG.getNode(ISD::ADD, DL, TLI.getPointerTy(), CPIdx,
|
||||
CstOffset);
|
||||
return DAG.getLoad(TV->getValueType(0), DL, DAG.getEntryNode(), CPIdx,
|
||||
PseudoSourceValue::getConstantPool(), 0, false,
|
||||
Alignment);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
// Check to see if we can perform the "gzip trick", transforming
|
||||
// (select_cc setlt X, 0, A, 0) -> (and (sra X, (sub size(X), 1), A)
|
||||
|
@ -1,6 +1,4 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mcpu=yonah | not grep xmm
|
||||
; FIXME: Failing this until the reverted patch is fixed.
|
||||
; XFAIL: *
|
||||
; This should do a single load into the fp stack for the return, not diddle with xmm registers.
|
||||
|
||||
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
|
||||
|
@ -2,10 +2,10 @@
|
||||
; RUN: -o %t -f
|
||||
; RUN: grep _GLOBAL_OFFSET_TABLE_ %t
|
||||
; RUN: grep piclabel %t | count 3
|
||||
; RUN: grep GOTOFF %t | count 2
|
||||
; RUN: grep CPI %t | count 4
|
||||
; RUN: grep GOTOFF %t | count 1
|
||||
; RUN: grep CPI %t | count 2
|
||||
|
||||
define double @foo(i32 %a.u) {
|
||||
define double @foo(i32 %a.u) nounwind {
|
||||
entry:
|
||||
%tmp = icmp eq i32 %a.u,0
|
||||
%retval = select i1 %tmp, double 4.561230e+02, double 1.234560e+02
|
||||
|
Loading…
x
Reference in New Issue
Block a user