2002-04-30 22:22:54 +00:00
|
|
|
// The contents of this file are subject to the Mozilla Public License
|
|
|
|
// Version 1.0 (the "License"); you may not use this file except in
|
|
|
|
// compliance with the License. You may obtain a copy of the License at
|
|
|
|
// http://www.mozilla.org/MPL/
|
|
|
|
//
|
|
|
|
// Software distributed under the License is distributed on an "AS IS"
|
|
|
|
// basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
|
|
|
// License for the specific language governing rights and limitations
|
|
|
|
// under the License.
|
|
|
|
//
|
|
|
|
// The Original Code is the Berkeley Open Infrastructure for Network Computing.
|
|
|
|
//
|
|
|
|
// The Initial Developer of the Original Code is the SETI@home project.
|
|
|
|
// Portions created by the SETI@home project are Copyright (C) 2002
|
|
|
|
// University of California at Berkeley. All Rights Reserved.
|
|
|
|
//
|
|
|
|
// Contributor(s):
|
|
|
|
//
|
|
|
|
|
2002-06-10 06:14:18 +00:00
|
|
|
#include <stdio.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
#ifdef HAVE_SYS_TIME_H
|
2002-06-21 18:31:32 +00:00
|
|
|
#include <sys/time.h>
|
2002-07-03 22:37:24 +00:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_RESOURCE_H
|
2002-06-21 18:31:32 +00:00
|
|
|
#include <sys/resource.h>
|
|
|
|
#endif
|
2002-06-10 06:14:18 +00:00
|
|
|
|
|
|
|
#ifndef BOINC_API
|
|
|
|
#define BOINC_API
|
|
|
|
|
2002-04-30 22:22:54 +00:00
|
|
|
// MFILE supports a primitive form of checkpointing.
|
|
|
|
// Write all your output (and restart file) to MFILEs.
|
|
|
|
// The output is buffered in memory.
|
|
|
|
// Then close all the MFILEs;
|
|
|
|
// all the buffers will be flushed to disk, almost atomically.
|
|
|
|
|
|
|
|
class MFILE {
|
|
|
|
char* buf;
|
|
|
|
int len;
|
|
|
|
FILE* f;
|
|
|
|
public:
|
|
|
|
int open(char* path, char* mode);
|
|
|
|
int _putchar(char);
|
|
|
|
int puts(char*);
|
|
|
|
int printf(char* format, ...);
|
2002-05-10 04:04:36 +00:00
|
|
|
size_t write(const void *,size_t,size_t);
|
2002-04-30 22:22:54 +00:00
|
|
|
int close();
|
|
|
|
int flush();
|
|
|
|
};
|
2002-05-10 04:04:36 +00:00
|
|
|
|
2002-06-10 06:14:18 +00:00
|
|
|
// An application that wants to be well-behaved should do the following:
|
|
|
|
//
|
2002-06-24 17:30:49 +00:00
|
|
|
// - call boinc_init(APP_IN&) at startup
|
|
|
|
// - call time_to_checkpoint() often.
|
|
|
|
// This is cheap - it returns true if time to checkpoint.
|
2002-07-15 23:37:55 +00:00
|
|
|
// - checkpoint if time_to_checkpoint() returns true
|
2002-06-24 17:30:49 +00:00
|
|
|
// - call checkpoint_completed() when checkpoint is complete
|
2002-07-15 23:37:55 +00:00
|
|
|
// The only member of APP_OUT that needs to be filled in is percent_done
|
2002-06-10 06:14:18 +00:00
|
|
|
// - boinc_poll():
|
|
|
|
// Call this as often as requested by core
|
2002-07-15 23:37:55 +00:00
|
|
|
// - call app_completed() when the application is completed
|
|
|
|
// The only member of APP_OUT that needs to be filled in is percent_done
|
2002-06-10 06:14:18 +00:00
|
|
|
|
|
|
|
struct APP_IN_GRAPHICS {
|
|
|
|
int xsize;
|
|
|
|
int ysize;
|
|
|
|
double refresh_period;
|
|
|
|
char shmem_seg_name[32];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct APP_OUT_GRAPHICS {
|
|
|
|
};
|
|
|
|
|
|
|
|
struct APP_IN {
|
|
|
|
char app_preferences[4096];
|
|
|
|
APP_IN_GRAPHICS graphics;
|
|
|
|
double checkpoint_period; // recommended checkpoint period
|
|
|
|
double poll_period; // recommended poll period
|
2002-06-21 18:31:32 +00:00
|
|
|
double cpu_time; // cpu time from previous sessions
|
2002-06-10 06:14:18 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct APP_OUT {
|
2002-07-15 23:37:55 +00:00
|
|
|
double percent_done; //percent of work unit completed
|
|
|
|
double cpu_time_at_checkpoint; //cpu time of current process
|
2002-06-10 06:14:18 +00:00
|
|
|
bool checkpointed; // true iff checkpointed since last call
|
|
|
|
};
|
|
|
|
|
2002-06-10 22:59:15 +00:00
|
|
|
void write_core_file(FILE* f, APP_IN &ai);
|
2002-06-21 18:31:32 +00:00
|
|
|
void parse_core_file(FILE* f, APP_IN&);
|
2002-06-14 22:56:28 +00:00
|
|
|
void write_init_file(FILE* f, char *file_name, int fdesc, int input_file );
|
|
|
|
void parse_init_file(FILE* f);
|
2002-06-10 06:14:18 +00:00
|
|
|
void boinc_init(APP_IN&);
|
2002-06-21 18:31:32 +00:00
|
|
|
void parse_app_file(FILE* f, APP_OUT&);
|
|
|
|
void write_app_file(FILE* f, APP_OUT&);
|
2002-06-10 06:14:18 +00:00
|
|
|
void boinc_poll(APP_IN&, APP_OUT&);
|
|
|
|
double boinc_cpu_time();
|
2002-06-14 22:56:28 +00:00
|
|
|
int boinc_resolve_link(char *file_name, char *resolved_name);
|
2002-06-10 06:14:18 +00:00
|
|
|
|
|
|
|
#define CORE_TO_APP_FILE "core_to_app.xml"
|
|
|
|
#define APP_TO_CORE_FILE "app_to_core.xml"
|
2002-06-14 22:56:28 +00:00
|
|
|
#define BOINC_INIT_FILE "boinc_init.xml"
|
2002-06-10 06:14:18 +00:00
|
|
|
|
2002-06-21 18:31:32 +00:00
|
|
|
//the following are provided for implementation of the checkpoint system
|
2002-07-15 23:37:55 +00:00
|
|
|
int checkpoint_completed(APP_OUT& ao); //call this when checkpoint is completed
|
|
|
|
int app_completed(APP_OUT& ao); //call this when app is completed
|
2002-07-03 20:48:01 +00:00
|
|
|
|
2002-06-24 21:29:05 +00:00
|
|
|
extern bool _checkpoint;
|
|
|
|
#define time_to_checkpoint() _checkpoint
|
2002-06-28 23:30:22 +00:00
|
|
|
int set_timer(double period); //period is seconds spent in process
|
2002-07-15 23:37:55 +00:00
|
|
|
void on_timer(int not_used); //sets _checkpoint to true
|
2002-06-21 18:31:32 +00:00
|
|
|
double get_cpu_time(); //return cpu time for this process
|
|
|
|
|
2002-05-10 04:04:36 +00:00
|
|
|
#endif
|