xref: /freebsd/usr.bin/procstat/procstat_ptlwpinfo.c (revision 5e3934b15a2741b2de6b217e77dc9d798d740804)
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