2008-05-06 19:53:49 +00:00
|
|
|
// Berkeley Open Infrastructure for Network Computing
|
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2008 University of California
|
|
|
|
//
|
|
|
|
// This is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
|
|
// License as published by the Free Software Foundation;
|
|
|
|
// either version 2.1 of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This software 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 Lesser General Public License for more details.
|
|
|
|
//
|
|
|
|
// To view the GNU Lesser General Public License visit
|
|
|
|
// http://www.gnu.org/copyleft/lesser.html
|
|
|
|
// or write to the Free Software Foundation, Inc.,
|
|
|
|
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
|
|
#ifndef _HR_INFO_
|
|
|
|
#define _HR_INFO_
|
|
|
|
|
2007-06-25 23:56:03 +00:00
|
|
|
#include "hr.h"
|
|
|
|
|
2008-05-06 19:53:49 +00:00
|
|
|
// statistics about the host population,
|
|
|
|
// and about the set of jobs in shared mem.
|
|
|
|
//
|
|
|
|
struct PERF_INFO {
|
|
|
|
double host_fpops_mean;
|
|
|
|
double host_fpops_stdev;
|
|
|
|
double wu_fpops_mean;
|
|
|
|
double wu_fpops_stdev;
|
|
|
|
|
|
|
|
int write_file();
|
|
|
|
int read_file();
|
|
|
|
};
|
|
|
|
|
2007-06-25 23:56:03 +00:00
|
|
|
struct HR_INFO {
|
|
|
|
double *rac_per_class[HR_NTYPES];
|
|
|
|
// how much RAC per class
|
|
|
|
int *max_slots[HR_NTYPES];
|
|
|
|
// max # of work array slots per class
|
|
|
|
int *cur_slots[HR_NTYPES];
|
|
|
|
// estimate of current # of slots used for per class
|
|
|
|
double type_weights[HR_NTYPES];
|
|
|
|
// total app weight per type
|
|
|
|
int slots_per_type[HR_NTYPES];
|
|
|
|
// # of slots per type (fixed at start)
|
|
|
|
bool type_being_used[HR_NTYPES];
|
|
|
|
// whether any app is actually using this HR type
|
2008-05-06 19:53:49 +00:00
|
|
|
PERF_INFO perf_info;
|
|
|
|
|
2007-06-25 23:56:03 +00:00
|
|
|
int write_file();
|
|
|
|
int read_file();
|
|
|
|
void scan_db();
|
|
|
|
void allot();
|
|
|
|
void init();
|
|
|
|
void allocate(int);
|
|
|
|
bool accept(int, int);
|
2007-07-05 23:06:18 +00:00
|
|
|
void show(FILE*);
|
2007-06-25 23:56:03 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#define HR_INFO_FILENAME "../hr_info.txt"
|
2008-05-06 19:53:49 +00:00
|
|
|
#define PERF_INFO_FILENAME "../perf_info.txt"
|
|
|
|
|
|
|
|
#endif
|