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