mirror of https://github.com/BOINC/boinc.git
192 lines
5.0 KiB
C++
192 lines
5.0 KiB
C++
#include <vector>
|
|
|
|
#include "app.h"
|
|
#include "time_stats.h"
|
|
#include "client_types.h"
|
|
|
|
using std::vector;
|
|
|
|
#define WORK_FETCH_DONT_NEED 0
|
|
// project: suspended, deferred, or no new work (can't ask for more work)
|
|
// overall: not work_fetch_ok (from CPU policy)
|
|
#define WORK_FETCH_OK 1
|
|
// project: has more than min queue * share, not suspended/def/nonewwork
|
|
// overall: at least min queue, work fetch OK
|
|
#define WORK_FETCH_NEED 2
|
|
// project: less than min queue * resource share of DL/runnable results
|
|
// overall: less than min queue
|
|
#define WORK_FETCH_NEED_IMMEDIATELY 3
|
|
// project: no downloading or runnable results
|
|
// overall: at least one idle CPU
|
|
|
|
|
|
class NORMAL_DIST {
|
|
public:
|
|
double mean;
|
|
double var;
|
|
int parse(XML_PARSER&, char* end_tag);
|
|
double sample();
|
|
};
|
|
|
|
class UNIFORM_DIST {
|
|
public:
|
|
double lo;
|
|
double hi;
|
|
int parse(XML_PARSER&, char* end_tag);
|
|
double sample();
|
|
};
|
|
|
|
class RANDOM_PROCESS {
|
|
public:
|
|
double frac;
|
|
double lambda;
|
|
int parse(XML_PARSER&, char* end_tag);
|
|
};
|
|
|
|
class SIM_APP: public APP {
|
|
public:
|
|
double latency_bound;
|
|
NORMAL_DIST fpops;
|
|
NORMAL_DIST checkpoint_period;
|
|
double working_set;
|
|
|
|
int parse(XML_PARSER&);
|
|
};
|
|
|
|
class SIM_PROJECT: public PROJECT {
|
|
public:
|
|
RANDOM_PROCESS available;
|
|
int parse(XML_PARSER&);
|
|
};
|
|
|
|
class SIM_HOST: public HOST_INFO {
|
|
public:
|
|
RANDOM_PROCESS available;
|
|
RANDOM_PROCESS idle;
|
|
int parse(XML_PARSER&);
|
|
};
|
|
|
|
class CLIENT_STATE {
|
|
public:
|
|
double now;
|
|
vector<PROJECT*> projects;
|
|
vector<WORKUNIT*> workunits;
|
|
vector<RESULT*> results;
|
|
vector<APP*> apps;
|
|
ACTIVE_TASK_SET active_tasks;
|
|
GLOBAL_PREFS global_prefs;
|
|
SIM_HOST host_info;
|
|
TIME_STATS time_stats;
|
|
CLIENT_STATE();
|
|
|
|
private:
|
|
double app_started;
|
|
public:
|
|
ACTIVE_TASK* lookup_active_task_by_result(RESULT*);
|
|
int report_result_error(RESULT&, const char *format, ...);
|
|
double available_ram();
|
|
double max_available_ram();
|
|
void set_client_state_dirty(const char*);
|
|
RESULT* lookup_result(PROJECT*, const char*);
|
|
|
|
// cpu_sched.C
|
|
private:
|
|
double debt_interval_start;
|
|
double total_wall_cpu_time_this_debt_interval;
|
|
// "wall CPU time" accumulated since last adjust_debts()
|
|
double total_cpu_time_this_debt_interval;
|
|
double cpu_shortfall;
|
|
bool work_fetch_no_new_work;
|
|
bool must_enforce_cpu_schedule;
|
|
bool must_schedule_cpus;
|
|
bool must_check_work_fetch;
|
|
std::vector <RESULT*> ordered_scheduled_results;
|
|
void assign_results_to_projects();
|
|
RESULT* largest_debt_project_best_result();
|
|
RESULT* earliest_deadline_result();
|
|
void adjust_debts();
|
|
bool possibly_schedule_cpus();
|
|
void schedule_cpus();
|
|
bool enforce_schedule();
|
|
bool no_work_for_a_cpu();
|
|
void rr_simulation();
|
|
void make_running_task_heap(vector<ACTIVE_TASK*>&);
|
|
void print_deadline_misses();
|
|
inline double work_buf_min() {
|
|
return global_prefs.work_buf_min_days * 86400;
|
|
}
|
|
public:
|
|
void request_enforce_schedule(const char*);
|
|
void request_schedule_cpus(const char*);
|
|
|
|
// --------------- cs_apps.C:
|
|
private:
|
|
double total_resource_share();
|
|
double potentially_runnable_resource_share();
|
|
double nearly_runnable_resource_share();
|
|
public:
|
|
double runnable_resource_share();
|
|
void request_work_fetch(const char*);
|
|
// Check if work fetch needed. Called when:
|
|
// - core client starts (CS::init())
|
|
// - task is completed or fails
|
|
// - tasks are killed
|
|
// - an RPC completes
|
|
// - project suspend/detch/attach/reset GUI RPC
|
|
// - result suspend/abort GUI RPC
|
|
int quit_activities();
|
|
void set_ncpus();
|
|
double estimate_cpu_time(WORKUNIT&);
|
|
double get_fraction_done(RESULT* result);
|
|
int input_files_available(RESULT*, bool);
|
|
ACTIVE_TASK* get_next_graphics_capable_app();
|
|
int ncpus;
|
|
// number of usable cpus
|
|
private:
|
|
int nslots;
|
|
|
|
int app_finished(ACTIVE_TASK&);
|
|
bool start_apps();
|
|
bool handle_finished_apps();
|
|
public:
|
|
ACTIVE_TASK* get_task(RESULT*);
|
|
|
|
// --------------- cs_scheduler.C
|
|
private:
|
|
bool contacted_sched_server;
|
|
int overall_work_fetch_urgency;
|
|
double avg_proc_rate();
|
|
|
|
// --------------- work_fetch.C:
|
|
public:
|
|
int proj_min_results(PROJECT*, double);
|
|
void check_project_timeout();
|
|
PROJECT* next_project_master_pending();
|
|
PROJECT* next_project_sched_rpc_pending();
|
|
PROJECT* next_project_trickle_up_pending();
|
|
PROJECT* next_project_need_work();
|
|
PROJECT* find_project_with_overdue_results();
|
|
double overall_cpu_frac();
|
|
double time_until_work_done(PROJECT*, int, double);
|
|
bool compute_work_requests();
|
|
double work_needed_secs();
|
|
void scale_duration_correction_factors(double);
|
|
void generate_new_host_cpid();
|
|
void compute_nuploading_results();
|
|
|
|
//////////////////
|
|
int parse_projects(char*);
|
|
int parse_host(char*);
|
|
void simulate(double);
|
|
bool scheduler_rpc_poll();
|
|
void simulate_rpc(PROJECT*);
|
|
};
|
|
|
|
class NET_STATUS {
|
|
public:
|
|
bool have_sporadic_connection;
|
|
};
|
|
|
|
extern CLIENT_STATE gstate;
|
|
extern NET_STATUS net_status;
|