openrc/man/rc_find_pids.3

57 lines
1.5 KiB
Groff
Raw Normal View History

.\" Copyright (c) 2007-2015 The OpenRC Authors.
.\" See the Authors file at the top-level directory of this distribution and
.\" https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS
2007-12-24 22:03:27 +00:00
.\"
.\" This file is part of OpenRC. It is subject to the license terms in
.\" the LICENSE file found in the top-level directory of this
.\" distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE
.\" This file may not be copied, modified, propagated, or distributed
.\" except according to the terms contained in the LICENSE file.
2007-12-24 22:03:27 +00:00
.\"
.Dd Mar 17, 2008
2007-12-24 22:03:27 +00:00
.Dt RC_FIND_PIDS 3 SMM
.Os OpenRC
.Sh NAME
.Nm rc_find_pids
.Nd finds the pids of processes that match the given criteria
.Sh LIBRARY
Run Command library (librc, -lrc)
.Sh SYNOPSIS
.In rc.h
.Ft "RC_PIDLIST *" Fo rc_find_pids
.Fa "const char *const *argv"
2007-12-24 22:03:27 +00:00
.Fa "const char *cmd"
.Fa "uid_t uid"
.Fa "pid_t pid"
.Fc
.Sh DESCRIPTION
.Fn rc_find_pids
returns RC_PIDLIST, a structure based on the LIST macro from
.Xr queue 3
which contains all the pids found matching the given criteria.
If
2007-12-24 22:03:27 +00:00
.Fa pid
is given then only that pid is returned if it is running. Otherise we check
all instances of
.Fa argv
2007-12-24 22:03:27 +00:00
with a process name of
.Fa cmd
owned by
.Fa uid ,
all of which are optional.
.Pp
The returned list should be freed when done.
2007-12-24 22:03:27 +00:00
.Sh IMPLEMENTATION NOTES
On BSD systems we use
.Lb libkvm
and on Linux systems we use the
.Pa /proc
filesystem to find our processes.
.Pp
Each RC_PID should be freed in the list as well as the list itself when done.
2007-12-24 22:03:27 +00:00
.Sh SEE ALSO
.Xr free 3 ,
.Xr queue 3
2007-12-24 22:03:27 +00:00
.Sh AUTHORS
2008-12-30 19:08:51 +00:00
.An Roy Marples <roy@marples.name>