diff options
author | Volker Lendecke <vl@samba.org> | 2011-10-26 12:18:21 +0200 |
---|---|---|
committer | Volker Lendecke <vlendec@samba.org> | 2011-10-27 20:28:31 +0200 |
commit | ba0171f72402d823abc86504c35312a29749f9b2 (patch) | |
tree | c7ffa33a32faf8d6baba38f0524532bd21235936 /source3/lib | |
parent | c5cfc83a3e045d87e1fe73160523282eec2314ec (diff) | |
download | samba-ba0171f72402d823abc86504c35312a29749f9b2.tar.gz samba-ba0171f72402d823abc86504c35312a29749f9b2.tar.bz2 samba-ba0171f72402d823abc86504c35312a29749f9b2.zip |
s3: Add processes_exist
Diffstat (limited to 'source3/lib')
-rw-r--r-- | source3/lib/util.c | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/source3/lib/util.c b/source3/lib/util.c index f547ec2a56..9b9d34c22f 100644 --- a/source3/lib/util.c +++ b/source3/lib/util.c @@ -657,6 +657,72 @@ bool process_exists(const struct server_id pid) #endif } +bool processes_exist(const struct server_id *pids, int num_pids, + bool *results) +{ + struct server_id *remote_pids = NULL; + int *remote_idx = NULL; + bool *remote_results = NULL; + int i, num_remote_pids; + bool result = false; + + remote_pids = talloc_array(talloc_tos(), struct server_id, num_pids); + if (remote_pids == NULL) { + goto fail; + } + remote_idx = talloc_array(talloc_tos(), int, num_pids); + if (remote_idx == NULL) { + goto fail; + } + remote_results = talloc_array(talloc_tos(), bool, num_pids); + if (remote_results == NULL) { + goto fail; + } + + num_remote_pids = 0; + + for (i=0; i<num_pids; i++) { + if (procid_is_me(&pids[i])) { + results[i] = true; + continue; + } + if (procid_is_local(&pids[i])) { + results[i] = ((kill(pids[i].pid,0) == 0) || + (errno != ESRCH)); + continue; + } + + remote_pids[num_remote_pids] = pids[i]; + remote_idx[num_remote_pids] = i; + num_remote_pids += 1; + } + + if (num_remote_pids != 0) { +#ifdef CLUSTER_SUPPORT + if (!ctdb_processes_exist(messaging_ctdbd_connection(), + remote_pids, num_remote_pids, + remote_results)) { + goto fail; + } +#else + for (i=0; i<num_remote_pids; i++) { + remote_results[i] = false; + } +#endif + + for (i=0; i<num_remote_pids; i++) { + results[remote_idx[i]] = remote_results[i]; + } + } + + result = true; +fail: + TALLOC_FREE(remote_results); + TALLOC_FREE(remote_idx); + TALLOC_FREE(remote_pids); + return result; +} + /******************************************************************* Convert a uid into a user name. ********************************************************************/ |