projects
/
oota-llvm.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[WinEH] Update CoreCLR EH for catchpad MBBs
[oota-llvm.git]
/
lib
/
CodeGen
/
Spiller.h
diff --git
a/lib/CodeGen/Spiller.h
b/lib/CodeGen/Spiller.h
index dda52e871feafffff473e967eec8cac57dc58b0f..08f99ec78adc70fa561f1a2332fc9a50322105f4 100644
(file)
--- a/
lib/CodeGen/Spiller.h
+++ b/
lib/CodeGen/Spiller.h
@@
-7,43
+7,36
@@
//
//===----------------------------------------------------------------------===//
//
//===----------------------------------------------------------------------===//
-#ifndef LLVM_CODEGEN_SPILLER_H
-#define LLVM_CODEGEN_SPILLER_H
-
-#include "llvm/ADT/SmallVector.h"
-#include <vector>
+#ifndef LLVM_LIB_CODEGEN_SPILLER_H
+#define LLVM_LIB_CODEGEN_SPILLER_H
namespace llvm {
namespace llvm {
- class LiveInterval;
- class LiveIntervals;
- class LiveStacks;
+ class LiveRangeEdit;
class MachineFunction;
class MachineFunction;
- class MachineInstr;
- class MachineLoopInfo;
- class SlotIndex;
+ class MachineFunctionPass;
class VirtRegMap;
class VirtRegMap;
- class VNInfo;
/// Spiller interface.
///
/// Implementations are utility classes which insert spill or remat code on
/// demand.
class Spiller {
/// Spiller interface.
///
/// Implementations are utility classes which insert spill or remat code on
/// demand.
class Spiller {
+ virtual void anchor();
public:
virtual ~Spiller() = 0;
public:
virtual ~Spiller() = 0;
- /// Spill the given live range. The method used will depend on the Spiller
- /// implementation selected.
- virtual std::vector<LiveInterval*> spill(LiveInterval *li,
- SmallVectorImpl<LiveInterval*> &spillIs,
- SlotIndex *earliestIndex = 0) = 0;
+ /// spill - Spill the LRE.getParent() live interval.
+ virtual void spill(LiveRangeEdit &LRE) = 0;
};
};
- /// Create and return a spiller object, as specified on the command line.
- Spiller* createSpiller(MachineFunction *mf, LiveIntervals *li,
- const MachineLoopInfo *loopInfo, VirtRegMap *vrm);
+ /// Create and return a spiller that will insert spill code directly instead
+ /// of deferring though VirtRegMap.
+ Spiller *createInlineSpiller(MachineFunctionPass &pass,
+ MachineFunction &mf,
+ VirtRegMap &vrm);
+
}
#endif
}
#endif