svn commit: r357701 - head/usr.bin/procstat

Konstantin Belousov kib at FreeBSD.org
Sun Feb 9 12:30:51 UTC 2020


Author: kib
Date: Sun Feb  9 12:30:50 2020
New Revision: 357701
URL: https://svnweb.freebsd.org/changeset/base/357701

Log:
  Add procstat(1) sigfastblock command to show process sigfastblock word address.
  
  Tested by:	pho
  Disscussed with:	cem, emaste, jilles
  Sponsored by:	The FreeBSD Foundation
  Differential revision:	https://reviews.freebsd.org/D12773

Modified:
  head/usr.bin/procstat/procstat.c
  head/usr.bin/procstat/procstat.h
  head/usr.bin/procstat/procstat_sigs.c

Modified: head/usr.bin/procstat/procstat.c
==============================================================================
--- head/usr.bin/procstat/procstat.c	Sun Feb  9 12:29:51 2020	(r357700)
+++ head/usr.bin/procstat/procstat.c	Sun Feb  9 12:30:50 2020	(r357701)
@@ -94,6 +94,8 @@ static const struct procstat_cmd cmd_table[] = {
 	    PS_CMP_NORMAL },
 	{ "rusage", "rusage", "[-Ht]", &procstat_rusage, &cmdopt_rusage,
 	    PS_CMP_NORMAL },
+	{ "sigfastblock", "sigfastblock", NULL, &procstat_sigfastblock,
+	    &cmdopt_none, PS_CMP_NORMAL },
 	{ "signal", "signals", "[-n]", &procstat_sigs, &cmdopt_signals,
 	    PS_CMP_PLURAL | PS_CMP_SUBSTR },
 	{ "thread", "threads", NULL, &procstat_threads, &cmdopt_none,

Modified: head/usr.bin/procstat/procstat.h
==============================================================================
--- head/usr.bin/procstat/procstat.h	Sun Feb  9 12:29:51 2020	(r357700)
+++ head/usr.bin/procstat/procstat.h	Sun Feb  9 12:30:50 2020	(r357701)
@@ -67,6 +67,8 @@ void	procstat_kstack(struct procstat *prstat, struct k
 void	procstat_ptlwpinfo(struct procstat *prstat, struct kinfo_proc *kipp);
 void	procstat_rlimit(struct procstat *prstat, struct kinfo_proc *kipp);
 void	procstat_rusage(struct procstat *prstat, struct kinfo_proc *kipp);
+void	procstat_sigfastblock(struct procstat *procstat,
+	    struct kinfo_proc *kipp);
 void	procstat_sigs(struct procstat *prstat, struct kinfo_proc *kipp);
 void	procstat_threads(struct procstat *prstat, struct kinfo_proc *kipp);
 void	procstat_threads_sigs(struct procstat *prstat, struct kinfo_proc *kipp);

Modified: head/usr.bin/procstat/procstat_sigs.c
==============================================================================
--- head/usr.bin/procstat/procstat_sigs.c	Sun Feb  9 12:29:51 2020	(r357700)
+++ head/usr.bin/procstat/procstat_sigs.c	Sun Feb  9 12:30:50 2020	(r357701)
@@ -37,6 +37,8 @@
 #include <err.h>
 #include <errno.h>
 #include <signal.h>
+#include <stdbool.h>
+#include <stdint.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
@@ -163,6 +165,7 @@ procstat_threads_sigs(struct procstat *procstat, struc
 		xo_open_container(threadid);
 		xo_emit("{e:thread_id/%6d/%d}", kipp->ki_tid);
 		xo_open_container("signals");
+
 		for (j = 1; j <= _SIG_MAXSIG; j++) {
 			xo_emit("{dk:process_id/%5d/%d} ", kipp->ki_pid);
 			xo_emit("{d:thread_id/%6d/%d} ", kipp->ki_tid);
@@ -175,6 +178,66 @@ procstat_threads_sigs(struct procstat *procstat, struc
 			xo_emit("\n");
 		}
 		xo_close_container("signals");
+		xo_close_container(threadid);
+		free(threadid);
+	}
+	xo_close_container("threads");
+	procstat_freeprocs(procstat, kip);
+}
+
+void
+procstat_sigfastblock(struct procstat *procstat, struct kinfo_proc *kipp)
+{
+	struct kinfo_proc *kip;
+	char *threadid;
+	uintptr_t sigfastblk_addr;
+	int error, name[4];
+	unsigned int count, i;
+	size_t len;
+	bool has_sigfastblk_addr;
+
+	if ((procstat_opts & PS_OPT_NOHEADER) == 0)
+		xo_emit("{T:/%5s %6s %-16s %-16s}\n", "PID", "TID",
+		     "COMM", "SIGFBLK");
+
+	kip = procstat_getprocs(procstat, KERN_PROC_PID | KERN_PROC_INC_THREAD,
+	    kipp->ki_pid, &count);
+	if (kip == NULL)
+		return;
+	xo_emit("{ek:process_id/%5d/%d}", kipp->ki_pid);
+	xo_emit("{e:command/%-16s/%s}", kipp->ki_comm);
+	xo_open_container("threads");
+	kinfo_proc_sort(kip, count);
+	for (i = 0; i < count; i++) {
+		kipp = &kip[i];
+		len = sizeof(sigfastblk_addr);
+		name[0] = CTL_KERN;
+		name[1] = KERN_PROC;
+		name[2] = KERN_PROC_SIGFASTBLK;
+		name[3] = kipp->ki_tid;
+		error = sysctl(name, 4, &sigfastblk_addr, &len, NULL, 0);
+		if (error < 0) {
+			if (errno != ESRCH && errno != ENOTTY) {
+				warn("sysctl: kern.proc.fastsigblk: %d",
+				    kipp->ki_tid);
+			}
+			has_sigfastblk_addr = false;
+		} else
+			has_sigfastblk_addr = true;
+
+		asprintf(&threadid, "%d", kipp->ki_tid);
+		if (threadid == NULL)
+			xo_errc(1, ENOMEM, "Failed to allocate memory in "
+			    "procstat_sigfastblock()");
+		xo_open_container(threadid);
+		xo_emit("{dk:process_id/%5d/%d} ", kipp->ki_pid);
+		xo_emit("{d:thread_id/%6d/%d} ", kipp->ki_tid);
+		xo_emit("{d:command/%-16s/%s} ", kipp->ki_comm);
+		xo_emit("{e:sigfastblock/%#-16jx/%#jx}", has_sigfastblk_addr ?
+		    (uintmax_t)sigfastblk_addr : (uintmax_t)-1);
+		xo_emit("{d:sigfastblock/%#-16jx/%#jx}", has_sigfastblk_addr ?
+		    (uintmax_t)sigfastblk_addr : (uintmax_t)-1);
+		xo_emit("\n");
 		xo_close_container(threadid);
 		free(threadid);
 	}


More information about the svn-src-head mailing list