From f4b1b6183eb200d945f8a81e2eb920ddd98c3e32 Mon Sep 17 00:00:00 2001 From: Mark Johnston Date: Mon, 5 Aug 2024 18:28:42 -0400 Subject: [PATCH] procstat: Include a maxprot column in "vm -v" output This field is unlikely to be useful most of the time, but it can be handy. Hide it under verbose mode together with the RESERV column. --- usr.bin/procstat/procstat.1 | 2 ++ usr.bin/procstat/procstat_vm.c | 38 ++++++++++++++++++++++++++++++++-- 2 files changed, 38 insertions(+), 2 deletions(-) diff --git a/usr.bin/procstat/procstat.1 b/usr.bin/procstat/procstat.1 index fc938dde6084..6886dcdb0595 100644 --- a/usr.bin/procstat/procstat.1 +++ b/usr.bin/procstat/procstat.1 @@ -746,6 +746,8 @@ ending address of mapping starting address of the reservation this entry belongs to .It PRT protection flags +.It MAXPRT +maximum protection flags .It RES resident pages .It PRES diff --git a/usr.bin/procstat/procstat_vm.c b/usr.bin/procstat/procstat_vm.c index 71aee3f9d74b..e0e31291e605 100644 --- a/usr.bin/procstat/procstat_vm.c +++ b/usr.bin/procstat/procstat_vm.c @@ -60,9 +60,9 @@ procstat_vm(struct procstat *procstat, struct kinfo_proc *kipp) "PID", ptrwidth, "START", ptrwidth, "END", "PRT", "RES", "PRES", "REF", "SHD", "FLAG", "TP", "PATH"); else - xo_emit("{T:/%5s %*s %*s %*s %-5s %4s %4s %3s %3s %-6s %-2s %-s}\n", + xo_emit("{T:/%5s %*s %*s %*s %-5s %-5s %4s %4s %3s %3s %-6s %-2s %-s}\n", "PID", ptrwidth, "START", ptrwidth, "END", - ptrwidth, "RESERV", "PRT", + ptrwidth, "RESERV", "PRT", "MAXPRT", "RES", "PRES", "REF", "SHD", "FLAG", "TP", "PATH"); } @@ -109,6 +109,40 @@ procstat_vm(struct procstat *procstat, struct kinfo_proc *kipp) xo_emit("{en:write_cap/%s}", kve->kve_protection & KVME_PROT_WRITE_CAP ? "true" : "false"); xo_close_container("kve_protection"); + if ((procstat_opts & PS_OPT_VERBOSE) != 0) { + xo_emit("{d:max_read/%s}", + kve->kve_max_protection & KVME_PROT_READ ? + "r" : "-"); + xo_emit("{d:max_write/%s}", + kve->kve_max_protection & KVME_PROT_WRITE ? + "w" : "-"); + xo_emit("{d:max_exec/%s}", + kve->kve_max_protection & KVME_PROT_EXEC ? + "x" : "-"); + xo_emit("{d:max_read_cap/%s}", + kve->kve_max_protection & KVME_PROT_READ_CAP ? + "R" : "-"); + xo_emit("{d:max_write_cap/%-2s} ", + kve->kve_max_protection & KVME_PROT_WRITE_CAP ? + "W" : "-"); + xo_open_container("kve_max_protection"); + xo_emit("{en:max_read/%s}", + kve->kve_max_protection & KVME_PROT_READ ? + "true" : "false"); + xo_emit("{en:max_write/%s}", + kve->kve_max_protection & KVME_PROT_WRITE ? + "true" : "false"); + xo_emit("{en:max_exec/%s}", + kve->kve_max_protection & KVME_PROT_EXEC ? + "true" : "false"); + xo_emit("{en:max_read_cap/%s}", + kve->kve_max_protection & KVME_PROT_READ_CAP ? + "true" : "false"); + xo_emit("{en:max_write_cap/%s}", + kve->kve_max_protection & KVME_PROT_WRITE_CAP ? + "true" : "false"); + xo_close_container("kve_max_protection"); + } xo_emit("{:kve_resident/%4d/%d} ", kve->kve_resident); xo_emit("{:kve_private_resident/%4d/%d} ", kve->kve_private_resident);