mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-10 22:00:58 +00:00
Stub out constant GV handling, fixes C++ eh tests.
llvm-svn: 115375
This commit is contained in:
parent
619f1c1cc5
commit
c1f6f9a730
@ -19,6 +19,7 @@
|
||||
#include "ARMRegisterInfo.h"
|
||||
#include "ARMTargetMachine.h"
|
||||
#include "ARMSubtarget.h"
|
||||
#include "ARMConstantPoolValue.h"
|
||||
#include "llvm/CallingConv.h"
|
||||
#include "llvm/DerivedTypes.h"
|
||||
#include "llvm/GlobalVariable.h"
|
||||
@ -59,7 +60,7 @@ class ARMFastISel : public FastISel {
|
||||
const TargetMachine &TM;
|
||||
const TargetInstrInfo &TII;
|
||||
const TargetLowering &TLI;
|
||||
const ARMFunctionInfo *AFI;
|
||||
ARMFunctionInfo *AFI;
|
||||
|
||||
// Convenience variables to avoid some queries.
|
||||
bool isThumb;
|
||||
@ -139,6 +140,7 @@ class ARMFastISel : public FastISel {
|
||||
bool ARMComputeRegOffset(const Value *Obj, unsigned &Reg, int &Offset);
|
||||
unsigned ARMMaterializeFP(const ConstantFP *CFP, EVT VT);
|
||||
unsigned ARMMaterializeInt(const Constant *C, EVT VT);
|
||||
unsigned ARMMaterializeGV(const GlobalValue *GV, EVT VT);
|
||||
unsigned ARMMoveToFPReg(EVT VT, unsigned SrcReg);
|
||||
unsigned ARMMoveToIntReg(EVT VT, unsigned SrcReg);
|
||||
|
||||
@ -446,6 +448,11 @@ unsigned ARMFastISel::ARMMaterializeInt(const Constant *C, EVT VT) {
|
||||
return DestReg;
|
||||
}
|
||||
|
||||
unsigned ARMFastISel::ARMMaterializeGV(const GlobalValue *GV, EVT VT) {
|
||||
// Disable currently...
|
||||
return 0;
|
||||
}
|
||||
|
||||
unsigned ARMFastISel::TargetMaterializeConstant(const Constant *C) {
|
||||
EVT VT = TLI.getValueType(C->getType(), true);
|
||||
|
||||
@ -454,7 +461,12 @@ unsigned ARMFastISel::TargetMaterializeConstant(const Constant *C) {
|
||||
|
||||
if (const ConstantFP *CFP = dyn_cast<ConstantFP>(C))
|
||||
return ARMMaterializeFP(CFP, VT);
|
||||
return ARMMaterializeInt(C, VT);
|
||||
else if (const GlobalValue *GV = dyn_cast<GlobalValue>(C))
|
||||
return ARMMaterializeGV(GV, VT);
|
||||
else if (isa<ConstantInt>(C))
|
||||
return ARMMaterializeInt(C, VT);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
unsigned ARMFastISel::TargetMaterializeAlloca(const AllocaInst *AI) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user