Merge remote-tracking branch 'sami/to-craig' into sami-merge
Conflicts: pgrep.c w.c
This commit is contained in:
25
configure.ac
25
configure.ac
@ -16,6 +16,7 @@ AC_PROG_CC
|
|||||||
AM_PROG_CC_C_O
|
AM_PROG_CC_C_O
|
||||||
AC_PROG_INSTALL
|
AC_PROG_INSTALL
|
||||||
AC_PROG_LN_S
|
AC_PROG_LN_S
|
||||||
|
PKG_PROG_PKG_CONFIG
|
||||||
|
|
||||||
AC_SUBST([WITH_WATCH8BIT])
|
AC_SUBST([WITH_WATCH8BIT])
|
||||||
AC_ARG_ENABLE([watch8bit],
|
AC_ARG_ENABLE([watch8bit],
|
||||||
@ -127,25 +128,29 @@ AC_TRY_COMPILE([#include <argp.h>],
|
|||||||
|
|
||||||
AC_ARG_WITH([ncurses],
|
AC_ARG_WITH([ncurses],
|
||||||
AS_HELP_STRING([--without-ncurses], [build only applications not needing ncurses]),
|
AS_HELP_STRING([--without-ncurses], [build only applications not needing ncurses]),
|
||||||
[with_ncurses=no], [with_ncurses=yes]
|
[with_ncurses=$withval], [with_ncurses=yes]
|
||||||
)
|
)
|
||||||
|
|
||||||
if test "x$with_ncurses" = xno; then
|
if test "x$with_ncurses" = xno; then
|
||||||
AM_CONDITIONAL(WITH_NCURSES, false)
|
AM_CONDITIONAL(WITH_NCURSES, false)
|
||||||
else
|
else
|
||||||
AC_CHECK_LIB(ncursesw, initscr, [have_ncurses=yes], [have_ncurses=no])
|
PKG_CHECK_MODULES([NCURSES], [ncurses], [], [
|
||||||
AC_CHECK_HEADERS(curses.h ncurses.h term.h, [], [have_ncurses=no], AC_INCLUDES_DEFAULT)
|
AC_CHECK_LIB(ncurses, initscr, [have_ncurses=yes], [have_ncurses=no])
|
||||||
if test "x$have_ncurses" = xno; then
|
AC_CHECK_HEADERS(curses.h ncurses.h term.h, [], [have_ncurses=no], AC_INCLUDES_DEFAULT)
|
||||||
AC_MSG_ERROR([ncurses support missing/incomplete (for partial build use --without-ncurses)])
|
if test "x$have_ncurses" = xno; then
|
||||||
fi
|
AC_MSG_ERROR([ncurses support missing/incomplete (for partial build use --without-ncurses)])
|
||||||
|
fi
|
||||||
|
NCURSES_LIBS="-lncurses"
|
||||||
|
])
|
||||||
AM_CONDITIONAL(WITH_NCURSES, true)
|
AM_CONDITIONAL(WITH_NCURSES, true)
|
||||||
if test "$enable_watch8bit" = yes; then
|
if test "$enable_watch8bit" = yes; then
|
||||||
AC_CHECK_LIB([ncursesw], [addwstr], [WATCH_NCURSES_LIBS=-lncursesw],
|
PKG_CHECK_MODULES([NCURSESW], [ncursesw], [WATCH_NCURSES_LIBS="$NCURSESW_LIBS"], [
|
||||||
[AC_MSG_ERROR([Cannot find ncurses wide library ncursesw with --enable-watch8bit])])
|
AC_CHECK_LIB([ncursesw], [addwstr], [WATCH_NCURSES_LIBS=-lncursesw],
|
||||||
|
[AC_MSG_ERROR([Cannot find ncurses wide library ncursesw with --enable-watch8bit])])
|
||||||
|
])
|
||||||
else
|
else
|
||||||
WATCH_NCURSES_LIBS="-lncurses"
|
WATCH_NCURSES_LIBS="$NCURSES_LIBS"
|
||||||
fi
|
fi
|
||||||
NCURSES_LIBS="-lncurses"
|
|
||||||
fi
|
fi
|
||||||
AC_SUBST([NCURSES_LIBS])
|
AC_SUBST([NCURSES_LIBS])
|
||||||
AC_SUBST([WATCH_NCURSES_LIBS])
|
AC_SUBST([WATCH_NCURSES_LIBS])
|
||||||
|
6
pgrep.c
6
pgrep.c
@ -798,9 +798,9 @@ int main (int argc, char **argv)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (errno==ESRCH)
|
if (errno==ESRCH)
|
||||||
/* gone now, which is OK */
|
// gone now, which is OK
|
||||||
continue;
|
continue;
|
||||||
xwarn(_("killing pid %d failed"), procs[i].num);
|
xwarn(_("killing pid %ld failed"), procs[i].num);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (opt_count) {
|
if (opt_count) {
|
||||||
|
2
pmap.c
2
pmap.c
@ -161,7 +161,7 @@ static int one_proc(proc_t * p)
|
|||||||
unsigned long total_private_writeable = 0ul;
|
unsigned long total_private_writeable = 0ul;
|
||||||
KLONG diff = 0;
|
KLONG diff = 0;
|
||||||
|
|
||||||
char *cp2 = NULL;
|
const char *cp2 = NULL;
|
||||||
unsigned long long rss = 0ull;
|
unsigned long long rss = 0ull;
|
||||||
unsigned long long private_dirty = 0ull;
|
unsigned long long private_dirty = 0ull;
|
||||||
unsigned long long shared_dirty = 0ull;
|
unsigned long long shared_dirty = 0ull;
|
||||||
|
@ -624,8 +624,12 @@ static int pr_pri_api(char *restrict const outbuf, const proc_t *restrict const
|
|||||||
return snprintf(outbuf, COLWID, "%ld", -1 - pp->priority);
|
return snprintf(outbuf, COLWID, "%ld", -1 - pp->priority);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Linux applies nice value in the scheduling policies (classes)
|
||||||
|
// SCHED_OTHER(0) and SCHED_BATCH(3). Ref: sched_setscheduler(2).
|
||||||
|
// Also print nice value for old kernels which didn't use scheduling
|
||||||
|
// policies (-1).
|
||||||
static int pr_nice(char *restrict const outbuf, const proc_t *restrict const pp){
|
static int pr_nice(char *restrict const outbuf, const proc_t *restrict const pp){
|
||||||
if(pp->sched!=0 && pp->sched!=(unsigned long)-1) return snprintf(outbuf, COLWID, "-");
|
if(pp->sched!=0 && pp->sched!=3 && pp->sched!=-1) return snprintf(outbuf, COLWID, "-");
|
||||||
return snprintf(outbuf, COLWID, "%ld", pp->nice);
|
return snprintf(outbuf, COLWID, "%ld", pp->nice);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
1
testsuite/.gitignore
vendored
1
testsuite/.gitignore
vendored
@ -2,3 +2,4 @@
|
|||||||
*.sum
|
*.sum
|
||||||
site.bak
|
site.bak
|
||||||
site.exp
|
site.exp
|
||||||
|
test-schedbatch
|
||||||
|
@ -4,6 +4,10 @@ export DEJAGNU
|
|||||||
# Programs that are expected across the board.
|
# Programs that are expected across the board.
|
||||||
DEJATOOL =
|
DEJATOOL =
|
||||||
|
|
||||||
|
noinst_PROGRAMS = test-schedbatch
|
||||||
|
|
||||||
|
test_schedbatch_SOURCES = ps.test/test-schedbatch.c
|
||||||
|
|
||||||
if LINUX
|
if LINUX
|
||||||
# These should be in defined in 'across the board' scope, but are
|
# These should be in defined in 'across the board' scope, but are
|
||||||
# temporarily disabled on other than linux systems, see commit
|
# temporarily disabled on other than linux systems, see commit
|
||||||
@ -35,6 +39,7 @@ EXTRA_DIST = \
|
|||||||
pmap.test/pmap.exp \
|
pmap.test/pmap.exp \
|
||||||
ps.test/ps_output.exp \
|
ps.test/ps_output.exp \
|
||||||
ps.test/ps_personality.exp \
|
ps.test/ps_personality.exp \
|
||||||
|
ps.test/ps_sched_batch.exp \
|
||||||
pwdx.test/pwdx.exp \
|
pwdx.test/pwdx.exp \
|
||||||
slabtop.test/slabtop.exp \
|
slabtop.test/slabtop.exp \
|
||||||
sysctl.test/sysctl_read.exp \
|
sysctl.test/sysctl_read.exp \
|
||||||
|
12
testsuite/ps.test/ps_sched_batch.exp
Normal file
12
testsuite/ps.test/ps_sched_batch.exp
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
#
|
||||||
|
# check the ps SCHED_BATCH scheduler policy output
|
||||||
|
#
|
||||||
|
set ps "${topdir}ps/pscommand"
|
||||||
|
set schedbatch "${topdir}testsuite/test-schedbatch"
|
||||||
|
|
||||||
|
spawn $schedbatch 18
|
||||||
|
|
||||||
|
set test "ps SCHED_BATCH scheduler"
|
||||||
|
spawn $ps --no-header -o comm,cls,nice -a
|
||||||
|
expect_pass "$test" "\\s+test-schedbatch\\s+B\\s+18"
|
||||||
|
untested "$test"
|
39
testsuite/ps.test/test-schedbatch.c
Normal file
39
testsuite/ps.test/test-schedbatch.c
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
/* test-schedbatch.c - Create a process using SCHED_BATCH scheduler
|
||||||
|
* policy and nice value.
|
||||||
|
* Compile: gcc -o test-schedbatch -Wall test-schedbatch.c
|
||||||
|
* Usage: ./test-schedbatch [ <NICE> ]
|
||||||
|
*
|
||||||
|
* Author: Mike Fleetwood
|
||||||
|
* https://bugzilla.redhat.com/show_bug.cgi?id=741090
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define _GNU_SOURCE
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <sched.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <sys/resource.h>
|
||||||
|
|
||||||
|
int main(int argc, const char *argv[])
|
||||||
|
{
|
||||||
|
int nice = 19;
|
||||||
|
struct sched_param sp;
|
||||||
|
char msg[50];
|
||||||
|
|
||||||
|
if (argc >= 2) {
|
||||||
|
nice = atoi(argv[1]);
|
||||||
|
}
|
||||||
|
sp.sched_priority = 0;
|
||||||
|
if (sched_setscheduler(0, SCHED_BATCH, &sp)) {
|
||||||
|
perror("sched_setscheduler(0,SCHED_BATCH,{.sched_priority=0}");
|
||||||
|
}
|
||||||
|
if (setpriority(PRIO_PROCESS, 0, nice) || errno) {
|
||||||
|
(void)snprintf(msg, sizeof(msg),
|
||||||
|
"setpriority(PRIO_PROCESS, 0, %d)", nice);
|
||||||
|
perror(msg);
|
||||||
|
}
|
||||||
|
while (1) {
|
||||||
|
getchar();
|
||||||
|
}
|
||||||
|
}
|
2
vmstat.c
2
vmstat.c
@ -356,7 +356,7 @@ static int diskpartition_format(const char *partition_name)
|
|||||||
struct disk_stat *disks;
|
struct disk_stat *disks;
|
||||||
struct partition_stat *partitions, *current_partition = NULL;
|
struct partition_stat *partitions, *current_partition = NULL;
|
||||||
unsigned long ndisks, j, k, npartitions;
|
unsigned long ndisks, j, k, npartitions;
|
||||||
const char format[] = "%20u %10llu %10u %10u\n";
|
const char format[] = "%20u %10llu %10u %10llu\n";
|
||||||
|
|
||||||
fDiskstat = fopen("/proc/diskstats", "rb");
|
fDiskstat = fopen("/proc/diskstats", "rb");
|
||||||
if (!fDiskstat)
|
if (!fDiskstat)
|
||||||
|
2
w.c
2
w.c
@ -392,7 +392,7 @@ int main(int argc, char **argv)
|
|||||||
userlen = atoi(env_var);
|
userlen = atoi(env_var);
|
||||||
if (userlen < 8 || userlen > USERSZ) {
|
if (userlen < 8 || userlen > USERSZ) {
|
||||||
xwarnx
|
xwarnx
|
||||||
(_("user length environment PROCPS_USERLEN must be between 8 and %d, ignoring\n"),
|
(_("User length environment PROCPS_USERLEN must be between 8 and %zu, ignoring.\n"),
|
||||||
USERSZ);
|
USERSZ);
|
||||||
userlen = 8;
|
userlen = 8;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user