summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--utils/ps.c21
1 files changed, 14 insertions, 7 deletions
diff --git a/utils/ps.c b/utils/ps.c
index a7f09e87..f6149b21 100644
--- a/utils/ps.c
+++ b/utils/ps.c
@@ -48,13 +48,15 @@ usage(status)
\n\
-a, --all-users List other users' processes\n\
--fmt=FMT Use the output-format FMT\n\
- FMT may be `default', `user', `vmem', `long',\n\
+ FMT may be `default', `user', `vmem', `long',\n\
`hurd', `hurd-long', or a format-string\n\
-g Include session leaders\n\
-H, --no-header Don't print a descriptive header line\n\
-l Use the `long' output-format'\n\
--login[=LID] Add the processes from the login collection LID\n\
- (which defaults that of the current process)\n
+ (which defaults that of the current process)\n\
+ -M, --no-msg-port Don't show info that uses a process's msg port\n\
+ -o, --owner=USER Show processes owned by USER\n\
-P, --no-parent Include processes without parents\n\
-Q, --all-fields Don't elide unusable fields (normally if there's\n\
some reason ps can't print a field for any\n\
@@ -128,7 +130,7 @@ char *procset_names[] =
#define OPT_FMT -5
#define OPT_HELP -6
-#define SHORT_OPTIONS "agHlPQrtuvx"
+#define SHORT_OPTIONS "agHlMPQrtuvx"
static struct option options[] =
{
@@ -138,6 +140,7 @@ static struct option options[] =
{"help", no_argument, 0, OPT_HELP},
{"login", optional_argument, 0, OPT_LOGIN},
{"no-header", no_argument, 0, 'H'},
+ {"no-msg-port", no_argument, 0, 'M'},
{"no-squash", no_argument, 0, 'Q'},
{"no-parent", no_argument, 0, 'P'},
{"session", optional_argument, 0, OPT_SESSION},
@@ -184,7 +187,7 @@ main(int argc, char *argv[])
int filter_mask =
FILTER_OWN | FILTER_NSESSLDR | FILTER_UNORPHANED | FILTER_PARENTED;
bool sort_reverse = FALSE, print_heading = TRUE, squash_bogus_fields = TRUE;
- bool show_threads = FALSE;
+ bool show_threads = FALSE, no_msg_port = FALSE;
/* Handle an argument that is a process ID. */
void pid_arg (const char *arg)
@@ -228,7 +231,7 @@ main(int argc, char *argv[])
break;
case 'a':
- filter_mask &= ~FILTER_OWN; break;
+ filter_mask &= ~(FILTER_OWN | FILTER_NSESSLDR); break;
case 'g':
filter_mask &= ~FILTER_NSESSLDR; break;
case 'x':
@@ -241,8 +244,10 @@ main(int argc, char *argv[])
fmt_string = "vmem"; break;
case 'l':
fmt_string = "long"; break;
+ case 'M':
+ no_msg_port = TRUE; break;
case 'H':
- print_heading = 0; break;
+ print_heading = FALSE; break;
case 'Q':
squash_bogus_fields = FALSE; break;
case 't':
@@ -306,7 +311,6 @@ main(int argc, char *argv[])
while (argv[optind] != NULL)
pid_arg (argv[optind++]);
-
if (proc_stat_list_num_procs(procset) == 0)
{
err = proc_stat_list_add_all(procset);
@@ -314,6 +318,9 @@ main(int argc, char *argv[])
error(2, err, "Couldn't get process list");
}
+ if (no_msg_port)
+ proc_stat_list_set_flags(procset, PSTAT_NO_MSGPORT);
+
if (filter_mask & FILTER_OWN)
proc_stat_list_filter(procset, &ps_own_filter, FALSE);
if (filter_mask & FILTER_NSESSLDR)