2006-02-12 18:12:54 +01:00
|
|
|
// src/backend/policy.hh - Copyright 2005, 2006, University
|
|
|
|
// of Padova, dept. of Pure and Applied
|
|
|
|
// Mathematics
|
|
|
|
//
|
|
|
|
// This file is part of SGPEMv2.
|
|
|
|
//
|
|
|
|
// This is free software; you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation; either version 2 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// SGPEMv2 is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with SGPEMv2; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
|
|
|
#ifndef POLICY_HH
|
|
|
|
#define POLICY_HH 1
|
|
|
|
|
|
|
|
#include "config.h"
|
2006-02-21 12:09:55 +01:00
|
|
|
#include "gettext.h"
|
2006-02-13 12:32:05 +01:00
|
|
|
|
|
|
|
#include "glibmm/ustring.h"
|
|
|
|
|
2006-02-12 18:12:54 +01:00
|
|
|
#include "scheduler.hh"
|
2006-02-13 12:32:05 +01:00
|
|
|
#include "policy_parameters.hh"
|
2006-02-12 18:12:54 +01:00
|
|
|
|
|
|
|
namespace sgpem
|
|
|
|
{
|
2006-02-17 23:19:25 +01:00
|
|
|
|
|
|
|
class Policy;
|
2006-02-12 18:12:54 +01:00
|
|
|
|
2006-02-24 02:06:49 +01:00
|
|
|
/** \brief
|
|
|
|
It's a Strategy wich stay for a scheduling algorithm.
|
|
|
|
It implements the related scheduling policy.
|
|
|
|
Its goal is, usually, to keep a list of Schedulable objects
|
|
|
|
mantained in a SchedulableQueue.
|
|
|
|
*/
|
2006-02-17 23:19:25 +01:00
|
|
|
class SG_DLLEXPORT Policy
|
|
|
|
{
|
|
|
|
public:
|
2006-02-24 02:06:49 +01:00
|
|
|
virtual ~Policy();
|
2006-02-22 16:16:08 +01:00
|
|
|
|
2006-02-24 02:06:49 +01:00
|
|
|
/**
|
|
|
|
Initialize the inner components of the policy.
|
|
|
|
|
|
|
|
Because it's a pure virtual method, must be re-implemented
|
|
|
|
in concrete derived classes.
|
|
|
|
*/
|
|
|
|
virtual void configure() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sort the \ref SchedulableQueue object that contain all the Schedulable objects
|
|
|
|
(Processes, Threads) still active managed by the scheduler.
|
|
|
|
|
|
|
|
Because it's a pure virtual method, must be re-implemented
|
|
|
|
in concrete derived classes.
|
|
|
|
\param event Call reason. Needed only by some scheduling policies.
|
|
|
|
*/
|
|
|
|
virtual void sort_queue(Scheduler::event event) const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the unique identifier (id) of this Policy.
|
|
|
|
\return The Policy id.
|
|
|
|
*/
|
|
|
|
int get_id() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets a string description of the policy.
|
|
|
|
|
|
|
|
Because it's a pure virtual method, must be re-implemented
|
|
|
|
in concrete derived classes.
|
|
|
|
\return String description of the policy.
|
|
|
|
*/
|
|
|
|
virtual Glib::ustring get_description() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Tell if this policy is preemptible.
|
|
|
|
If true, for the \ref Scheduler::SCHEDULABLE_ARRIVAL event, the
|
|
|
|
ready queue will contain also the running \ref Schedulable;
|
|
|
|
else the running Schedulable will not be in the queue.
|
|
|
|
|
|
|
|
Because it's a pure virtual method, must be re-implemented
|
|
|
|
in concrete derived classes.
|
|
|
|
\return True if this policy is preemptible.
|
|
|
|
*/
|
|
|
|
virtual bool is_pre_emptive() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the time quantum for the policy.
|
|
|
|
|
|
|
|
Because it's a pure virtual method, must be re-implemented
|
|
|
|
in concrete derived classes.
|
|
|
|
\return Time quantum for the policy.
|
|
|
|
*/
|
|
|
|
virtual int get_time_slice() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the time quantum for the policy.
|
|
|
|
|
|
|
|
Because it's a pure virtual method, must be re-implemented
|
|
|
|
in concrete derived classes.
|
|
|
|
\param quantum The desired time quantum for the policy.
|
|
|
|
*/
|
|
|
|
virtual void set_time_slice(const int& quantum) = 0;
|
2006-02-22 16:16:08 +01:00
|
|
|
|
2006-02-24 02:06:49 +01:00
|
|
|
/**
|
|
|
|
Gets the parameters related with this policy.
|
|
|
|
|
|
|
|
Because it's a pure virtual method, must be re-implemented
|
|
|
|
in concrete derived classes.
|
|
|
|
\return The policy parameters.
|
|
|
|
*/
|
|
|
|
PolicyParameters& get_parameters();
|
2006-02-22 16:16:08 +01:00
|
|
|
|
2006-02-21 12:09:55 +01:00
|
|
|
protected:
|
2006-02-24 02:06:49 +01:00
|
|
|
PolicyParameters _parameters;
|
|
|
|
int _id;
|
2006-02-17 23:19:25 +01:00
|
|
|
};
|
2006-02-12 18:12:54 +01:00
|
|
|
|
|
|
|
}//~ namespace sgpem
|
|
|
|
|
|
|
|
|
2006-02-19 23:36:24 +01:00
|
|
|
#endif
|