mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-10 22:00:58 +00:00
Make several cleanups to Andrews varargs change:
1. Pass Value*'s into lowering methods so that the proper pointers can be added to load/stores from the valist 2. Intrinsics that return void should only return a token chain, not a token chain/retval pair. 3. Rename LowerVAArgNext -> LowerVAArg, because VANext is long gone. llvm-svn: 22338
This commit is contained in:
parent
3543e3b3a9
commit
bf100c8bdb
@ -26,6 +26,7 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
class Value;
|
||||||
class Function;
|
class Function;
|
||||||
class TargetMachine;
|
class TargetMachine;
|
||||||
class TargetData;
|
class TargetData;
|
||||||
@ -266,25 +267,29 @@ public:
|
|||||||
ArgListTy &Args, SelectionDAG &DAG) = 0;
|
ArgListTy &Args, SelectionDAG &DAG) = 0;
|
||||||
|
|
||||||
/// LowerVAStart - This lowers the llvm.va_start intrinsic. If not
|
/// LowerVAStart - This lowers the llvm.va_start intrinsic. If not
|
||||||
/// implemented, this method prints a message and aborts.
|
/// implemented, this method prints a message and aborts. This method should
|
||||||
virtual std::pair<SDOperand, SDOperand>
|
/// return the modified chain value. Note that VAListPtr* correspond to the
|
||||||
LowerVAStart(SDOperand Chain, SelectionDAG &DAG, SDOperand Dest);
|
/// llvm.va_start operand.
|
||||||
|
virtual SDOperand LowerVAStart(SDOperand Chain, SDOperand VAListP,
|
||||||
|
Value *VAListV, SelectionDAG &DAG);
|
||||||
|
|
||||||
/// LowerVAEnd - This lowers llvm.va_end and returns the resultant chain. If
|
/// LowerVAEnd - This lowers llvm.va_end and returns the resultant chain. If
|
||||||
/// not implemented, this defaults to a noop.
|
/// not implemented, this defaults to a noop.
|
||||||
virtual SDOperand LowerVAEnd(SDOperand Chain, SDOperand L, SelectionDAG &DAG);
|
virtual SDOperand LowerVAEnd(SDOperand Chain, SDOperand LP, Value *LV,
|
||||||
|
SelectionDAG &DAG);
|
||||||
|
|
||||||
/// LowerVACopy - This lowers llvm.va_copy and returns the resultant
|
/// LowerVACopy - This lowers llvm.va_copy and returns the resultant chain.
|
||||||
/// value/chain pair. If not implemented, this defaults to returning the
|
/// If not implemented, this defaults to loading a pointer from the input and
|
||||||
/// input operand.
|
/// storing it to the output.
|
||||||
virtual std::pair<SDOperand,SDOperand>
|
virtual SDOperand LowerVACopy(SDOperand Chain, SDOperand SrcP, Value *SrcV,
|
||||||
LowerVACopy(SDOperand Chain, SDOperand Src, SDOperand Dest, SelectionDAG &DAG);
|
SDOperand DestP, Value *DestV,
|
||||||
|
SelectionDAG &DAG);
|
||||||
|
|
||||||
/// LowerVAArgNext - This lowers the instruction
|
/// LowerVAArg - This lowers the vaarg instruction. If not implemented, this
|
||||||
/// If not implemented, this prints a message and aborts.
|
/// prints a message and aborts.
|
||||||
virtual std::pair<SDOperand,SDOperand>
|
virtual std::pair<SDOperand,SDOperand>
|
||||||
LowerVAArgNext(SDOperand Chain, SDOperand VAList,
|
LowerVAArg(SDOperand Chain, SDOperand VAListP, Value *VAListV,
|
||||||
const Type *ArgTy, SelectionDAG &DAG);
|
const Type *ArgTy, SelectionDAG &DAG);
|
||||||
|
|
||||||
/// LowerFrameReturnAddress - This hook lowers a call to llvm.returnaddress or
|
/// LowerFrameReturnAddress - This hook lowers a call to llvm.returnaddress or
|
||||||
/// llvm.frameaddress (depending on the value of the first argument). The
|
/// llvm.frameaddress (depending on the value of the first argument). The
|
||||||
|
@ -837,34 +837,37 @@ void SelectionDAGLowering::visitFree(FreeInst &I) {
|
|||||||
DAG.setRoot(Result.second);
|
DAG.setRoot(Result.second);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<SDOperand, SDOperand>
|
SDOperand TargetLowering::LowerVAStart(SDOperand Chain,
|
||||||
TargetLowering::LowerVAStart(SDOperand Chain, SelectionDAG &DAG, SDOperand Dest) {
|
SDOperand VAListP, Value *VAListV,
|
||||||
|
SelectionDAG &DAG) {
|
||||||
// We have no sane default behavior, just emit a useful error message and bail
|
// We have no sane default behavior, just emit a useful error message and bail
|
||||||
// out.
|
// out.
|
||||||
std::cerr << "Variable arguments handling not implemented on this target!\n";
|
std::cerr << "Variable arguments handling not implemented on this target!\n";
|
||||||
abort();
|
abort();
|
||||||
return std::make_pair(SDOperand(), SDOperand());
|
return SDOperand();
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand TargetLowering::LowerVAEnd(SDOperand Chain, SDOperand L,
|
SDOperand TargetLowering::LowerVAEnd(SDOperand Chain, SDOperand LP, Value *LV,
|
||||||
SelectionDAG &DAG) {
|
SelectionDAG &DAG) {
|
||||||
// Default to a noop.
|
// Default to a noop.
|
||||||
return Chain;
|
return Chain;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<SDOperand,SDOperand>
|
SDOperand TargetLowering::LowerVACopy(SDOperand Chain,
|
||||||
TargetLowering::LowerVACopy(SDOperand Chain, SDOperand Src, SDOperand Dest,
|
SDOperand SrcP, Value *SrcV,
|
||||||
SelectionDAG &DAG) {
|
SDOperand DestP, Value *DestV,
|
||||||
//Default to returning the input list
|
SelectionDAG &DAG) {
|
||||||
SDOperand Val = DAG.getLoad(getPointerTy(), Chain, Src, DAG.getSrcValue(NULL));
|
// Default to copying the input list.
|
||||||
|
SDOperand Val = DAG.getLoad(getPointerTy(), Chain,
|
||||||
|
SrcP, DAG.getSrcValue(SrcV));
|
||||||
SDOperand Result = DAG.getNode(ISD::STORE, MVT::Other, Val.getValue(1),
|
SDOperand Result = DAG.getNode(ISD::STORE, MVT::Other, Val.getValue(1),
|
||||||
Val, Dest, DAG.getSrcValue(NULL));
|
Val, DestP, DAG.getSrcValue(DestV));
|
||||||
return std::make_pair(Result, Result);
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<SDOperand,SDOperand>
|
std::pair<SDOperand,SDOperand>
|
||||||
TargetLowering::LowerVAArgNext(SDOperand Chain, SDOperand VAList,
|
TargetLowering::LowerVAArg(SDOperand Chain, SDOperand VAListP, Value *VAListV,
|
||||||
const Type *ArgTy, SelectionDAG &DAG) {
|
const Type *ArgTy, SelectionDAG &DAG) {
|
||||||
// We have no sane default behavior, just emit a useful error message and bail
|
// We have no sane default behavior, just emit a useful error message and bail
|
||||||
// out.
|
// out.
|
||||||
std::cerr << "Variable arguments handling not implemented on this target!\n";
|
std::cerr << "Variable arguments handling not implemented on this target!\n";
|
||||||
@ -874,28 +877,28 @@ TargetLowering::LowerVAArgNext(SDOperand Chain, SDOperand VAList,
|
|||||||
|
|
||||||
|
|
||||||
void SelectionDAGLowering::visitVAStart(CallInst &I) {
|
void SelectionDAGLowering::visitVAStart(CallInst &I) {
|
||||||
std::pair<SDOperand,SDOperand> Result = TLI.LowerVAStart(getRoot(), DAG, getValue(I.getOperand(1)));
|
DAG.setRoot(TLI.LowerVAStart(getRoot(), getValue(I.getOperand(1)),
|
||||||
setValue(&I, Result.first);
|
I.getOperand(1), DAG));
|
||||||
DAG.setRoot(Result.second);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SelectionDAGLowering::visitVAArg(VAArgInst &I) {
|
void SelectionDAGLowering::visitVAArg(VAArgInst &I) {
|
||||||
std::pair<SDOperand,SDOperand> Result =
|
std::pair<SDOperand,SDOperand> Result =
|
||||||
TLI.LowerVAArgNext(getRoot(), getValue(I.getOperand(0)),
|
TLI.LowerVAArg(getRoot(), getValue(I.getOperand(0)), I.getOperand(0),
|
||||||
I.getType(), DAG);
|
I.getType(), DAG);
|
||||||
setValue(&I, Result.first);
|
setValue(&I, Result.first);
|
||||||
DAG.setRoot(Result.second);
|
DAG.setRoot(Result.second);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SelectionDAGLowering::visitVAEnd(CallInst &I) {
|
void SelectionDAGLowering::visitVAEnd(CallInst &I) {
|
||||||
DAG.setRoot(TLI.LowerVAEnd(getRoot(), getValue(I.getOperand(1)), DAG));
|
DAG.setRoot(TLI.LowerVAEnd(getRoot(), getValue(I.getOperand(1)),
|
||||||
|
I.getOperand(1), DAG));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SelectionDAGLowering::visitVACopy(CallInst &I) {
|
void SelectionDAGLowering::visitVACopy(CallInst &I) {
|
||||||
std::pair<SDOperand,SDOperand> Result =
|
SDOperand Result =
|
||||||
TLI.LowerVACopy(getRoot(), getValue(I.getOperand(2)), getValue(I.getOperand(1)), DAG);
|
TLI.LowerVACopy(getRoot(), getValue(I.getOperand(2)), I.getOperand(2),
|
||||||
setValue(&I, Result.first);
|
getValue(I.getOperand(1)), I.getOperand(1), DAG);
|
||||||
DAG.setRoot(Result.second);
|
DAG.setRoot(Result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user