integrate systemd-login support to ps
Merge commit 'refs/merge-requests/12' of git://gitorious.org/procps/procps into merge-requests/12
This commit is contained in:
commit
a076c37d07
18
configure.ac
18
configure.ac
@ -264,6 +264,24 @@ then
|
|||||||
fi
|
fi
|
||||||
AC_SUBST(DEJAGNU)
|
AC_SUBST(DEJAGNU)
|
||||||
|
|
||||||
|
AC_ARG_WITH([systemd],
|
||||||
|
[AS_HELP_STRING([--with-systemd], [enable systemd support])],
|
||||||
|
[], [with_systemd=no])
|
||||||
|
|
||||||
|
if test "x$with_systemd" != xno; then
|
||||||
|
PKG_CHECK_MODULES([SYSTEMD], [libsystemd-login >= 202], [], [
|
||||||
|
AC_CHECK_LIB(systemd-login, sd_pid_get_machine_name, [have_systemd=yes], [have_systemd=no])
|
||||||
|
if test "x$have_systemd" = xno; then
|
||||||
|
AC_MSG_ERROR([systemd support missing/incomplete])
|
||||||
|
fi
|
||||||
|
SYSTEMD_LIBS="-lsystemd-login"
|
||||||
|
])
|
||||||
|
AM_CONDITIONAL(WITH_SYSTEMD, true)
|
||||||
|
AC_DEFINE(WITH_SYSTEMD, 1, [enable systemd support])
|
||||||
|
else
|
||||||
|
AM_CONDITIONAL(WITH_SYSTEMD, false)
|
||||||
|
fi
|
||||||
|
|
||||||
AC_CONFIG_FILES([
|
AC_CONFIG_FILES([
|
||||||
Makefile
|
Makefile
|
||||||
include/Makefile
|
include/Makefile
|
||||||
|
@ -5,6 +5,10 @@ AM_CPPFLAGS = \
|
|||||||
|
|
||||||
AM_LDFLAGS = ../proc/libprocps.la
|
AM_LDFLAGS = ../proc/libprocps.la
|
||||||
|
|
||||||
|
if WITH_SYSTEMD
|
||||||
|
AM_LDFLAGS += @SYSTEMD_LIBS@
|
||||||
|
endif
|
||||||
|
|
||||||
dist_man_MANS = ps.1
|
dist_man_MANS = ps.1
|
||||||
|
|
||||||
# Use `ginstall' in the definition of PROGRAMS and in dependencies to avoid
|
# Use `ginstall' in the definition of PROGRAMS and in dependencies to avoid
|
||||||
|
117
ps/output.c
117
ps/output.c
@ -71,6 +71,10 @@
|
|||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
#include <systemd/sd-login.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/* TODO:
|
/* TODO:
|
||||||
* Stop assuming system time is local time.
|
* Stop assuming system time is local time.
|
||||||
*/
|
*/
|
||||||
@ -1169,7 +1173,112 @@ static int pr_sgi_p(char *restrict const outbuf, const proc_t *restrict const pp
|
|||||||
return snprintf(outbuf, COLWID, "*");
|
return snprintf(outbuf, COLWID, "*");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
/************************* Systemd stuff ********************************/
|
||||||
|
static int pr_sd_unit(char *restrict const outbuf, const proc_t *restrict const pp){
|
||||||
|
int r;
|
||||||
|
size_t len;
|
||||||
|
char *unit;
|
||||||
|
|
||||||
|
r = sd_pid_get_unit(pp->tgid, &unit);
|
||||||
|
if(r<0) goto fail;
|
||||||
|
len = snprintf(outbuf, COLWID, "%s", unit);
|
||||||
|
free(unit);
|
||||||
|
return len;
|
||||||
|
|
||||||
|
fail:
|
||||||
|
outbuf[0] = '-';
|
||||||
|
outbuf[1] = '\0';
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int pr_sd_session(char *restrict const outbuf, const proc_t *restrict const pp){
|
||||||
|
int r;
|
||||||
|
size_t len;
|
||||||
|
char *session;
|
||||||
|
|
||||||
|
r = sd_pid_get_session(pp->tgid, &session);
|
||||||
|
if(r<0) goto fail;
|
||||||
|
len = snprintf(outbuf, COLWID, "%s", session);
|
||||||
|
free(session);
|
||||||
|
return len;
|
||||||
|
|
||||||
|
fail:
|
||||||
|
outbuf[0] = '-';
|
||||||
|
outbuf[1] = '\0';
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int pr_sd_ouid(char *restrict const outbuf, const proc_t *restrict const pp){
|
||||||
|
int r;
|
||||||
|
size_t len;
|
||||||
|
uid_t ouid;
|
||||||
|
|
||||||
|
r = sd_pid_get_owner_uid(pp->tgid, &ouid);
|
||||||
|
if(r<0) goto fail;
|
||||||
|
return snprintf(outbuf, COLWID, "%d", ouid);
|
||||||
|
|
||||||
|
fail:
|
||||||
|
outbuf[0] = '-';
|
||||||
|
outbuf[1] = '\0';
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int pr_sd_machine(char *restrict const outbuf, const proc_t *restrict const pp){
|
||||||
|
int r;
|
||||||
|
size_t len;
|
||||||
|
char *machine;
|
||||||
|
|
||||||
|
r = sd_pid_get_machine_name(pp->tgid, &machine);
|
||||||
|
if(r<0) goto fail;
|
||||||
|
len = snprintf(outbuf, COLWID, "%s", machine);
|
||||||
|
free(machine);
|
||||||
|
return len;
|
||||||
|
|
||||||
|
fail:
|
||||||
|
outbuf[0] = '-';
|
||||||
|
outbuf[1] = '\0';
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int pr_sd_uunit(char *restrict const outbuf, const proc_t *restrict const pp){
|
||||||
|
int r;
|
||||||
|
size_t len;
|
||||||
|
char *unit;
|
||||||
|
|
||||||
|
r = sd_pid_get_user_unit(pp->tgid, &unit);
|
||||||
|
if(r<0) goto fail;
|
||||||
|
len = snprintf(outbuf, COLWID, "%s", unit);
|
||||||
|
free(unit);
|
||||||
|
return len;
|
||||||
|
|
||||||
|
fail:
|
||||||
|
outbuf[0] = '-';
|
||||||
|
outbuf[1] = '\0';
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int pr_sd_seat(char *restrict const outbuf, const proc_t *restrict const pp){
|
||||||
|
int r;
|
||||||
|
size_t len;
|
||||||
|
char *session;
|
||||||
|
char *seat;
|
||||||
|
r = sd_pid_get_session(pp->tgid, &session);
|
||||||
|
if(r<0) goto fail;
|
||||||
|
r = sd_session_get_seat(session, &seat);
|
||||||
|
free(session);
|
||||||
|
if(r<0) goto fail;
|
||||||
|
len = snprintf(outbuf, COLWID, "%s", seat);
|
||||||
|
free(seat);
|
||||||
|
return len;
|
||||||
|
|
||||||
|
fail:
|
||||||
|
outbuf[0] = '-';
|
||||||
|
outbuf[1] = '\0';
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
/****************** FLASK & seLinux security stuff **********************/
|
/****************** FLASK & seLinux security stuff **********************/
|
||||||
// move the bulk of this to libproc sometime
|
// move the bulk of this to libproc sometime
|
||||||
|
|
||||||
@ -1496,6 +1605,14 @@ static const format_struct format_array[] = {
|
|||||||
{"sched", "SCH", pr_sched, sr_sched, 3, 0, AIX, TO|RIGHT},
|
{"sched", "SCH", pr_sched, sr_sched, 3, 0, AIX, TO|RIGHT},
|
||||||
{"scnt", "SCNT", pr_nop, sr_nop, 4, 0, DEC, AN|RIGHT}, /* man page misspelling of scount? */
|
{"scnt", "SCNT", pr_nop, sr_nop, 4, 0, DEC, AN|RIGHT}, /* man page misspelling of scount? */
|
||||||
{"scount", "SC", pr_nop, sr_nop, 4, 0, AIX, AN|RIGHT}, /* scnt==scount, DEC claims both */
|
{"scount", "SC", pr_nop, sr_nop, 4, 0, AIX, AN|RIGHT}, /* scnt==scount, DEC claims both */
|
||||||
|
#ifdef WITH_SYSTEMD
|
||||||
|
{"sd_machine","MACHINE", pr_sd_machine, sr_nop, 31, 0, LNX, ET|LEFT},
|
||||||
|
{"sd_ouid", "OWNER", pr_sd_ouid, sr_nop, 5, 0, LNX, ET|LEFT},
|
||||||
|
{"sd_seat", "SEAT", pr_sd_seat, sr_nop, 11, 0, LNX, ET|LEFT},
|
||||||
|
{"sd_session","SESSION", pr_sd_session, sr_nop, 11, 0, LNX, ET|LEFT},
|
||||||
|
{"sd_unit", "UNIT", pr_sd_unit, sr_nop, 31, 0, LNX, ET|LEFT},
|
||||||
|
{"sd_uunit", "UUNIT", pr_sd_uunit, sr_nop, 31, 0, LNX, ET|LEFT},
|
||||||
|
#endif
|
||||||
{"sess", "SESS", pr_sess, sr_session, 5, 0, XXX, PO|PIDMAX|RIGHT},
|
{"sess", "SESS", pr_sess, sr_session, 5, 0, XXX, PO|PIDMAX|RIGHT},
|
||||||
{"session", "SESS", pr_sess, sr_session, 5, 0, LNX, PO|PIDMAX|RIGHT},
|
{"session", "SESS", pr_sess, sr_session, 5, 0, LNX, PO|PIDMAX|RIGHT},
|
||||||
{"sgi_p", "P", pr_sgi_p, sr_nop, 1, 0, LNX, TO|RIGHT}, /* "cpu" number */
|
{"sgi_p", "P", pr_sgi_p, sr_nop, 1, 0, LNX, TO|RIGHT}, /* "cpu" number */
|
||||||
|
24
ps/ps.1
24
ps/ps.1
@ -1489,6 +1489,30 @@ SCHED_FIFO, SCHED_RR, SCHED_BATCH, SCHED_ISO, and SCHED_IDLE are respectively
|
|||||||
displayed as 0, 1, 2, 3, 4, and 5.
|
displayed as 0, 1, 2, 3, 4, and 5.
|
||||||
T}
|
T}
|
||||||
|
|
||||||
|
sd_machine MACHINE T{
|
||||||
|
displays machine name for processes assigned to VM or container.
|
||||||
|
T}
|
||||||
|
|
||||||
|
sd_ouid OWNER T{
|
||||||
|
displays the Unix user identifier of the owner of the session of a process.
|
||||||
|
T}
|
||||||
|
|
||||||
|
sd_seat SEAT T{
|
||||||
|
displays login session identifier of a process.
|
||||||
|
T}
|
||||||
|
|
||||||
|
sd_session SESSION T{
|
||||||
|
displays login session identifier of a process.
|
||||||
|
T}
|
||||||
|
|
||||||
|
sd_unit UNIT T{
|
||||||
|
displays systemd unit which a process belongs to.
|
||||||
|
T}
|
||||||
|
|
||||||
|
sd_uunit UUNIT T{
|
||||||
|
displays systemd user unit which a process belongs to.
|
||||||
|
T}
|
||||||
|
|
||||||
sess SESS T{
|
sess SESS T{
|
||||||
session ID or, equivalently, the process ID of the session leader. (alias
|
session ID or, equivalently, the process ID of the session leader. (alias
|
||||||
.BR session , \ sid ).
|
.BR session , \ sid ).
|
||||||
|
Loading…
Reference in New Issue
Block a user