Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/miscfs/procfs Split the status printing routines (one fo...



details:   https://anonhg.NetBSD.org/src/rev/da92dfa6ac32
branches:  trunk
changeset: 826786:da92dfa6ac32
user:      christos <christos%NetBSD.org@localhost>
date:      Fri Sep 29 12:57:05 2017 +0000

description:
Split the status printing routines (one for NetBSD and one for Linux) for
simplicity (Robert Swindelis)

diffstat:

 sys/miscfs/procfs/procfs_status.c |  196 ++++++++++++++++++++++++++-----------
 1 files changed, 136 insertions(+), 60 deletions(-)

diffs (248 lines):

diff -r afe2565ab33f -r da92dfa6ac32 sys/miscfs/procfs/procfs_status.c
--- a/sys/miscfs/procfs/procfs_status.c Fri Sep 29 12:42:36 2017 +0000
+++ b/sys/miscfs/procfs/procfs_status.c Fri Sep 29 12:57:05 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: procfs_status.c,v 1.37 2016/11/14 08:55:51 kre Exp $   */
+/*     $NetBSD: procfs_status.c,v 1.38 2017/09/29 12:57:05 christos Exp $      */
 
 /*
  * Copyright (c) 1993
@@ -72,7 +72,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: procfs_status.c,v 1.37 2016/11/14 08:55:51 kre Exp $");
+__KERNEL_RCSID(0, "$NetBSD: procfs_status.c,v 1.38 2017/09/29 12:57:05 christos Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -88,13 +88,8 @@
 
 #include <miscfs/procfs/procfs.h>
 
-int
-procfs_dostatus(
-    struct lwp *curl,
-    struct lwp *l,
-    struct pfsnode *pfs,
-    struct uio *uio
-)
+static int
+procfs_status_netbsd(struct lwp *l, struct uio *uio)
 {
        struct session *sess;
        struct tty *tp;
@@ -102,13 +97,12 @@
        struct proc *p = l->l_proc;
        char *ps;
        const char *sep;
+       const char *emulname = curlwp->l_proc->p_emul->e_name;
        int pid, ppid, pgid, sid;
        u_int i;
        char psbuf[256+MAXHOSTNAMELEN];         /* XXX - conservative */
        uint16_t ngroups;
 
-       if (uio->uio_rw != UIO_READ)
-               return (EOPNOTSUPP);
 
        mutex_enter(proc_lock);
        mutex_enter(p->p_lock);
@@ -119,67 +113,149 @@
        sess = p->p_pgrp->pg_session;
        sid = sess->s_sid;
 
+       ps = psbuf;
+       if (strncmp(emulname, "linux", 5) == 0) {
+               ps += snprintf(ps, sizeof(psbuf), "Name:\t%s\n", p->p_comm);
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "Pid:\t%d\n", pid);
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "PPid:\t%d\n", ppid);
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "TracerPid:\t%d\n", 0);
+
+               cr = p->p_cred;
+               ngroups = kauth_cred_ngroups(cr);
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "Groups:\t");
+               for (i = 0; i < ngroups; i++)
+                       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%d ",
+                           kauth_cred_group(cr, i));
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "\n");
+
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf),
+                   "VmPeak:\t%8lu kB\n", p->p_rlimit[RLIMIT_DATA].rlim_cur / 1024);
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf),
+                   "VmSize:\t%8lu kB\n", p->p_rlimit[RLIMIT_DATA].rlim_cur / 1024);
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf),
+                   "VmRSS:\t%8lu kB\n", p->p_rlimit[RLIMIT_RSS].rlim_cur / 1024);
+
+       } else {
 /* comm pid ppid pgid sid maj,min ctty,sldr start ut st wmsg uid gid groups ... */
 
+               memcpy(ps, p->p_comm, MAXCOMLEN);
+               ps[MAXCOMLEN] = '\0';
+               ps += strlen(ps);
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %d %d %d %d ",
+                   pid, ppid, pgid, sid);
+
+               if ((p->p_lflag & PL_CONTROLT) && (tp = sess->s_ttyp))
+                       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%llu,%llu ",
+                           (unsigned long long)major(tp->t_dev),
+                           (unsigned long long)minor(tp->t_dev));
+               else
+                       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%d,%d ",
+                           -1, -1);
+
+               sep = "";
+               if (sess->s_ttyvp) {
+                       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%sctty", sep);
+                       sep = ",";
+               }
+               if (SESS_LEADER(p)) {
+                       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%ssldr", sep);
+                       sep = ",";
+               }
+               if (*sep != ',')
+                       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "noflags");
+
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %lld,%ld",
+                   (long long)p->p_stats->p_start.tv_sec,
+                   (long)p->p_stats->p_start.tv_usec);
+
+               {
+                       struct timeval ut, st;
+
+                       calcru(p, &ut, &st, (void *) 0, NULL);
+                       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf),
+                           " %lld,%ld %lld,%ld", (long long)ut.tv_sec,
+                           (long)ut.tv_usec, (long long)st.tv_sec, (long)st.tv_usec);
+               }
+
+               lwp_lock(l);
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %s",
+                   (l->l_wchan && l->l_wmesg) ? l->l_wmesg : "nochan");
+               lwp_unlock(l);
+
+               cr = p->p_cred;
+
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %d",
+                   kauth_cred_geteuid(cr));
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %d",
+                   kauth_cred_getegid(cr));
+               ngroups = kauth_cred_ngroups(cr);
+               for (i = 0; i < ngroups; i++)
+                       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), ",%d",
+                           kauth_cred_group(cr, i));
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "\n");
+       }
+       mutex_exit(p->p_lock);
+       mutex_exit(proc_lock);
+
+       return (uiomove_frombuf(psbuf, ps - psbuf, uio));
+}
+
+static int
+procfs_status_linux(struct lwp *l, struct uio *uio)
+{
+       kauth_cred_t cr;
+       struct proc *p = l->l_proc;
+       char *ps;
+       int pid, ppid;
+       u_int i;
+       char psbuf[256+MAXHOSTNAMELEN];         /* XXX - conservative */
+       uint16_t ngroups;
+
+       mutex_enter(proc_lock);
+       mutex_enter(p->p_lock);
+
+       pid = p->p_pid;
+       ppid = p->p_ppid;
+
        ps = psbuf;
-       memcpy(ps, p->p_comm, MAXCOMLEN);
-       ps[MAXCOMLEN] = '\0';
-       ps += strlen(ps);
-       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %d %d %d %d ",
-           pid, ppid, pgid, sid);
-
-       if ((p->p_lflag & PL_CONTROLT) && (tp = sess->s_ttyp))
-               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%llu,%llu ",
-                   (unsigned long long)major(tp->t_dev),
-                   (unsigned long long)minor(tp->t_dev));
-       else
-               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%d,%d ",
-                   -1, -1);
-
-       sep = "";
-       if (sess->s_ttyvp) {
-               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%sctty", sep);
-               sep = ",";
-       }
-       if (SESS_LEADER(p)) {
-               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%ssldr", sep);
-               sep = ",";
-       }
-       if (*sep != ',')
-               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "noflags");
-
-       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %lld,%ld",
-           (long long)p->p_stats->p_start.tv_sec,
-           (long)p->p_stats->p_start.tv_usec);
-
-       {
-               struct timeval ut, st;
-
-               calcru(p, &ut, &st, (void *) 0, NULL);
-               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf),
-                   " %lld,%ld %lld,%ld", (long long)ut.tv_sec,
-                   (long)ut.tv_usec, (long long)st.tv_sec, (long)st.tv_usec);
-       }
-
-       lwp_lock(l);
-       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %s",
-           (l->l_wchan && l->l_wmesg) ? l->l_wmesg : "nochan");
-       lwp_unlock(l);
+       ps += snprintf(ps, sizeof(psbuf), "Name:\t%s\n", p->p_comm);
+       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "Pid:\t%d\n", pid);
+       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "PPid:\t%d\n", ppid);
+       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "TracerPid:\t%d\n", 0);
 
        cr = p->p_cred;
-
-       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %d",
-                      kauth_cred_geteuid(cr));
-       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), " %d",
-                      kauth_cred_getegid(cr));
        ngroups = kauth_cred_ngroups(cr);
+       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "Groups:\t");
        for (i = 0; i < ngroups; i++)
-               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), ",%d",
+               ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "%d ",
                    kauth_cred_group(cr, i));
        ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf), "\n");
 
+       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf),
+           "VmPeak:\t%8" PRIu64 " kB\n", p->p_rlimit[RLIMIT_DATA].rlim_cur / 1024);
+       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf),
+           "VmSize:\t%8" PRIu64 " kB\n", p->p_rlimit[RLIMIT_DATA].rlim_cur / 1024);
+       ps += snprintf(ps, sizeof(psbuf) - (ps - psbuf),
+           "VmRSS:\t%8" PRIu64 " kB\n", p->p_rlimit[RLIMIT_RSS].rlim_cur / 1024);
+
        mutex_exit(p->p_lock);
        mutex_exit(proc_lock);
 
        return (uiomove_frombuf(psbuf, ps - psbuf, uio));
 }
+
+int
+procfs_dostatus(struct lwp *curl, struct lwp *l, struct pfsnode *pfs,
+    struct uio *uio)
+{
+       const char *emulname = curlwp->l_proc->p_emul->e_name;
+
+       if (uio->uio_rw != UIO_READ)
+               return (EOPNOTSUPP);
+
+       if (strncmp(emulname, "linux", 5) == 0) {
+               return procfs_status_linux(l, uio);
+       } else {
+               return procfs_status_netbsd(l, uio);
+       }
+}



Home | Main Index | Thread Index | Old Index