boinc/api/api.h

114 lines
3.7 KiB
C++

// 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):
//
#include <stdio.h>
#ifdef HAVE_SYS_TIME_H
#include <sys/time.h>
#endif
#ifdef HAVE_SYS_RESOURCE_H
#include <sys/resource.h>
#endif
#ifndef BOINC_API
#define BOINC_API
// 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, ...);
size_t write(const void *,size_t,size_t);
int close();
int flush();
};
// An application that wants to be well-behaved should do the following:
//
// - call boinc_init(APP_IN&) at startup
// - call time_to_checkpoint() often.
// This is cheap - it returns true if time to checkpoint.
// - checkpoint if time_to_checkpoint() returns true
// - call checkpoint_completed() when checkpoint is complete
// The only member of APP_OUT that needs to be filled in is percent_done
// - boinc_poll():
// Call this as often as requested by core
// - call app_completed() when the application is completed
// The only member of APP_OUT that needs to be filled in is percent_done
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
double cpu_time; // cpu time from previous sessions
};
struct APP_OUT {
double percent_done; //percent of work unit completed
double cpu_time_at_checkpoint; //cpu time of current process
bool checkpointed; // true iff checkpointed since last call
};
void write_core_file(FILE* f, APP_IN &ai);
void parse_core_file(FILE* f, APP_IN&);
void write_init_file(FILE* f, char *file_name, int fdesc, int input_file );
void parse_init_file(FILE* f);
void boinc_init(APP_IN&);
void parse_app_file(FILE* f, APP_OUT&);
void write_app_file(FILE* f, APP_OUT&);
void boinc_poll(APP_IN&, APP_OUT&);
double boinc_cpu_time();
int boinc_resolve_link(char *file_name, char *resolved_name);
#define CORE_TO_APP_FILE "core_to_app.xml"
#define APP_TO_CORE_FILE "app_to_core.xml"
#define BOINC_INIT_FILE "boinc_init.xml"
//the following are provided for implementation of the checkpoint system
int checkpoint_completed(APP_OUT& ao); //call this when checkpoint is completed
int app_completed(APP_OUT& ao); //call this when app is completed
extern bool _checkpoint;
#define time_to_checkpoint() _checkpoint
int set_timer(double period); //period is seconds spent in process
void on_timer(int not_used); //sets _checkpoint to true
double get_cpu_time(); //return cpu time for this process
#endif