mirror of https://github.com/BOINC/boinc.git
*** empty log message ***
svn path=/trunk/boinc/; revision=6778
This commit is contained in:
parent
d25c0d383c
commit
0d2a0ad9a3
|
@ -90,21 +90,27 @@ static volatile bool have_new_trickle_up = false;
|
||||||
static volatile bool have_trickle_down = true;
|
static volatile bool have_trickle_down = true;
|
||||||
// on first call, scan slot dir for msgs
|
// on first call, scan slot dir for msgs
|
||||||
static volatile int heartbeat_giveup_time;
|
static volatile int heartbeat_giveup_time;
|
||||||
|
// interrupt count value at which to give up on core client
|
||||||
static volatile bool heartbeat_active;
|
static volatile bool heartbeat_active;
|
||||||
// if false, suppress heartbeat mechanism
|
// if false, suppress heartbeat mechanism
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
static volatile int nrunning_ticks = 0;
|
static volatile int nrunning_ticks = 0;
|
||||||
#endif
|
#endif
|
||||||
|
static volatile int interrupt_count = 0;
|
||||||
|
// number of timer interrupts
|
||||||
|
// used to measure elapsed time in a way that's
|
||||||
|
// not affected by user changing system clock,
|
||||||
|
// and that doesn't have big jumps around hibernation
|
||||||
static double fpops_per_cpu_sec = 0;
|
static double fpops_per_cpu_sec = 0;
|
||||||
static double fpops_cumulative = 0;
|
static double fpops_cumulative = 0;
|
||||||
|
|
||||||
#define TIMER_PERIOD 1
|
#define TIMER_PERIOD 1
|
||||||
// period of worker-thread timer
|
// period of worker-thread timer interrupts.
|
||||||
// This determines the resolution of fraction done and CPU time reporting
|
// This determines the resolution of fraction done and CPU time reporting
|
||||||
// to the core client, and of checkpoint enabling.
|
// to the core client, and of checkpoint enabling.
|
||||||
// It doesn't influence graphics, so 1 sec is enough.
|
// It doesn't influence graphics, so 1 sec is enough.
|
||||||
#define HEARTBEAT_GIVEUP_PERIOD 30
|
#define HEARTBEAT_GIVEUP_PERIOD (30/TIMER_PERIOD)
|
||||||
// quit if no heartbeat from core in this #secs
|
// quit if no heartbeat from core in this #interrupts
|
||||||
#define HEARTBEAT_TIMEOUT_PERIOD 35
|
#define HEARTBEAT_TIMEOUT_PERIOD 35
|
||||||
// quit if we cannot aquire slot resource in this #secs
|
// quit if we cannot aquire slot resource in this #secs
|
||||||
|
|
||||||
|
@ -275,7 +281,7 @@ int boinc_init_options_general(BOINC_OPTIONS& opt) {
|
||||||
last_wu_cpu_time = aid.wu_cpu_time;
|
last_wu_cpu_time = aid.wu_cpu_time;
|
||||||
|
|
||||||
heartbeat_active = !standalone;
|
heartbeat_active = !standalone;
|
||||||
heartbeat_giveup_time = time(0) + HEARTBEAT_GIVEUP_PERIOD;
|
heartbeat_giveup_time = interrupt_count + HEARTBEAT_GIVEUP_PERIOD;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -450,7 +456,7 @@ static void handle_heartbeat_msg() {
|
||||||
char buf[MSG_CHANNEL_SIZE];
|
char buf[MSG_CHANNEL_SIZE];
|
||||||
if (app_client_shm->shm->heartbeat.get_msg(buf)) {
|
if (app_client_shm->shm->heartbeat.get_msg(buf)) {
|
||||||
if (match_tag(buf, "<heartbeat/>")) {
|
if (match_tag(buf, "<heartbeat/>")) {
|
||||||
heartbeat_giveup_time = time(0) + HEARTBEAT_GIVEUP_PERIOD;
|
heartbeat_giveup_time = interrupt_count + HEARTBEAT_GIVEUP_PERIOD;
|
||||||
}
|
}
|
||||||
if (match_tag(buf, "<enable_heartbeat/>")) {
|
if (match_tag(buf, "<enable_heartbeat/>")) {
|
||||||
heartbeat_active = true;
|
heartbeat_active = true;
|
||||||
|
@ -533,7 +539,7 @@ static void handle_process_control_msg() {
|
||||||
}
|
}
|
||||||
boinc_sleep(1.0);
|
boinc_sleep(1.0);
|
||||||
}
|
}
|
||||||
heartbeat_giveup_time = time(0) + HEARTBEAT_GIVEUP_PERIOD;
|
heartbeat_giveup_time = interrupt_time + HEARTBEAT_GIVEUP_PERIOD;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -566,6 +572,7 @@ static void CALLBACK worker_timer(
|
||||||
#else
|
#else
|
||||||
static void worker_timer(int /*a*/) {
|
static void worker_timer(int /*a*/) {
|
||||||
#endif
|
#endif
|
||||||
|
interrupt_count++;
|
||||||
if (!ready_to_checkpoint) {
|
if (!ready_to_checkpoint) {
|
||||||
time_until_checkpoint -= TIMER_PERIOD;
|
time_until_checkpoint -= TIMER_PERIOD;
|
||||||
if (time_until_checkpoint <= 0) {
|
if (time_until_checkpoint <= 0) {
|
||||||
|
@ -591,11 +598,10 @@ static void worker_timer(int /*a*/) {
|
||||||
// (unless we're checkpointing)
|
// (unless we're checkpointing)
|
||||||
//
|
//
|
||||||
if (!checkpointing && options.check_heartbeat && heartbeat_active) {
|
if (!checkpointing && options.check_heartbeat && heartbeat_active) {
|
||||||
int now = time(0);
|
if (heartbeat_giveup_time < interrupt_count) {
|
||||||
if (heartbeat_giveup_time < now) {
|
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"No heartbeat from core client for %d sec - exiting\n",
|
"No heartbeat from core client for %d sec - exiting\n",
|
||||||
now - (heartbeat_giveup_time - HEARTBEAT_GIVEUP_PERIOD)
|
interrupt_count - (heartbeat_giveup_time - HEARTBEAT_GIVEUP_PERIOD)
|
||||||
);
|
);
|
||||||
if (options.direct_process_action) {
|
if (options.direct_process_action) {
|
||||||
boinc_exit(0);
|
boinc_exit(0);
|
||||||
|
|
|
@ -9477,3 +9477,28 @@ David 23 July 2005
|
||||||
md5_file.C,h
|
md5_file.C,h
|
||||||
miofile.C
|
miofile.C
|
||||||
network.C
|
network.C
|
||||||
|
|
||||||
|
David 23 July 2005
|
||||||
|
- API: change heartbeat mechanism so that instead of using time(0),
|
||||||
|
it uses its own counter (incremented on interrupt).
|
||||||
|
This avoid specious heartbeat timeout
|
||||||
|
when user resets system clock.
|
||||||
|
It should also fix problem where BOINC restarts
|
||||||
|
after hibernation, app runs before core client,
|
||||||
|
and it gets heartbeat timeout.
|
||||||
|
- Core client: add "-no_gui_rpc" cmdline option.
|
||||||
|
If present, don't create listening socket for GUI RPC.
|
||||||
|
(Useful if bind() doesn't work).
|
||||||
|
- shared memory: in shmget() mode, first try 0666;
|
||||||
|
if that fails, try SHM_R|SHM_W
|
||||||
|
This is just paranoia, in case 21/July checkin
|
||||||
|
breaks some platform.
|
||||||
|
|
||||||
|
api/
|
||||||
|
boinc_api.C
|
||||||
|
client/
|
||||||
|
client_state.C,h
|
||||||
|
cs_cmdline.C
|
||||||
|
gui_rpc_server.C,h
|
||||||
|
lib/
|
||||||
|
shmem.C
|
||||||
|
|
|
@ -118,6 +118,7 @@ CLIENT_STATE::CLIENT_STATE() {
|
||||||
total_wall_cpu_time_this_period = 0;
|
total_wall_cpu_time_this_period = 0;
|
||||||
must_schedule_cpus = true;
|
must_schedule_cpus = true;
|
||||||
want_network_flag = false;
|
want_network_flag = false;
|
||||||
|
no_gui_rpc = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
@ -357,8 +358,10 @@ int CLIENT_STATE::init() {
|
||||||
//
|
//
|
||||||
set_client_state_dirty("init");
|
set_client_state_dirty("init");
|
||||||
|
|
||||||
retval = gui_rpcs.init();
|
if (!no_gui_rpc) {
|
||||||
if (retval) return retval;
|
retval = gui_rpcs.init();
|
||||||
|
if (retval) return retval;
|
||||||
|
}
|
||||||
|
|
||||||
acct_mgr_info.init();
|
acct_mgr_info.init();
|
||||||
|
|
||||||
|
|
|
@ -191,6 +191,7 @@ public:
|
||||||
bool want_network_flag;
|
bool want_network_flag;
|
||||||
bool want_network();
|
bool want_network();
|
||||||
void network_available();
|
void network_available();
|
||||||
|
bool no_gui_rpc;
|
||||||
private:
|
private:
|
||||||
int link_app(PROJECT*, APP*);
|
int link_app(PROJECT*, APP*);
|
||||||
int link_file_info(PROJECT*, FILE_INFO*);
|
int link_file_info(PROJECT*, FILE_INFO*);
|
||||||
|
|
|
@ -47,7 +47,9 @@ static void print_options(char* prog) {
|
||||||
" -check_all_logins for idle detection, check remote logins\n too"
|
" -check_all_logins for idle detection, check remote logins\n too"
|
||||||
" -allow_remote_gui_rpc allow remote GUI RPC connections\n"
|
" -allow_remote_gui_rpc allow remote GUI RPC connections\n"
|
||||||
" -redirectio redirect stdout and stderr to log files\n"
|
" -redirectio redirect stdout and stderr to log files\n"
|
||||||
" -dir <path> use given dir as BOINC home\n",
|
" -dir <path> use given dir as BOINC home\n"
|
||||||
|
" -no_gui_rpc don't allow GUI RPC, don't make socket\n"
|
||||||
|
,
|
||||||
prog
|
prog
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -167,6 +169,8 @@ void CLIENT_STATE::parse_cmdline(int argc, char** argv) {
|
||||||
if (chdir(argv[++i])) {
|
if (chdir(argv[++i])) {
|
||||||
perror("chdir");
|
perror("chdir");
|
||||||
}
|
}
|
||||||
|
} else if (ARG(no_gui_rpc)) {
|
||||||
|
no_gui_rpc = true;
|
||||||
} else {
|
} else {
|
||||||
printf("Unknown option: %s\n", argv[i]);
|
printf("Unknown option: %s\n", argv[i]);
|
||||||
show_options = true;
|
show_options = true;
|
||||||
|
|
|
@ -656,6 +656,10 @@ int GUI_RPC_CONN::handle_rpc() {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GUI_RPC_CONN_SET::GUI_RPC_CONN_SET() {
|
||||||
|
lsock = -1;
|
||||||
|
}
|
||||||
|
|
||||||
int GUI_RPC_CONN_SET::get_password() {
|
int GUI_RPC_CONN_SET::get_password() {
|
||||||
strcpy(password, "");
|
strcpy(password, "");
|
||||||
if (boinc_file_exists(GUI_RPC_PASSWD_FILE)) {
|
if (boinc_file_exists(GUI_RPC_PASSWD_FILE)) {
|
||||||
|
|
|
@ -45,6 +45,7 @@ class GUI_RPC_CONN_SET {
|
||||||
int get_password();
|
int get_password();
|
||||||
int insert(GUI_RPC_CONN*);
|
int insert(GUI_RPC_CONN*);
|
||||||
public:
|
public:
|
||||||
|
GUI_RPC_CONN_SET();
|
||||||
char password[256];
|
char password[256];
|
||||||
bool poll();
|
bool poll();
|
||||||
int init();
|
int init();
|
||||||
|
|
10
lib/shmem.C
10
lib/shmem.C
|
@ -50,7 +50,6 @@
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
|
||||||
HANDLE create_shmem(LPCTSTR seg_name, int size, void** pp, bool disable_mapview) {
|
HANDLE create_shmem(LPCTSTR seg_name, int size, void** pp, bool disable_mapview) {
|
||||||
|
|
||||||
SECURITY_ATTRIBUTES security;
|
SECURITY_ATTRIBUTES security;
|
||||||
HANDLE hMap;
|
HANDLE hMap;
|
||||||
DWORD dwError = 0;
|
DWORD dwError = 0;
|
||||||
|
@ -95,8 +94,10 @@ int detach_shmem(HANDLE hMap, void* p) {
|
||||||
|
|
||||||
int create_shmem(key_t key, int size, void** pp) {
|
int create_shmem(key_t key, int size, void** pp) {
|
||||||
int id;
|
int id;
|
||||||
assert(pp!=NULL);
|
id = shmget(key, size, IPC_CREAT|0666);
|
||||||
id = shmget(key, size, IPC_CREAT|SHM_R|SHM_W);
|
if (id < 0) {
|
||||||
|
id = shmget(key, size, IPC_CREAT|SHM_R|SHM_W);
|
||||||
|
}
|
||||||
if (id < 0) {
|
if (id < 0) {
|
||||||
return ERR_SHMGET;
|
return ERR_SHMGET;
|
||||||
}
|
}
|
||||||
|
@ -122,7 +123,7 @@ int destroy_shmem(key_t key){
|
||||||
int attach_shmem(key_t key, void** pp){
|
int attach_shmem(key_t key, void** pp){
|
||||||
void* p;
|
void* p;
|
||||||
int id;
|
int id;
|
||||||
assert(pp!=NULL);
|
|
||||||
id = shmget(key, 0, 0);
|
id = shmget(key, 0, 0);
|
||||||
if (id < 0) {
|
if (id < 0) {
|
||||||
return ERR_SHMGET;
|
return ERR_SHMGET;
|
||||||
|
@ -137,7 +138,6 @@ int attach_shmem(key_t key, void** pp){
|
||||||
|
|
||||||
int detach_shmem(void* p) {
|
int detach_shmem(void* p) {
|
||||||
int retval;
|
int retval;
|
||||||
assert(p!=NULL);
|
|
||||||
retval = shmdt((char *)p);
|
retval = shmdt((char *)p);
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue