diff options
author | Alexander Kolbasov <Alexander.Kolbasov@Sun.COM> | 2009-12-22 21:52:00 -0800 |
---|---|---|
committer | Alexander Kolbasov <Alexander.Kolbasov@Sun.COM> | 2009-12-22 21:52:00 -0800 |
commit | b885580b43755ee4ea1e280b85428893d2ba9291 (patch) | |
tree | f7f7848d3eef390282bab6fc859d7a5275053ecf /usr/src/cmd | |
parent | e7437094ebbbd4d60375f3927c017ff00cbab1de (diff) | |
download | illumos-joyent-b885580b43755ee4ea1e280b85428893d2ba9291.tar.gz |
6764832 Provide user-level processor groups observability
6831680 cputrack(1) leaves its victim with unneeded cpc context
6901343 cpc context flag updates are not always atomic
6908152 Dormant thread CPC context affects cpu CPC consumers
Diffstat (limited to 'usr/src/cmd')
-rw-r--r-- | usr/src/cmd/cpc/common/cputrack.c | 54 |
1 files changed, 52 insertions, 2 deletions
diff --git a/usr/src/cmd/cpc/common/cputrack.c b/usr/src/cmd/cpc/common/cputrack.c index 22ad2673e2..41034aef6e 100644 --- a/usr/src/cmd/cpc/common/cputrack.c +++ b/usr/src/cmd/cpc/common/cputrack.c @@ -19,7 +19,7 @@ * CDDL HEADER END */ /* - * Copyright 2008 Sun Microsystems, Inc. All rights reserved. + * Copyright 2009 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ @@ -62,6 +62,12 @@ static const struct options *opts = (const struct options *)&__options; static cpc_t *cpc; +/* + * How many signals caught from terminal + * We bail out as soon as possible when interrupt is set + */ +static int interrupt = 0; + /*ARGSUSED*/ static void cputrack_errfn(const char *fn, int subcode, const char *fmt, va_list ap) @@ -79,6 +85,8 @@ cputrack_pctx_errfn(const char *fn, const char *fmt, va_list ap) } static int cputrack(int argc, char *argv[], int optind); +static void intr(int); + #if defined(__i386) static void p4_ht_error(void); #endif @@ -220,6 +228,19 @@ main(int argc, char *argv[]) exit(2); } + /* + * Catch signals from terminal, so they can be handled asynchronously + * when we're ready instead of when we're not (;-) + */ + if (sigset(SIGHUP, SIG_IGN) == SIG_DFL) + (void) sigset(SIGHUP, intr); + if (sigset(SIGINT, SIG_IGN) == SIG_DFL) + (void) sigset(SIGINT, intr); + if (sigset(SIGQUIT, SIG_IGN) == SIG_DFL) + (void) sigset(SIGQUIT, intr); + (void) sigset(SIGPIPE, intr); + (void) sigset(SIGTERM, intr); + cpc_setgrp_reset(opts->master); (void) setvbuf(opts->log, NULL, _IOLBF, 0); ret = cputrack(argc, argv, optind); @@ -310,6 +331,9 @@ pinit_lwp(pctx_t *pctx, pid_t pid, id_t lwpid, void *arg) char *errstr; int nreq; + if (interrupt) + return (0); + if (state->maxlwpid < lwpid) { state->sgrps = realloc(state->sgrps, lwpid * sizeof (state->sgrps)); @@ -373,6 +397,9 @@ pfini_lwp(pctx_t *pctx, pid_t pid, id_t lwpid, void *arg) cpc_buf_t **data1, **data2, **scratch; int nreq; + if (interrupt) + return (0); + set = cpc_setgrp_getset(sgrp); nreq = cpc_setgrp_getbufs(sgrp, &data1, &data2, &scratch); if (cpc_set_sample(cpc, set, *scratch) == 0) { @@ -424,6 +451,9 @@ plwp_create(pctx_t *pctx, pid_t pid, id_t lwpid, void *arg) cpc_buf_t **data1, **data2, **scratch; int nreq; + if (interrupt) + return (0); + nreq = cpc_setgrp_getbufs(sgrp, &data1, &data2, &scratch); print_sample(pid, lwpid, "lwp_create", @@ -442,6 +472,9 @@ plwp_exit(pctx_t *pctx, pid_t pid, id_t lwpid, void *arg) int nreq; cpc_buf_t **data1, **data2, **scratch; + if (interrupt) + return (0); + start = cpc_setgrp_getset(sgrp); do { nreq = cpc_setgrp_getbufs(sgrp, &data1, &data2, &scratch); @@ -465,6 +498,9 @@ pexec(pctx_t *pctx, pid_t pid, id_t lwpid, char *name, void *arg) cpc_buf_t **data1, **data2, **scratch; hrtime_t hrt; + if (interrupt) + return (0); + /* * Print the accumulated results from the previous program image */ @@ -505,6 +541,9 @@ pexit(pctx_t *pctx, pid_t pid, id_t lwpid, int status, void *arg) int nreq; cpc_buf_t **data1, **data2, **scratch; + if (interrupt) + return; + cpc_setgrp_reset(state->accum); start = cpc_setgrp_getset(state->accum); do { @@ -539,6 +578,9 @@ ptick(pctx_t *pctx, pid_t pid, id_t lwpid, void *arg) char *errstr; int nreqs; + if (interrupt) + return (0); + nreqs = cpc_setgrp_getbufs(sgrp, &data1, &data2, &scratch); if (opts->nsets == 1) { @@ -704,7 +746,6 @@ cputrack(int argc, char *argv[], int optind) state->accum = NULL; } } - pctx_release(pctx); return (err != 0 ? 1 : 0); } @@ -834,3 +875,12 @@ p4_ht_error(void) } #endif /* defined(__i386) */ + +/*ARGSUSED*/ +static void +intr(int sig) +{ + interrupt++; + if (cpc != NULL) + cpc_terminate(cpc); +} |