blob: 59bc0ec6ae70f2c01b15d43457f3eb64af36771f [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
15namespace llvm {
Lang Hames10382fb2009-06-19 02:17:53 +000016
Daniel Dunbarcfb8a1b2009-07-19 01:38:38 +000017 class LiveInterval;
Bill Wendlingcd35ed52009-05-19 17:52:31 +000018 class MachineFunction;
Jakob Stoklund Olesenf2c6e362010-07-20 23:50:15 +000019 class MachineFunctionPass;
Lang Hames61945692009-12-09 05:39:12 +000020 class SlotIndex;
Lang Hames10382fb2009-06-19 02:17:53 +000021 class VirtRegMap;
Lang Hamese2b201b2009-05-18 19:03:16 +000022
23 /// Spiller interface.
24 ///
25 /// Implementations are utility classes which insert spill or remat code on
26 /// demand.
27 class Spiller {
28 public:
29 virtual ~Spiller() = 0;
Lang Hames857c4e02009-06-17 21:01:20 +000030
Jakob Stoklund Olesen67674e22010-06-24 20:54:29 +000031 /// spill - Spill the given live interval. The method used will depend on
32 /// the Spiller implementation selected.
33 ///
34 /// @param li The live interval to be spilled.
Jakob Stoklund Olesen9e55afb2010-06-30 23:03:52 +000035 /// @param spillIs A list of intervals that are about to be spilled,
36 /// and so cannot be used for remat etc.
Jakob Stoklund Olesen67674e22010-06-24 20:54:29 +000037 /// @param newIntervals The newly created intervals will be appended here.
Jakob Stoklund Olesen67674e22010-06-24 20:54:29 +000038 virtual void spill(LiveInterval *li,
Jakob Stoklund Olesen0a2b2a12010-08-13 22:56:53 +000039 SmallVectorImpl<LiveInterval*> &newIntervals,
40 SmallVectorImpl<LiveInterval*> &spillIs) = 0;
Lang Hames857c4e02009-06-17 21:01:20 +000041
Lang Hamese2b201b2009-05-18 19:03:16 +000042 };
43
44 /// Create and return a spiller object, as specified on the command line.
Jakob Stoklund Olesenf2c6e362010-07-20 23:50:15 +000045 Spiller* createSpiller(MachineFunctionPass &pass,
46 MachineFunction &mf,
47 VirtRegMap &vrm);
Lang Hamese2b201b2009-05-18 19:03:16 +000048}
49
50#endif