本文整理汇总了C++中WIFSIGNALED函数的典型用法代码示例。如果您正苦于以下问题:C++ WIFSIGNALED函数的具体用法?C++ WIFSIGNALED怎么用?C++ WIFSIGNALED使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了WIFSIGNALED函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: dns_endrequest
/* Called to end a DNS request. 0 = Not handled, >0 = Ok, <0 = Error */
int dns_endrequest(pid_t pid, int status) {
struct dnschild *lastchild, *child;
struct dnsresult result;
char *ip;
char *name;
size_t len;
/* Check to see whether this was a DNS child */
child = dnschildren;
lastchild = 0;
while (child) {
if (child->pid == pid)
break;
lastchild = child;
child = child->next;
}
if (!child)
return 0;
/* Remove it from the list */
if (lastchild) {
lastchild->next = child->next;
} else {
dnschildren = child->next;
}
debug("%d: Was a DNS child, getting result", pid);
/* Parameters to call function with */
name = 0;
ip = 0;
/* Read from pipe if child returned normally */
if (WIFEXITED(status)) {
if (!WEXITSTATUS(status)) {
len = read(child->pipe, (void *)&result, sizeof(struct dnsresult));
if (len != sizeof(struct dnsresult)) {
syscall_fail("read", 0, 0);
} else if (result.success) {
debug("%d: Got result", pid);
ip = result.ip;
name = result.name;
} else {
debug("%d: DNS lookup failed", pid);
}
} else {
debug("%d: DNS lookup returned %d", pid, WEXITSTATUS(status));
}
} else if (WIFSIGNALED(status)) {
debug("%d: DNS lookup terminated with signal %d", pid, WTERMSIG(status));
} else {
debug("%d: DNS lookup terminated abnormally", pid);
}
/* If DNS failed, but we were looking up an IP address, fill that */
if (!ip && child->ip) {
strcpy(result.ip, child->ip);
ip = result.ip;
}
/* If DNS failed but we have an IP, fill the name with the IP */
if (ip && (!name || !strlen(name))) {
strncpy(result.name, ip, sizeof(result.name));
result.name[sizeof(result.name) - 1] = '\0';
debug("%d: Changed name to '%s'", pid, result.name);
name = result.name;
}
/* Call the function */
child->function(child->boundto, child->data, ip, name);
/* Clean up */
close(child->pipe);
free(child);
return 1;
}
示例2: job_reap
int job_reap( bool interactive )
{
ASSERT_IS_MAIN_THREAD();
job_t *jnext;
int found=0;
static int locked = 0;
locked++;
/*
job_read may fire an event handler, we do not want to call
ourselves recursively (to avoid infinite recursion).
*/
if( locked>1 )
return 0;
job_iterator_t jobs;
jnext = jobs.next();
while (jnext)
{
job_t *j = jnext;
jnext = jobs.next();
process_t *p;
/*
If we are reaping only jobs who do not need status messages
sent to the console, do not consider reaping jobs that need
status messages
*/
if( (!job_get_flag( j, JOB_SKIP_NOTIFICATION ) ) && (!interactive) && (!job_get_flag( j, JOB_FOREGROUND )))
{
continue;
}
for( p=j->first_process; p; p=p->next )
{
int s;
if( !p->completed )
continue;
if( !p->pid )
continue;
s = p->status;
proc_fire_event( L"PROCESS_EXIT", EVENT_EXIT, p->pid, ( WIFSIGNALED(s)?-1:WEXITSTATUS( s )) );
if( WIFSIGNALED(s) )
{
/*
Ignore signal SIGPIPE.We issue it ourselves to the pipe
writer when the pipe reader dies.
*/
if( WTERMSIG(s) != SIGPIPE )
{
int proc_is_job = ((p==j->first_process) && (p->next == 0));
if( proc_is_job )
job_set_flag( j, JOB_NOTIFIED, 1 );
if( !job_get_flag( j, JOB_SKIP_NOTIFICATION ) )
{
if( proc_is_job )
fwprintf( stdout,
_( L"%ls: Job %d, \'%ls\' terminated by signal %ls (%ls)" ),
program_name,
j->job_id,
j->command_wcstr(),
sig2wcs(WTERMSIG(p->status)),
signal_get_desc( WTERMSIG(p->status) ) );
else
fwprintf( stdout,
_( L"%ls: Process %d, \'%ls\' from job %d, \'%ls\' terminated by signal %ls (%ls)" ),
program_name,
p->pid,
p->argv0(),
j->job_id,
j->command_wcstr(),
sig2wcs(WTERMSIG(p->status)),
signal_get_desc( WTERMSIG(p->status) ) );
tputs(clr_eol,1,&writeb);
fwprintf (stdout, L"\n" );
found=1;
}
/*
Clear status so it is not reported more than once
*/
p->status = 0;
}
}
}
/*
If all processes have completed, tell the user the job has
completed and delete it from the active job list.
*/
if( job_is_completed( j ) )
{
if( !job_get_flag( j, JOB_FOREGROUND) && !job_get_flag( j, JOB_NOTIFIED ) && !job_get_flag( j, JOB_SKIP_NOTIFICATION ) )
{
//.........这里部分代码省略.........
示例3: WIfSignaled
extern "C" int32_t WIfSignaled(int32_t status)
{
return WIFSIGNALED(status);
}
示例4: Unix_ShellCommandReturnsZero
int Unix_ShellCommandReturnsZero(char *comm, int useshell)
{
int status;
pid_t pid;
if (!useshell)
{
/* Build argument array */
}
if ((pid = fork()) < 0)
{
FatalError("Failed to fork new process");
}
else if (pid == 0) /* child */
{
ALARM_PID = -1;
if (useshell)
{
if (execl(SHELL_PATH, "sh", "-c", comm, NULL) == -1)
{
CfOut(cf_error, "execl", "Command %s failed", comm);
exit(1);
}
}
else
{
char **argv = ArgSplitCommand(comm);
if (execv(argv[0], argv) == -1)
{
CfOut(cf_error, "execv", "Command %s failed", argv[0]);
exit(1);
}
}
}
else /* parent */
{
# ifndef HAVE_WAITPID
pid_t wait_result;
# endif
ALARM_PID = pid;
# ifdef HAVE_WAITPID
while (waitpid(pid, &status, 0) < 0)
{
if (errno != EINTR)
{
return -1;
}
}
return (WEXITSTATUS(status) == 0);
# else
while ((wait_result = wait(&status)) != pid)
{
if (wait_result <= 0)
{
CfOut(cf_inform, "wait", " !! Wait for child failed\n");
return false;
}
}
if (WIFSIGNALED(status))
{
return false;
}
if (!WIFEXITED(status))
{
return false;
}
return (WEXITSTATUS(status) == 0);
# endif
}
return false;
}
示例5: job_continue
//.........这里部分代码省略.........
// debug( 1, L"select_try()" );
switch( select_try(j) )
{
case 1:
{
read_try( j );
break;
}
case -1:
{
/*
If there is no funky IO magic, we can use
waitpid instead of handling child deaths
through signals. This gives a rather large
speed boost (A factor 3 startup time
improvement on my 300 MHz machine) on
short-lived jobs.
*/
int status;
pid_t pid = waitpid(-1, &status, WUNTRACED );
if( pid > 0 )
{
handle_child_status( pid, status );
}
else
{
/*
This probably means we got a
signal. A signal might mean that the
terminal emulator sent us a hup
signal to tell is to close. If so,
we should exit.
*/
if( reader_exit_forced() )
{
quit = 1;
}
}
break;
}
}
}
}
}
}
if( job_get_flag( j, JOB_FOREGROUND ) )
{
if( job_is_completed( j ))
{
// It's possible that the job will produce output and exit before we've even read from it.
// We'll eventually read the output, but it may be after we've executed subsequent calls
// This is why my prompt colors kept getting screwed up - the builtin echo calls
// were sometimes having their output combined with the set_color calls in the wrong order!
read_try(j);
process_t *p = j->first_process;
while( p->next )
p = p->next;
if( WIFEXITED( p->status ) || WIFSIGNALED(p->status))
{
/*
Mark process status only if we are in the foreground
and the last process in a pipe, and it is not a short circuted builtin
*/
if( p->pid )
{
int status = proc_format_status(p->status);
//wprintf(L"setting status %d for %ls\n", job_get_flag( j, JOB_NEGATE )?!status:status, j->command);
proc_set_last_status( job_get_flag( j, JOB_NEGATE )?!status:status);
}
}
}
/*
Put the shell back in the foreground.
*/
if( job_get_flag( j, JOB_TERMINAL ) && job_get_flag( j, JOB_FOREGROUND ) )
{
int ok;
signal_block();
ok = terminal_return_from_job( j );
signal_unblock();
if( !ok )
return;
}
}
}
示例6: wait_subprocess
//.........这里部分代码省略.........
switch (info.si_code)
{
case CLD_KILLED:
case CLD_DUMPED:
if (termsigp != NULL)
*termsigp = info.si_status; /* TODO: or info.si_signo? */
# ifdef SIGPIPE
if (info.si_status == SIGPIPE && ignore_sigpipe)
return 0;
# endif
if (exit_on_error || (!null_stderr && termsigp == NULL))
error (exit_on_error ? EXIT_FAILURE : 0, 0,
_("%s subprocess got fatal signal %d"),
progname, info.si_status);
return 127;
case CLD_EXITED:
if (info.si_status == 127)
{
if (exit_on_error || !null_stderr)
error (exit_on_error ? EXIT_FAILURE : 0, 0,
_("%s subprocess failed"), progname);
return 127;
}
return info.si_status;
default:
abort ();
}
#else
/* waitpid() is just as portable as wait() nowadays. */
int status;
if (termsigp != NULL)
*termsigp = 0;
status = 0;
for (;;)
{
int result = waitpid (child, &status, 0);
if (result != child)
{
# ifdef EINTR
if (errno == EINTR)
continue;
# endif
# if 0 /* defined ECHILD */
if (errno == ECHILD)
{
/* Child process nonexistent?! Assume it terminated
successfully. */
status = 0;
break;
}
# endif
if (exit_on_error || !null_stderr)
error (exit_on_error ? EXIT_FAILURE : 0, errno,
_("%s subprocess"), progname);
return 127;
}
/* One of WIFSIGNALED (status), WIFEXITED (status), WIFSTOPPED (status)
must always be true, since we did not specify WCONTINUED in the
waitpid() call. Loop until the program terminates. */
if (!WIFSTOPPED (status))
break;
}
/* The child process has exited or was signalled. */
if (slave_process)
/* Unregister the child from the list of slave subprocesses, so that
later, when we exit, we don't kill a totally unrelated process which
may have acquired the same pid. */
unregister_slave_subprocess (child);
if (WIFSIGNALED (status))
{
if (termsigp != NULL)
*termsigp = WTERMSIG (status);
# ifdef SIGPIPE
if (WTERMSIG (status) == SIGPIPE && ignore_sigpipe)
return 0;
# endif
if (exit_on_error || (!null_stderr && termsigp == NULL))
error (exit_on_error ? EXIT_FAILURE : 0, 0,
_("%s subprocess got fatal signal %d"),
progname, (int) WTERMSIG (status));
return 127;
}
if (!WIFEXITED (status))
abort ();
if (WEXITSTATUS (status) == 127)
{
if (exit_on_error || !null_stderr)
error (exit_on_error ? EXIT_FAILURE : 0, 0,
_("%s subprocess failed"), progname);
return 127;
}
return WEXITSTATUS (status);
#endif
}
示例7: as_mysql_step_complete
extern int as_mysql_step_complete(mysql_conn_t *mysql_conn,
struct step_record *step_ptr)
{
time_t now;
int elapsed;
int comp_status;
int cpus = 0;
struct jobacctinfo *jobacct = (struct jobacctinfo *)step_ptr->jobacct;
struct jobacctinfo dummy_jobacct;
double ave_vsize = 0, ave_rss = 0, ave_pages = 0;
double ave_cpu = 0, ave_cpu2 = 0;
char *query = NULL;
int rc =SLURM_SUCCESS;
uint32_t exit_code = 0;
time_t start_time, submit_time;
if (!step_ptr->job_ptr->db_index
&& ((!step_ptr->job_ptr->details
|| !step_ptr->job_ptr->details->submit_time)
&& !step_ptr->job_ptr->resize_time)) {
error("as_mysql_step_complete: "
"Not inputing this job, it has no submit time.");
return SLURM_ERROR;
}
if (step_ptr->job_ptr->resize_time) {
submit_time = start_time = step_ptr->job_ptr->resize_time;
if (step_ptr->start_time > submit_time)
start_time = step_ptr->start_time;
} else {
start_time = step_ptr->start_time;
submit_time = step_ptr->job_ptr->details->submit_time;
}
if (jobacct == NULL) {
/* JobAcctGather=slurmdb_gather/none, no data to process */
memset(&dummy_jobacct, 0, sizeof(dummy_jobacct));
jobacct = &dummy_jobacct;
}
if (check_connection(mysql_conn) != SLURM_SUCCESS)
return ESLURM_DB_CONNECTION;
if (slurmdbd_conf) {
now = step_ptr->job_ptr->end_time;
cpus = step_ptr->cpu_count;
} else if (step_ptr->step_id == SLURM_BATCH_SCRIPT) {
now = time(NULL);
cpus = 1;
} else {
now = time(NULL);
#ifdef HAVE_BG_L_P
/* Only L and P use this code */
cpus = step_ptr->job_ptr->details->min_cpus;
#else
if (!step_ptr->step_layout || !step_ptr->step_layout->task_cnt)
cpus = step_ptr->job_ptr->total_cpus;
else
cpus = step_ptr->cpu_count;
#endif
}
if ((elapsed = (now - start_time)) < 0)
elapsed = 0; /* For *very* short jobs, if clock is wrong */
exit_code = step_ptr->exit_code;
if (WIFSIGNALED(exit_code)) {
comp_status = JOB_CANCELLED;
} else if (exit_code)
comp_status = JOB_FAILED;
else {
step_ptr->requid = -1;
comp_status = JOB_COMPLETE;
}
/* figure out the ave of the totals sent */
if (cpus > 0) {
ave_vsize = (double)jobacct->tot_vsize;
ave_vsize /= (double)cpus;
ave_rss = (double)jobacct->tot_rss;
ave_rss /= (double)cpus;
ave_pages = (double)jobacct->tot_pages;
ave_pages /= (double)cpus;
ave_cpu = (double)jobacct->tot_cpu;
ave_cpu /= (double)cpus;
}
if (jobacct->min_cpu != NO_VAL) {
ave_cpu2 = (double)jobacct->min_cpu;
}
if (!step_ptr->job_ptr->db_index) {
if (!(step_ptr->job_ptr->db_index =
_get_db_index(mysql_conn,
submit_time,
step_ptr->job_ptr->job_id,
step_ptr->job_ptr->assoc_id))) {
/* If we get an error with this just fall
* through to avoid an infinite loop
*/
//.........这里部分代码省略.........
示例8: main
int main(void)
{
#ifdef _POSIX_MEMORY_PROTECTION
char tmpfname[256];
void *pa;
size_t size = 1024;
int fd;
pid_t child;
int status;
int sig_num;
snprintf(tmpfname, sizeof(tmpfname), "/tmp/pts_mmap_6_1_%d", getpid());
unlink(tmpfname);
fd = open(tmpfname, O_CREAT | O_RDWR | O_EXCL, S_IRUSR | S_IWUSR);
if (fd == -1) {
printf("Error at open(): %s\n", strerror(errno));
return PTS_UNRESOLVED;
}
unlink(tmpfname);
child = fork();
switch (child) {
case 0:
if (ftruncate(fd, size) == -1) {
printf("Error at ftruncate(): %s\n",
strerror(errno));
return PTS_UNRESOLVED;
}
pa = mmap(NULL, size, PROT_READ, MAP_SHARED, fd, 0);
if (pa == MAP_FAILED) {
printf("Error at mmap: %s\n",
strerror(errno));
return PTS_FAIL;
}
*(char *)pa = 'b';
return 0;
break;
case -1:
printf("Error at fork(): %s\n", strerror(errno));
return PTS_UNRESOLVED;
break;
default:
break;
}
waitpid(child, &status, WUNTRACED);
close(fd);
if (WIFSIGNALED(status)) {
sig_num = WTERMSIG(status);
printf("Child process terminated by signal %d\n", sig_num);
if (sig_num == SIGSEGV) {
printf("Got SIGSEGV when writing to the mapped memory, "
"without setting PROT_WRITE\n"
"Test PASSED\n");
return PTS_PASS;
}
}
if (WIFEXITED(status)) {
if (WEXITSTATUS(status) == 0) {
printf("Did not got SIGSEGV when writing to the mapped memory,"
" without setting PROT_WRITE\n"
"Test FAILED\n");
return PTS_FAIL;
}
}
printf("Test Unresolved\n");
return PTS_UNRESOLVED;
#else
printf("Test Unsupported, _POSIX_MEMORY_PROTECTION not defined\n");
return PTS_UNSUPPORTED;
#endif
}
示例9: summarize
static void summarize (FILE *fp, const char *fmt, char **command, resource_t *resp)
{
unsigned long r; /* Elapsed real milliseconds. */
unsigned long v; /* Elapsed virtual (CPU) milliseconds. */
if (WIFSTOPPED (resp->waitstatus))
fprintf (fp, "Command stopped by signal %d\n", WSTOPSIG (resp->waitstatus));
else if (WIFSIGNALED (resp->waitstatus))
fprintf (fp, "Command terminated by signal %d\n", WTERMSIG (resp->waitstatus));
else if (WIFEXITED (resp->waitstatus) && WEXITSTATUS (resp->waitstatus))
fprintf (fp, "Command exited with non-zero status %d\n", WEXITSTATUS (resp->waitstatus));
/* Convert all times to milliseconds. Occasionally, one of these values
comes out as zero. Dividing by zero causes problems, so we first
check the time value. If it is zero, then we take `evasive action'
instead of calculating a value. */
r = resp->elapsed.tv_sec * 1000 + resp->elapsed.tv_usec / 1000;
v = resp->ru.ru_utime.tv_sec * 1000 + resp->ru.ru_utime.TV_MSEC +
resp->ru.ru_stime.tv_sec * 1000 + resp->ru.ru_stime.TV_MSEC;
while (*fmt)
{
switch (*fmt)
{
case '%':
switch (*++fmt)
{
case '%': /* Literal '%'. */
putc ('%', fp);
break;
case 'C': /* The command that got timed. */
fprintargv (fp, command, " ");
break;
case 'D': /* Average unshared data size. */
fprintf (fp, "%lu",
MSEC_TO_TICKS (v) == 0 ? 0 :
ptok ((UL) resp->ru.ru_idrss) / MSEC_TO_TICKS (v) +
ptok ((UL) resp->ru.ru_isrss) / MSEC_TO_TICKS (v));
break;
case 'E': /* Elapsed real (wall clock) time. */
if (resp->elapsed.tv_sec >= 3600) /* One hour -> h:m:s. */
fprintf (fp, "%ldh %ldm %02lds",
resp->elapsed.tv_sec / 3600,
(resp->elapsed.tv_sec % 3600) / 60,
resp->elapsed.tv_sec % 60);
else
fprintf (fp, "%ldm %ld.%02lds", /* -> m:s. */
resp->elapsed.tv_sec / 60,
resp->elapsed.tv_sec % 60,
resp->elapsed.tv_usec / 10000);
break;
case 'F': /* Major page faults. */
fprintf (fp, "%ld", resp->ru.ru_majflt);
break;
case 'I': /* Inputs. */
fprintf (fp, "%ld", resp->ru.ru_inblock);
break;
case 'K': /* Average mem usage == data+stack+text. */
fprintf (fp, "%lu",
MSEC_TO_TICKS (v) == 0 ? 0 :
ptok ((UL) resp->ru.ru_idrss) / MSEC_TO_TICKS (v) +
ptok ((UL) resp->ru.ru_isrss) / MSEC_TO_TICKS (v) +
ptok ((UL) resp->ru.ru_ixrss) / MSEC_TO_TICKS (v));
break;
case 'M': /* Maximum resident set size. */
fprintf (fp, "%lu", ptok ((UL) resp->ru.ru_maxrss));
break;
case 'O': /* Outputs. */
fprintf (fp, "%ld", resp->ru.ru_oublock);
break;
case 'P': /* Percent of CPU this job got. */
/* % cpu is (total cpu time)/(elapsed time). */
if (r > 0)
fprintf (fp, "%lu%%", (v * 100 / r));
else
fprintf (fp, "?%%");
break;
case 'R': /* Minor page faults (reclaims). */
fprintf (fp, "%ld", resp->ru.ru_minflt);
break;
case 'S': /* System time. */
fprintf (fp, "%ld.%02ld",
resp->ru.ru_stime.tv_sec,
resp->ru.ru_stime.TV_MSEC / 10);
break;
case 'T': /* System time. */
if (resp->ru.ru_stime.tv_sec >= 3600) /* One hour -> h:m:s. */
fprintf (fp, "%ldh %ldm %02lds",
resp->ru.ru_stime.tv_sec / 3600,
(resp->ru.ru_stime.tv_sec % 3600) / 60,
resp->ru.ru_stime.tv_sec % 60);
else
fprintf (fp, "%ldm %ld.%02lds", /* -> m:s. */
resp->ru.ru_stime.tv_sec / 60,
resp->ru.ru_stime.tv_sec % 60,
resp->ru.ru_stime.tv_usec / 10000);
break;
case 'U': /* User time. */
//.........这里部分代码省略.........
示例10: mu_progmailer_send
//.........这里部分代码省略.........
mu_message_get_header (msg, &hdr);
status = mu_header_get_streamref (hdr, &stream);
if (status)
{
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_ERROR,
("cannot get header stream: %s", mu_strerror (status)));
return status;
}
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_TRACE, ("Sending headers..."));
mu_stream_seek (stream, 0, MU_SEEK_SET, NULL);
while ((status = mu_stream_readline (stream, buffer, sizeof (buffer),
&len)) == 0
&& len != 0)
{
if (mu_c_strncasecmp (buffer, MU_HEADER_FCC, sizeof (MU_HEADER_FCC) - 1))
{
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_PROT, ("Header: %s", buffer));
if (write (pm->fd, buffer, len) == -1)
{
status = errno;
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_ERROR,
("write failed: %s", strerror (status)));
break;
}
}
found_nl = (len == 1 && buffer[0] == '\n');
}
if (!found_nl)
{
if (write (pm->fd, "\n", 1) == -1)
{
status = errno;
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_ERROR,
("write failed: %s", strerror (status)));
}
}
mu_stream_destroy (&stream);
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_TRACE, ("Sending body..."));
mu_message_get_body (msg, &body);
status = mu_body_get_streamref (body, &stream);
if (status)
{
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_ERROR,
("cannot get body stream: %s\n", mu_strerror (status)));
return status;
}
mu_stream_seek (stream, 0, MU_SEEK_SET, NULL);
while ((status = mu_stream_read (stream, buffer, sizeof (buffer),
&len)) == 0
&& len != 0)
{
if (write (pm->fd, buffer, len) == -1)
{
status = errno;
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_ERROR,
("write failed: %s\n", strerror (status)));
break;
}
}
mu_body_get_streamref (body, &stream);
close (pm->fd);
rc = waitpid (pm->pid, &exit_status, 0);
if (status == 0)
{
if (rc < 0)
{
if (errno == ECHILD)
status = 0;
else
{
status = errno;
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_ERROR,
("waitpid(%lu) failed: %s\n",
(unsigned long) pm->pid, strerror (status)));
}
}
else if (WIFEXITED (exit_status))
{
exit_status = WEXITSTATUS (exit_status);
mu_debug (MU_DEBCAT_MAILER, MU_DEBUG_TRACE,
("%s exited with: %d\n",
pm->command, exit_status));
status = (exit_status == 0) ? 0 : MU_ERR_PROCESS_EXITED;
}
else if (WIFSIGNALED (exit_status))
status = MU_ERR_PROCESS_SIGNALED;
else
status = MU_ERR_PROCESS_UNKNOWN_FAILURE;
}
pm->pid = -1;
return status;
}
示例11: RTR3DECL
RTR3DECL(int) RTProcWaitNoResume(RTPROCESS Process, unsigned fFlags, PRTPROCSTATUS pProcStatus)
{
/*
* Validate input.
*/
if (Process <= 0)
{
AssertMsgFailed(("Invalid Process=%d\n", Process));
return VERR_INVALID_PARAMETER;
}
if (fFlags & ~(RTPROCWAIT_FLAGS_NOBLOCK | RTPROCWAIT_FLAGS_BLOCK))
{
AssertMsgFailed(("Invalid flags %#x\n", fFlags));
return VERR_INVALID_PARAMETER;
}
/*
* Perform the wait.
*/
int iStatus = 0;
int rc = waitpid(Process, &iStatus, fFlags & RTPROCWAIT_FLAGS_NOBLOCK ? WNOHANG : 0);
if (rc > 0)
{
/*
* Fill in the status structure.
*/
if (pProcStatus)
{
if (WIFEXITED(iStatus))
{
pProcStatus->enmReason = RTPROCEXITREASON_NORMAL;
pProcStatus->iStatus = WEXITSTATUS(iStatus);
}
else if (WIFSIGNALED(iStatus))
{
pProcStatus->enmReason = RTPROCEXITREASON_SIGNAL;
pProcStatus->iStatus = WTERMSIG(iStatus);
}
else
{
Assert(!WIFSTOPPED(iStatus));
pProcStatus->enmReason = RTPROCEXITREASON_ABEND;
pProcStatus->iStatus = iStatus;
}
}
return VINF_SUCCESS;
}
/*
* Child running?
*/
if (!rc)
{
Assert(fFlags & RTPROCWAIT_FLAGS_NOBLOCK);
return VERR_PROCESS_RUNNING;
}
/*
* Figure out which error to return.
*/
int iErr = errno;
if (iErr == ECHILD)
return VERR_PROCESS_NOT_FOUND;
return RTErrConvertFromErrno(iErr);
}
示例12: do_test
//.........这里部分代码省略.........
exit(-1);
}
switch (fork()) { /* Parent and child share mapping */
case -1:
fprintf(stderr,"fork failed - errno = %d\n",errno);
exit(-1);
case 0: /* Child: increment shared integer and exit */
printf("Grand child started, ");
printf("value = %d\n", *addr);
(*addr)++;
if (*addr != 3) {
fprintf(stderr,"value is %d, must be 3\n",*addr);
exit(-1);
}
if (munmap(addr, sizeof(int)) == -1){
fprintf(stderr,"munmap failed - errno = %d\n",errno);
exit(-1);
}
exit(EXIT_SUCCESS);
default: /* Parent: wait for child to terminate */
if (wait(&status) == -1){
fprintf(stderr,"wait failed - errno = %d\n",errno);
exit(-1);
}
if (!WIFEXITED(status) || WEXITSTATUS(status)) {
fprintf(stderr,"child crashed or returned non-zero (status %x)\n", status);
exit(-1);
}
printf("In child, value = %d\n", *addr);
if (*addr != 3) {
fprintf(stderr,"value is %d, must be 3\n",*addr);
exit(-1);
}
if (munmap(addr, sizeof(int)) == -1){
fprintf(stderr,"munmap failed - errno = %d\n",errno);
exit(-1);
}
exit(EXIT_SUCCESS);
}
default: /* Parent: wait for child to terminate */
if (wait(&status) == -1){
fprintf(stderr,"wait failed - errno = %d\n",errno);
exit(-1);
}
if (!WIFEXITED(status) || WEXITSTATUS(status)) {
fprintf(stderr,"child crashed or returned non-zero (status %x)\n", status);
exit(-1);
}
printf("In parent, value = %d\n", *addr);
if (*addr != 3) {
fprintf(stderr,"value is %d, must be 3\n",*addr);
exit(-1);
}
}
/*
* Part 2. Test unsuccessful parent-chlid access.
*/
switch (fork()) { /* Parent and child share mapping */
case -1:
fprintf(stderr,"fork failed - errno = %d\n",errno);
exit(-1);
case 0: /* Child: increment shared integer and exit */
printf("Child started, ");
printf("value = %d\n", *addr);
(*addr)++;
if (*addr != 4) {
fprintf(stderr,"value is %d, must be 4\n",*addr);
exit(-1);
}
if (munmap(addr, sizeof(int)) == -1){
fprintf(stderr,"munmap failed - errno = %d\n",errno);
exit(-1);
}
/* This should crash the child with SIGSEGV */
(*addr)++;
exit(EXIT_SUCCESS);
default: /* Parent: wait for child to terminate */
if (wait(&status) == -1){
fprintf(stderr,"wait failed - errno = %d\n",errno);
exit(-1);
}
if (WIFEXITED(status) || !WIFSIGNALED(status) || WTERMSIG(status) != SIGSEGV) {
fprintf(stderr,"child ended sucessfully or crashed not with SIGSEGV (status %x)\n", status);
exit(-1);
}
printf("In parent, value = %d\n", *addr);
if (*addr != 4) {
fprintf(stderr,"value is %d, must be 4\n",*addr);
exit(-1);
}
if (munmap(addr, sizeof(int)) == -1){
fprintf(stderr,"munmap failed - errno = %d\n",errno);
exit(-1);
}
exit(EXIT_SUCCESS);
}
}
示例13: child_fn
/*
* child_fn() - Inside container
*/
int child_fn(void *arg)
{
int children[10], exit_val, i, status;
pid_t pid, ppid;
/* Set process id and parent pid */
pid = getpid();
ppid = getppid();
if (pid != CHILD_PID || ppid != PARENT_PID) {
printf("cinit: pidns was not created\n");
exit(1);
}
exit_val = 0;
/* Spawn many children */
for (i = 0; i < (sizeof(children) / sizeof(children[0])); i++) {
switch ((children[i] = fork())) {
case -1:
perror("fork failed");
exit_val = 1;
break;
case 0:
pause();
/* XXX (garrcoop): why exit with an exit code of 2? */
exit(2);
break;
default:
/* fork succeeded. */
break;
}
}
/* wait for last child to get scheduled */
sleep(1);
if (kill(-1, SIGUSR1) == -1) {
perror("cinit: kill(-1, SIGUSR1) failed");
exit_val = 1;
}
for (i = 0; i < (sizeof(children) / sizeof(children[0])); i++) {
if (waitpid(children[i], &status, 0) == -1) {
perror("cinit: waitpid failed");
kill(children[i], SIGTERM);
waitpid(children[i], &status, 0);
exit_val = 1;
}
if (!(WIFSIGNALED(status) || WTERMSIG(status) == SIGUSR1)) {
/*
* XXX (garrcoop): this status reporting is overly
* noisy. Someone obviously needs to read the
* constraints documented in wait(2) a bit more
* closely -- in particular the relationship between
* WIFEXITED and WEXITSTATUS, and WIFSIGNALED and
* WTERMSIG.
*/
printf("cinit: found a child alive still "
"%d exit: %d, %d, signal %d, %d", i,
WIFEXITED(status), WEXITSTATUS(status),
WIFSIGNALED(status), WTERMSIG(status));
exit_val = 1;
}
}
if (exit_val == 0)
printf("cinit: all children have terminated.\n");
exit(exit_val);
}
示例14: main
//.........这里部分代码省略.........
error = execvp(argv[0], argv);
if (error == -1) {
if (errno == ENOENT)
err(127, "exec(%s)", argv[0]);
else
err(126, "exec(%s)", argv[0]);
}
}
if (sigprocmask(SIG_BLOCK, &signals.sa_mask, NULL) == -1)
err(EX_OSERR, "sigprocmask()");
/* parent continues here */
set_interval(first_kill);
for (;;) {
sigemptyset(&signals.sa_mask);
sigsuspend(&signals.sa_mask);
if (sig_chld) {
sig_chld = 0;
while ((cpid = waitpid(-1, &status, WNOHANG)) != 0) {
if (cpid < 0) {
if (errno == EINTR)
continue;
else
break;
} else if (cpid == pid) {
pstat = status;
child_done = true;
}
}
if (child_done) {
if (foreground) {
break;
} else {
procctl(P_PID, getpid(),
PROC_REAP_STATUS, &info);
if (info.rs_children == 0)
break;
}
}
} else if (sig_alrm) {
sig_alrm = 0;
timedout = true;
if (!foreground) {
killemall.rk_sig = killsig;
killemall.rk_flags = 0;
procctl(P_PID, getpid(), PROC_REAP_KILL,
&killemall);
} else
kill(pid, killsig);
if (do_second_kill) {
set_interval(second_kill);
second_kill = 0;
sig_ign = killsig;
killsig = SIGKILL;
} else
break;
} else if (sig_term) {
if (!foreground) {
killemall.rk_sig = sig_term;
killemall.rk_flags = 0;
procctl(P_PID, getpid(), PROC_REAP_KILL,
&killemall);
} else
kill(pid, sig_term);
if (do_second_kill) {
set_interval(second_kill);
second_kill = 0;
sig_ign = killsig;
killsig = SIGKILL;
} else
break;
}
}
while (!child_done && wait(&pstat) == -1) {
if (errno != EINTR)
err(EX_OSERR, "waitpid()");
}
if (!foreground)
procctl(P_PID, getpid(), PROC_REAP_RELEASE, NULL);
if (WEXITSTATUS(pstat))
pstat = WEXITSTATUS(pstat);
else if(WIFSIGNALED(pstat))
pstat = 128 + WTERMSIG(pstat);
if (timedout && !preserve)
pstat = EXIT_TIMEOUT;
return (pstat);
}
示例15: handle_sigs
/**
* Signal handler for the server.
*/
void handle_sigs(void)
{
pid_t chld;
int chld_status;
int i;
int do_exit;
switch(sig_flag){
case 0: break; /* do nothing*/
case SIGPIPE:
/* SIGPIPE might be rarely received on use of
exec module; simply ignore it
*/
LM_WARN("SIGPIPE received and ignored\n");
break;
case SIGINT:
case SIGTERM:
/* we end the program in all these cases */
if (sig_flag==SIGINT)
LM_DBG("INT received, program terminates\n");
else
LM_DBG("SIGTERM received, program terminates\n");
/* first of all, kill the children also */
kill_all_children(SIGTERM);
if (signal(SIGALRM, sig_alarm_kill) == SIG_ERR ) {
LM_ERR("could not install SIGALARM handler\n");
/* continue, the process will die anyway if no
* alarm is installed which is exactly what we want */
}
alarm(OPENSER_SHUTDOWN_TIME); /* 1 minute close timeout */
while(wait(0) > 0); /* Wait for all the children to terminate */
signal(SIGALRM, sig_alarm_abort);
cleanup(1); /* cleanup & show status*/
alarm(0);
signal(SIGALRM, SIG_IGN);
dprint("Thank you for flying " NAME "\n");
exit(0);
break;
case SIGUSR1:
#ifdef PKG_MALLOC
LOG(memlog, "Memory status (pkg):\n");
pkg_status();
#endif
#ifdef SHM_MEM
LOG(memlog, "Memory status (shm):\n");
shm_status();
#endif
break;
case SIGCHLD:
do_exit = 0;
while ((chld=waitpid( -1, &chld_status, WNOHANG ))>0) {
/* is it a process we know about? */
for( i=0 ; i<counted_processes ; i++ )
if (pt[i].pid==chld) break;
if (i==counted_processes) {
LM_DBG("unkown child process %d ended. Ignoring\n",chld);
continue;
}
do_exit = 1;
/* process the signal */
if (WIFEXITED(chld_status))
LM_INFO("child process %d exited normally,"
" status=%d\n", chld,
WEXITSTATUS(chld_status));
else if (WIFSIGNALED(chld_status)) {
LM_INFO("child process %d exited by a signal"
" %d\n", chld, WTERMSIG(chld_status));
#ifdef WCOREDUMP
LM_INFO("core was %sgenerated\n",
WCOREDUMP(chld_status) ? "" : "not " );
#endif
}else if (WIFSTOPPED(chld_status))
LM_INFO("child process %d stopped by a"
" signal %d\n", chld,
WSTOPSIG(chld_status));
}
if (!do_exit)
break;
LM_INFO("terminating due to SIGCHLD\n");
/* exit */
kill_all_children(SIGTERM);
if (signal(SIGALRM, sig_alarm_kill) == SIG_ERR ) {
LM_ERR("could not install SIGALARM handler\n");
/* continue, the process will die anyway if no
* alarm is installed which is exactly what we want */
}
alarm(OPENSER_SHUTDOWN_TIME); /* 1 minute close timeout */
while(wait(0) > 0); /* wait for all the children to terminate*/
signal(SIGALRM, sig_alarm_abort);
cleanup(1); /* cleanup & show status*/
alarm(0);
signal(SIGALRM, SIG_IGN);
//.........这里部分代码省略.........