boinc/sched/sched_send.h

70 lines
2.2 KiB
C

// Berkeley Open Infrastructure for Network Computing
// http://boinc.berkeley.edu
// Copyright (C) 2005 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.,
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
extern int get_app_version(
WORKUNIT& wu, APP* &app, APP_VERSION* &avp,
SCHEDULER_REQUEST& sreq, SCHEDULER_REPLY& reply,
PLATFORM_LIST& platforms, SCHED_SHMEM& ss
);
extern void send_work(
SCHEDULER_REQUEST&, SCHEDULER_REPLY&, PLATFORM_LIST&, SCHED_SHMEM&
);
extern int add_result_to_reply(
DB_RESULT& result, WORKUNIT& wu, SCHEDULER_REQUEST&, SCHEDULER_REPLY&,
PLATFORM_LIST&, APP* app, APP_VERSION* avp
);
extern bool anonymous(PLATFORM*);
extern bool find_app_version(
WORK_REQ& wreq, WORKUNIT& wu, PLATFORM_LIST& platform, SCHED_SHMEM& ss,
APP*& app, APP_VERSION*& avp
);
extern bool app_core_compatible(WORK_REQ& wreq, APP_VERSION& av);
// values returned by wu_is_infeasible()
//
#define INFEASIBLE_MEM 1
#define INFEASIBLE_DISK 2
#define INFEASIBLE_CPU 3
#define INFEASIBLE_WORK_BUF 4
#define INFEASIBLE_APP_SETTING 5
#define INFEASIBLE_WORKLOAD 6
#define INFEASIBLE_DUP 7
#define INFEASIBLE_HR 8
extern int wu_is_infeasible(
WORKUNIT&, SCHEDULER_REQUEST&, SCHEDULER_REPLY&, APP&
);
extern double max_allowable_disk(SCHEDULER_REQUEST&, SCHEDULER_REPLY&);
extern bool wu_already_in_reply(WORKUNIT& wu, SCHEDULER_REPLY& reply);
extern double estimate_cpu_duration(WORKUNIT& wu, SCHEDULER_REPLY& reply);
extern int update_wu_transition_time(WORKUNIT wu, time_t x);
extern void lock_sema();
extern void unlock_sema();