boinc/sched/hr_info.h

67 lines
1.9 KiB
C

// 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_
#include "hr.h"
// 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();
};
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
PERF_INFO perf_info;
int write_file();
int read_file();
void scan_db();
void allot();
void init();
void allocate(int);
bool accept(int, int);
void show(FILE*);
};
#define HR_INFO_FILENAME "../hr_info.txt"
#define PERF_INFO_FILENAME "../perf_info.txt"
#endif