summaryrefslogtreecommitdiff
path: root/TAO/orbsvcs/examples/FaultTolerance/FLARe/DeCoRAM/src/FTRMFF_Forward_Packing.h
blob: f0844934a94957aa76bd0e1dd51e4c21be49cae6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// -*- C++ -*-

//=============================================================================
/**
 *  @file     FTRMFF_Forward_Packing.h
 *
 *  $Id$
 *
 *  @author  Friedhelm Wolf (fwolf@dre.vanderbilt.edu)
 */
//=============================================================================

#ifndef FTRMFF_FORWARD_PACKING_ALGORITHM_H_
#define FTRMFF_FORWARD_PACKING_ALGORITHM_H_

#include "Schedule.h"
#include "Packing_Scheduler.h"

class FTRMFF_Forward_Packing : public FTRMFF_Algorithm
{
public:
  virtual ~FTRMFF_Forward_Packing ();

  virtual FTRMFF_Output operator () (const FTRMFF_Input & input);
};

class FTRMFF_Forward_Packing_Algorithm : 
  public std::unary_function <TASK_LIST,
                              SCHEDULING_MAP>
{
public:
  FTRMFF_Forward_Packing_Algorithm (const PROCESSOR_LIST & processors,
                                    unsigned int consistency_level);

  virtual ~FTRMFF_Forward_Packing_Algorithm ();

  virtual SCHEDULING_MAP operator () (const TASK_LIST & tasks);

  SCHEDULE_PROGRESS_LIST get_unschedulable ();

  SCHEDULE schedule () const;
private:
  TASK_LIST create_tasks (const Task & task);

private:
  SCHEDULE_PROGRESS_LIST unschedulable_;
  unsigned int consistency_level_;
  Packing_Scheduler scheduler_;
};

#endif /* FTRMFF_FORWARD_PACKING_ALGORITHM_H_ */