The following reply was made to PR bin/161257; it has been noted by GNATS.

From: dfil...@freebsd.org (dfilter service)
To: bug-follo...@freebsd.org
Cc:  
Subject: Re: bin/161257: commit references a PR
Date: Thu,  2 Feb 2012 18:22:40 +0000 (UTC)

 Author: trociny
 Date: Thu Feb  2 18:22:25 2012
 New Revision: 230918
 URL: http://svn.freebsd.org/changeset/base/230918
 
 Log:
   MFC r227956, r228090, r228446, r230471, r230548:
   
   r227956:
   
   Add -l flag to display resource limits.
   
   PR:          bin/161257
   Reviewed by: kib
   
   r228090:
   
   Update SYNOPSIS to include the flags added recently.
   
   Spotted by:  jhb
   
   r228446:
   
   Make procstat -l output similar to the output of limits(1).
   
   Suggested by:        jhb
   
   r230471, r230548:
   
   Make procstat -l to work with the new version of kern.proc.rlimit.
   
   Submitted by:        Andrey Zonov <andrey at zonov.org>
 
 Added:
   stable/9/usr.bin/procstat/procstat_rlimit.c
      - copied, changed from r227956, head/usr.bin/procstat/procstat_rlimit.c
 Modified:
   stable/9/usr.bin/procstat/Makefile
   stable/9/usr.bin/procstat/procstat.1
   stable/9/usr.bin/procstat/procstat.c
   stable/9/usr.bin/procstat/procstat.h
 Directory Properties:
   stable/9/usr.bin/procstat/   (props changed)
 
 Modified: stable/9/usr.bin/procstat/Makefile
 ==============================================================================
 --- stable/9/usr.bin/procstat/Makefile Thu Feb  2 18:17:49 2012        
(r230917)
 +++ stable/9/usr.bin/procstat/Makefile Thu Feb  2 18:22:25 2012        
(r230918)
 @@ -10,6 +10,7 @@ SRCS=        procstat.c              \
        procstat_cred.c         \
        procstat_files.c        \
        procstat_kstack.c       \
 +      procstat_rlimit.c       \
        procstat_sigs.c         \
        procstat_threads.c      \
        procstat_vm.c
 
 Modified: stable/9/usr.bin/procstat/procstat.1
 ==============================================================================
 --- stable/9/usr.bin/procstat/procstat.1       Thu Feb  2 18:17:49 2012        
(r230917)
 +++ stable/9/usr.bin/procstat/procstat.1       Thu Feb  2 18:22:25 2012        
(r230918)
 @@ -25,7 +25,7 @@
  .\"
  .\" $FreeBSD$
  .\"
 -.Dd November 22, 2011
 +.Dd November 28, 2011
  .Dt PROCSTAT 1
  .Os
  .Sh NAME
 @@ -37,7 +37,7 @@
  .Op Fl n
  .Op Fl C
  .Op Fl w Ar interval
 -.Op Fl b | c | f | i | j | k | s | t | v
 +.Op Fl b | c | e | f | i | j | k | l | s | t | v | x
  .Op Fl a | Ar pid ...
  .Sh DESCRIPTION
  The
 @@ -69,6 +69,8 @@ Display the stacks of kernel threads in 
  threads currently running on a CPU and threads with stacks swapped to disk.
  If the flag is repeated, function offsets as well as function names are
  printed.
 +.It Fl l
 +Display resource limits for the process.
  .It Fl s
  Display security credential information for the process.
  .It Fl t
 
 Modified: stable/9/usr.bin/procstat/procstat.c
 ==============================================================================
 --- stable/9/usr.bin/procstat/procstat.c       Thu Feb  2 18:17:49 2012        
(r230917)
 +++ stable/9/usr.bin/procstat/procstat.c       Thu Feb  2 18:22:25 2012        
(r230918)
 @@ -39,8 +39,8 @@
  
  #include "procstat.h"
  
 -static int aflag, bflag, cflag, eflag, fflag, iflag, jflag, kflag, sflag, 
tflag;
 -static int vflag, xflag;
 +static int aflag, bflag, cflag, eflag, fflag, iflag, jflag, kflag, lflag, 
sflag;
 +static int tflag, vflag, xflag;
  int   hflag, nflag, Cflag;
  
  static void
 @@ -50,7 +50,7 @@ usage(void)
        fprintf(stderr, "usage: procstat [-h] [-C] [-M core] [-N system] "
            "[-w interval] \n");
        fprintf(stderr, "                [-b | -c | -e | -f | -i | -j | -k | "
 -          "-s | -t | -v | -x] [-a | pid ...]\n");
 +          "-l | -s | -t | -v | -x] [-a | pid ...]\n");
        exit(EX_USAGE);
  }
  
 @@ -72,6 +72,8 @@ procstat(struct procstat *prstat, struct
                procstat_threads_sigs(prstat, kipp);
        else if (kflag)
                procstat_kstack(kipp, kflag);
 +      else if (lflag)
 +              procstat_rlimit(kipp);
        else if (sflag)
                procstat_cred(kipp);
        else if (tflag)
 @@ -123,7 +125,7 @@ main(int argc, char *argv[])
  
        interval = 0;
        memf = nlistf = NULL;
 -      while ((ch = getopt(argc, argv, "CN:M:abcefijkhstvw:x")) != -1) {
 +      while ((ch = getopt(argc, argv, "CN:M:abcefijklhstvw:x")) != -1) {
                switch (ch) {
                case 'C':
                        Cflag++;
 @@ -167,6 +169,10 @@ main(int argc, char *argv[])
                        kflag++;
                        break;
  
 +              case 'l':
 +                      lflag++;
 +                      break;
 +
                case 'n':
                        nflag++;
                        break;
 @@ -210,8 +216,8 @@ main(int argc, char *argv[])
        argv += optind;
  
        /* We require that either 0 or 1 mode flags be set. */
 -      tmp = bflag + cflag + eflag + fflag + (kflag ? 1 : 0) + sflag + tflag +
 -          vflag + xflag;
 +      tmp = bflag + cflag + eflag + fflag + (kflag ? 1 : 0) + lflag + sflag +
 +          tflag + vflag + xflag;
        if (!(tmp == 0 || tmp == 1))
                usage();
  
 
 Modified: stable/9/usr.bin/procstat/procstat.h
 ==============================================================================
 --- stable/9/usr.bin/procstat/procstat.h       Thu Feb  2 18:17:49 2012        
(r230917)
 +++ stable/9/usr.bin/procstat/procstat.h       Thu Feb  2 18:22:25 2012        
(r230918)
 @@ -42,6 +42,7 @@ void procstat_cred(struct kinfo_proc *ki
  void  procstat_env(struct kinfo_proc *kipp);
  void  procstat_files(struct procstat *prstat, struct kinfo_proc *kipp);
  void  procstat_kstack(struct kinfo_proc *kipp, int kflag);
 +void  procstat_rlimit(struct kinfo_proc *kipp);
  void  procstat_sigs(struct procstat *prstat, struct kinfo_proc *kipp);
  void  procstat_threads(struct kinfo_proc *kipp);
  void  procstat_threads_sigs(struct procstat *prstat, struct kinfo_proc *kipp);
 
 Copied and modified: stable/9/usr.bin/procstat/procstat_rlimit.c (from 
r227956, head/usr.bin/procstat/procstat_rlimit.c)
 ==============================================================================
 --- head/usr.bin/procstat/procstat_rlimit.c    Thu Nov 24 20:54:06 2011        
(r227956, copy source)
 +++ stable/9/usr.bin/procstat/procstat_rlimit.c        Thu Feb  2 18:22:25 
2012        (r230918)
 @@ -28,7 +28,6 @@
  
  #include <sys/param.h>
  #include <sys/time.h>
 -#define _RLIMIT_IDENT
  #include <sys/resourcevar.h>
  #include <sys/sysctl.h>
  #include <sys/user.h>
 @@ -36,6 +35,7 @@
  #include <err.h>
  #include <errno.h>
  #include <libprocstat.h>
 +#include <libutil.h>
  #include <limits.h>
  #include <stdio.h>
  #include <stdlib.h>
 @@ -43,36 +43,77 @@
  
  #include "procstat.h"
  
 -static struct rlimit rlimit[RLIM_NLIMITS];
 +static struct {
 +      const char *name;
 +      const char *suffix;
 +} rlimit_param[13] = {
 +      {"cputime",          "sec"},
 +      {"filesize",         "B  "},
 +      {"datasize",         "B  "},
 +      {"stacksize",        "B  "},
 +      {"coredumpsize",     "B  "},
 +      {"memoryuse",        "B  "},
 +      {"memorylocked",     "B  "},
 +      {"maxprocesses",     "   "},
 +      {"openfiles",        "   "},
 +      {"sbsize",           "B  "},
 +      {"vmemoryuse",       "B  "},
 +      {"pseudo-terminals", "   "},
 +      {"swapuse",          "B  "},
 +};
 +
 +#if RLIM_NLIMITS > 13
 +#error "Resource limits have grown. Add new entries to rlimit_param[]."
 +#endif
 +
 +static
 +const char *humanize_rlimit(int indx, rlim_t limit)
 +{
 +      static char buf[14];
 +      int scale;
 +
 +      if (limit == RLIM_INFINITY)
 +              return ("infinity     ");
 +
 +      scale = humanize_number(buf, sizeof(buf) - 1, (int64_t)limit,
 +          rlimit_param[indx].suffix, HN_AUTOSCALE | HN_GETSCALE, HN_DECIMAL);
 +      (void)humanize_number(buf, sizeof(buf) - 1, (int64_t)limit,
 +          rlimit_param[indx].suffix, HN_AUTOSCALE, HN_DECIMAL);
 +      /* Pad with one space if there is no suffix prefix. */
 +      if (scale == 0)
 +              sprintf(buf + strlen(buf), " ");
 +      return (buf);
 +}
  
  void
  procstat_rlimit(struct kinfo_proc *kipp)
  {
 -      int error, i, name[4];
 +      struct rlimit rlimit;
 +      int error, i, name[5];
        size_t len;
  
 -      if (!hflag)
 -              printf("%5s %-16s %-10s %12s %12s\n", "PID", "COMM", "RLIMIT",
 -                  "CURRENT", "MAX");
 +      if (!hflag) {
 +              printf("%5s %-16s %-16s %16s %16s\n",
 +                  "PID", "COMM", "RLIMIT", "SOFT     ", "HARD     ");
 +      }
 +      len = sizeof(struct rlimit);
        name[0] = CTL_KERN;
        name[1] = KERN_PROC;
        name[2] = KERN_PROC_RLIMIT;
        name[3] = kipp->ki_pid;
 -      len = sizeof(rlimit);
 -      error = sysctl(name, 4, rlimit, &len, NULL, 0);
 -      if (error < 0 && errno != ESRCH) {
 -              warn("sysctl: kern.proc.rlimit: %d", kipp->ki_pid);
 -              return;
 -      }
 -      if (error < 0 || len != sizeof(rlimit))
 -              return;
 -
        for (i = 0; i < RLIM_NLIMITS; i++) {
 -              printf("%5d %-16s %-10s %12jd %12jd\n", kipp->ki_pid,
 -                  kipp->ki_comm, rlimit_ident[i],
 -                  rlimit[i].rlim_cur == RLIM_INFINITY ?
 -                  -1 : rlimit[i].rlim_cur,
 -                  rlimit[i].rlim_max == RLIM_INFINITY ?
 -                  -1 : rlimit[i].rlim_max);
 -        }
 +              name[4] = i;
 +              error = sysctl(name, 5, &rlimit, &len, NULL, 0);
 +              if (error < 0 && errno != ESRCH) {
 +                      warn("sysctl: kern.proc.rlimit: %d", kipp->ki_pid);
 +                      return;
 +              }
 +              if (error < 0 || len != sizeof(struct rlimit))
 +                      return;
 +
 +              printf("%5d %-16s %-16s ", kipp->ki_pid, kipp->ki_comm,
 +                  rlimit_param[i].name);
 +              printf("%16s ", humanize_rlimit(i, rlimit.rlim_cur));
 +              printf("%16s\n", humanize_rlimit(i, rlimit.rlim_max));
 +      }
  }
 _______________________________________________
 svn-src-...@freebsd.org mailing list
 http://lists.freebsd.org/mailman/listinfo/svn-src-all
 To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"
 
_______________________________________________
freebsd-bugs@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-bugs
To unsubscribe, send any mail to "freebsd-bugs-unsubscr...@freebsd.org"

Reply via email to