blob: c6bd9857dbaf2d1ff98b0ba50aaad46f6130a491 [file] [log] [blame]
Lang Hamese2b201b2009-05-18 19:03:16 +00001//===-- llvm/CodeGen/Spiller.h - Spiller -*- C++ -*------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#ifndef LLVM_CODEGEN_SPILLER_H
11#define LLVM_CODEGEN_SPILLER_H
12
Lang Hames835ca072009-11-19 04:15:33 +000013#include "llvm/ADT/SmallVector.h"
Lang Hamese2b201b2009-05-18 19:03:16 +000014#include <vector>
15
16namespace llvm {
Lang Hames10382fb2009-06-19 02:17:53 +000017
Daniel Dunbarcfb8a1b2009-07-19 01:38:38 +000018 class LiveInterval;
Bill Wendlingcd35ed52009-05-19 17:52:31 +000019 class LiveIntervals;
Lang Hamesf41538d2009-06-02 16:53:25 +000020 class LiveStacks;
Bill Wendlingcd35ed52009-05-19 17:52:31 +000021 class MachineFunction;
Lang Hames857c4e02009-06-17 21:01:20 +000022 class MachineInstr;
Lang Hames835ca072009-11-19 04:15:33 +000023 class MachineLoopInfo;
Lang Hames10382fb2009-06-19 02:17:53 +000024 class VirtRegMap;
25 class VNInfo;
Lang Hamese2b201b2009-05-18 19:03:16 +000026
27 /// Spiller interface.
28 ///
29 /// Implementations are utility classes which insert spill or remat code on
30 /// demand.
31 class Spiller {
32 public:
33 virtual ~Spiller() = 0;
Lang Hames857c4e02009-06-17 21:01:20 +000034
35 /// Spill the given live range. The method used will depend on the Spiller
36 /// implementation selected.
Lang Hames835ca072009-11-19 04:15:33 +000037 virtual std::vector<LiveInterval*> spill(LiveInterval *li,
38 SmallVectorImpl<LiveInterval*> &spillIs) = 0;
Lang Hames857c4e02009-06-17 21:01:20 +000039
Lang Hamese2b201b2009-05-18 19:03:16 +000040 };
41
42 /// Create and return a spiller object, as specified on the command line.
Bill Wendling0bde89e2009-05-19 17:51:26 +000043 Spiller* createSpiller(MachineFunction *mf, LiveIntervals *li,
Lang Hames8783e402009-11-20 00:53:30 +000044 const MachineLoopInfo *loopInfo, VirtRegMap *vrm);
Lang Hamese2b201b2009-05-18 19:03:16 +000045}
46
47#endif