186be94fcSTycho Nightingale /*-
286be94fcSTycho Nightingale * Copyright (c) 2017 Dell EMC
386be94fcSTycho Nightingale * All rights reserved.
486be94fcSTycho Nightingale *
586be94fcSTycho Nightingale * Redistribution and use in source and binary forms, with or without
686be94fcSTycho Nightingale * modification, are permitted provided that the following conditions
786be94fcSTycho Nightingale * are met:
886be94fcSTycho Nightingale * 1. Redistributions of source code must retain the above copyright
986be94fcSTycho Nightingale * notice, this list of conditions and the following disclaimer.
1086be94fcSTycho Nightingale * 2. Redistributions in binary form must reproduce the above copyright
1186be94fcSTycho Nightingale * notice, this list of conditions and the following disclaimer in the
1286be94fcSTycho Nightingale * documentation and/or other materials provided with the distribution.
1386be94fcSTycho Nightingale *
1486be94fcSTycho Nightingale * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
1586be94fcSTycho Nightingale * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1686be94fcSTycho Nightingale * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1786be94fcSTycho Nightingale * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
1886be94fcSTycho Nightingale * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
1986be94fcSTycho Nightingale * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2086be94fcSTycho Nightingale * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2186be94fcSTycho Nightingale * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2286be94fcSTycho Nightingale * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2386be94fcSTycho Nightingale * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2486be94fcSTycho Nightingale * SUCH DAMAGE.
2586be94fcSTycho Nightingale */
26*b65eb2f8SKonstantin Belousov
2786be94fcSTycho Nightingale #include <sys/param.h>
2886be94fcSTycho Nightingale #include <sys/ptrace.h>
2986be94fcSTycho Nightingale #include <sys/user.h>
3086be94fcSTycho Nightingale
3186be94fcSTycho Nightingale #include <libprocstat.h>
3286be94fcSTycho Nightingale
3386be94fcSTycho Nightingale #include "procstat.h"
3486be94fcSTycho Nightingale
3586be94fcSTycho Nightingale void
procstat_ptlwpinfo(struct procstat * prstat,struct kinfo_proc * kipp __unused)362a243b95SBrooks Davis procstat_ptlwpinfo(struct procstat *prstat, struct kinfo_proc *kipp __unused)
3786be94fcSTycho Nightingale {
3886be94fcSTycho Nightingale struct ptrace_lwpinfo *pl;
3986be94fcSTycho Nightingale unsigned int count, i;
4086be94fcSTycho Nightingale
4186be94fcSTycho Nightingale pl = procstat_getptlwpinfo(prstat, &count);
4286be94fcSTycho Nightingale if (pl == NULL)
4386be94fcSTycho Nightingale return;
4486be94fcSTycho Nightingale
452a243b95SBrooks Davis if ((procstat_opts & PS_OPT_NOHEADER) == 0)
4696330772SMark Johnston xo_emit(
4796330772SMark Johnston "{T:/%6s %7s %5s %5s %5s %6s %5s} {[:/%d}{T:/%s}{]:} {T:/%s}\n",
4886be94fcSTycho Nightingale "LWPID", "EVENT", "SIGNO", "CODE", "ERRNO", "PID", "UID",
4986be94fcSTycho Nightingale 2 * sizeof(void *) + 2, "ADDR", "TDNAME");
5086be94fcSTycho Nightingale
5196330772SMark Johnston xo_open_container("threads");
5286be94fcSTycho Nightingale for (i = 0; i < count; i++) {
5396330772SMark Johnston xo_open_container("thread");
5496330772SMark Johnston xo_emit("{:lwpid/%6d} ", pl[i].pl_lwpid);
5586be94fcSTycho Nightingale switch (pl[i].pl_event) {
5686be94fcSTycho Nightingale case PL_EVENT_NONE:
5786be94fcSTycho Nightingale xo_emit("{eq:event/none}{d:event/%7s} ", "none");
5886be94fcSTycho Nightingale break;
5986be94fcSTycho Nightingale case PL_EVENT_SIGNAL:
6086be94fcSTycho Nightingale xo_emit("{eq:event/signal}{d:event/%7s} ", "signal");
6186be94fcSTycho Nightingale break;
6286be94fcSTycho Nightingale default:
6386be94fcSTycho Nightingale xo_emit("{eq:event/unknown}{d:event/%7s} ", "?");
6486be94fcSTycho Nightingale break;
6586be94fcSTycho Nightingale }
6686be94fcSTycho Nightingale if ((pl[i].pl_flags & PL_FLAG_SI) != 0) {
6786be94fcSTycho Nightingale siginfo_t *si;
6886be94fcSTycho Nightingale
6986be94fcSTycho Nightingale si = &pl[i].pl_siginfo;
7086be94fcSTycho Nightingale xo_emit("{:signal_number/%5d} ", si->si_signo);
7186be94fcSTycho Nightingale xo_emit("{:code/%5d} ", si->si_code);
7286be94fcSTycho Nightingale xo_emit("{:signal_errno/%5d} ", si->si_errno);
7386be94fcSTycho Nightingale xo_emit("{:process_id/%6d} ", si->si_pid);
7486be94fcSTycho Nightingale xo_emit("{:user_id/%5d} ", si->si_uid);
7586be94fcSTycho Nightingale xo_emit("{[:/%d}{:address/%p}{]:} ",
7686be94fcSTycho Nightingale 2 * sizeof(void *) + 2, si->si_addr);
7786be94fcSTycho Nightingale } else {
7886be94fcSTycho Nightingale xo_emit("{:signal_number/%5s} ", "-");
7986be94fcSTycho Nightingale xo_emit("{:code/%5s} ", "-");
8086be94fcSTycho Nightingale xo_emit("{:signal_errno/%5s} ", "-");
8186be94fcSTycho Nightingale xo_emit("{:process_id/%6s} ", "-");
8286be94fcSTycho Nightingale xo_emit("{:user_id/%5s} ", "-");
8386be94fcSTycho Nightingale xo_emit("{[:/%d}{:address/%s}{]:} ",
8486be94fcSTycho Nightingale 2 * sizeof(void *) + 2, "-");
8586be94fcSTycho Nightingale }
8686be94fcSTycho Nightingale xo_emit("{:tdname/%s}\n", pl[i].pl_tdname);
8796330772SMark Johnston xo_close_container("thread");
8886be94fcSTycho Nightingale }
8996330772SMark Johnston xo_close_container("threads");
9086be94fcSTycho Nightingale
9186be94fcSTycho Nightingale procstat_freeptlwpinfo(prstat, pl);
9286be94fcSTycho Nightingale }
93