Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/systat PR/53906: Paul Ripke: systat(1) vmstat & sysc...
details: https://anonhg.NetBSD.org/src/rev/812458d4f9aa
branches: trunk
changeset: 996239:812458d4f9aa
user: christos <christos%NetBSD.org@localhost>
date: Fri Jan 25 15:31:11 2019 +0000
description:
PR/53906: Paul Ripke: systat(1) vmstat & syscall get
"alternate system clock has died" on terminal resize (SIGWINCH)
diffstat:
usr.bin/systat/extern.h | 7 ++++++-
usr.bin/systat/iostat.c | 5 ++---
usr.bin/systat/main.c | 35 ++++++++++++++++++++++++++++++++---
usr.bin/systat/syscall.c | 23 +++--------------------
usr.bin/systat/vmstat.c | 24 ++++--------------------
5 files changed, 47 insertions(+), 47 deletions(-)
diffs (279 lines):
diff -r 043fae8ed751 -r 812458d4f9aa usr.bin/systat/extern.h
--- a/usr.bin/systat/extern.h Fri Jan 25 14:29:05 2019 +0000
+++ b/usr.bin/systat/extern.h Fri Jan 25 15:31:11 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: extern.h,v 1.46 2016/10/22 22:02:55 christos Exp $ */
+/* $NetBSD: extern.h,v 1.47 2019/01/25 15:31:11 christos Exp $ */
/*-
* Copyright (c) 1991, 1993
@@ -33,10 +33,12 @@
#include <sys/cdefs.h>
#include <fcntl.h>
+#include <stdbool.h>
#include <kvm.h>
#define ADJINETCTR(c, o, n, e) (c.e = n.e - o.e)
#define xADJINETCTR(c, o, n, e) (c[e] = n[e] - o[e])
+#define MAXFAIL 5
extern struct command global_commands[];
extern struct mode *curmode;
@@ -60,6 +62,8 @@
extern int allflag;
extern int turns;
extern gid_t egid;
+extern float hertz;
+extern double etime;
struct inpcb;
#ifdef INET6
@@ -210,6 +214,7 @@
void tcp_run(char *);
void tcp_time(char *);
void tcp_zero(char *);
+bool toofast(int *);
void vmstat_boot(char *);
void vmstat_run(char *);
void vmstat_time(char *);
diff -r 043fae8ed751 -r 812458d4f9aa usr.bin/systat/iostat.c
--- a/usr.bin/systat/iostat.c Fri Jan 25 14:29:05 2019 +0000
+++ b/usr.bin/systat/iostat.c Fri Jan 25 15:31:11 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: iostat.c,v 1.38 2017/07/15 08:22:23 mlelstv Exp $ */
+/* $NetBSD: iostat.c,v 1.39 2019/01/25 15:31:11 christos Exp $ */
/*
* Copyright (c) 1980, 1992, 1993
@@ -34,7 +34,7 @@
#if 0
static char sccsid[] = "@(#)iostat.c 8.1 (Berkeley) 6/6/93";
#endif
-__RCSID("$NetBSD: iostat.c,v 1.38 2017/07/15 08:22:23 mlelstv Exp $");
+__RCSID("$NetBSD: iostat.c,v 1.39 2019/01/25 15:31:11 christos Exp $");
#endif /* not lint */
#include <sys/param.h>
@@ -46,7 +46,6 @@
#include "drvstats.h"
static int linesperregion;
-static double etime;
static int numbers = 0; /* default display bar graphs */
static int secs = 0; /* default seconds shown */
static int read_write = 0; /* default read/write shown */
diff -r 043fae8ed751 -r 812458d4f9aa usr.bin/systat/main.c
--- a/usr.bin/systat/main.c Fri Jan 25 14:29:05 2019 +0000
+++ b/usr.bin/systat/main.c Fri Jan 25 15:31:11 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: main.c,v 1.54 2018/12/26 01:47:37 sevan Exp $ */
+/* $NetBSD: main.c,v 1.55 2019/01/25 15:31:11 christos Exp $ */
/*-
* Copyright (c) 1980, 1992, 1993
@@ -36,7 +36,7 @@
#if 0
static char sccsid[] = "@(#)main.c 8.1 (Berkeley) 6/6/93";
#endif
-__RCSID("$NetBSD: main.c,v 1.54 2018/12/26 01:47:37 sevan Exp $");
+__RCSID("$NetBSD: main.c,v 1.55 2019/01/25 15:31:11 christos Exp $");
#endif /* not lint */
#include <sys/param.h>
@@ -57,6 +57,7 @@
#include "systat.h"
#include "extern.h"
+#include "drvstats.h"
static int dellave;
@@ -78,6 +79,8 @@
int allflag;
int allcounter;
sig_atomic_t needsredraw = 0;
+float hertz;
+double etime;
static WINDOW *wload; /* one line window for load average */
@@ -332,7 +335,6 @@
void
redraw(void)
{
- resizeterm(LINES, COLS);
CMDLINE = LINES - 1;
labels();
@@ -417,3 +419,30 @@
endwin();
exit(1);
}
+
+bool
+toofast(int *failcnt)
+{
+ static char pigs[] = "pigs";
+ etime = cur.cp_etime;
+ /* < 1 ticks - sleep for a tick */
+ /* this is often triggered by repeated SIGWINCH */
+ if ((etime * hertz) >= 1.0)
+ return false;
+
+ if ((*failcnt)++ <= MAXFAIL) {
+ struct timespec interval = { 0, 1000000000L / hertz };
+ while (nanosleep(&interval, &interval) == -1)
+ continue;
+ return true;
+ }
+ clear();
+ mvprintw(2, 10, "The alternate system clock has died!");
+ mvprintw(3, 10, "Reverting to ``pigs'' display.");
+ move(CMDLINE, 0);
+ refresh();
+ failcnt = 0;
+ sleep(5);
+ command(pigs);
+ return true;
+}
diff -r 043fae8ed751 -r 812458d4f9aa usr.bin/systat/syscall.c
--- a/usr.bin/systat/syscall.c Fri Jan 25 14:29:05 2019 +0000
+++ b/usr.bin/systat/syscall.c Fri Jan 25 15:31:11 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: syscall.c,v 1.9 2014/02/19 20:42:14 dsl Exp $ */
+/* $NetBSD: syscall.c,v 1.10 2019/01/25 15:31:11 christos Exp $ */
/*-
* Copyright (c) 2006 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: syscall.c,v 1.9 2014/02/19 20:42:14 dsl Exp $");
+__RCSID("$NetBSD: syscall.c,v 1.10 2019/01/25 15:31:11 christos Exp $");
/* System call stats */
@@ -75,7 +75,6 @@
static void getinfo(struct Info *, int);
static char buf[32];
-static float hertz;
static size_t counts_mib_len, times_mib_len;
static int counts_mib[4], times_mib[4];
@@ -146,8 +145,6 @@
labelvmstat_top();
}
-#define MAXFAIL 5
-
static void
putuint64(uint64_t v, int row, int col, int width)
{
@@ -186,7 +183,6 @@
uint64_t v;
static int failcnt = 0;
static int relabel = 0;
- static char pigs[] = "pigs";
uint64_t itime;
if (relabel) {
@@ -196,21 +192,8 @@
cpuswap();
if (display_mode == TIME) {
- etime = cur.cp_etime;
- /* < 5 ticks - ignore this trash */
- if ((etime * hertz) < 1.0) {
- if (failcnt++ <= MAXFAIL)
- return;
- clear();
- mvprintw(2, 10, "The alternate system clock has died!");
- mvprintw(3, 10, "Reverting to ``pigs'' display.");
- move(CMDLINE, 0);
- refresh();
- failcnt = 0;
- sleep(5);
- command(pigs);
+ if (toofast(&failcnt))
return;
- }
} else
etime = 1.0;
itime = etime * 100;
diff -r 043fae8ed751 -r 812458d4f9aa usr.bin/systat/vmstat.c
--- a/usr.bin/systat/vmstat.c Fri Jan 25 14:29:05 2019 +0000
+++ b/usr.bin/systat/vmstat.c Fri Jan 25 15:31:11 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vmstat.c,v 1.84 2019/01/08 08:22:20 tih Exp $ */
+/* $NetBSD: vmstat.c,v 1.85 2019/01/25 15:31:11 christos Exp $ */
/*-
* Copyright (c) 1983, 1989, 1992, 1993
@@ -34,7 +34,7 @@
#if 0
static char sccsid[] = "@(#)vmstat.c 8.2 (Berkeley) 1/12/94";
#endif
-__RCSID("$NetBSD: vmstat.c,v 1.84 2019/01/08 08:22:20 tih Exp $");
+__RCSID("$NetBSD: vmstat.c,v 1.85 2019/01/25 15:31:11 christos Exp $");
#endif /* not lint */
/*
@@ -53,6 +53,7 @@
#include <stdlib.h>
#include <string.h>
#include <util.h>
+#include <curses.h>
#include "systat.h"
#include "extern.h"
@@ -80,8 +81,6 @@
static char buf[26];
static u_int64_t temp;
-double etime;
-static float hertz;
static int nintr;
static long *intrloc;
static char **intrname;
@@ -415,7 +414,6 @@
{temp = (s).fld; (s).fld -= (s1).fld; \
if (display_mode == TIME) (s1).fld = temp; \
putint((int)((float)(s).fld/etime + 0.5), l, c, w);}
-#define MAXFAIL 5
static char cpuchar[CPUSTATES] = { '=' , '>', '-', '%', ' ' };
static char cpuorder[CPUSTATES] = { CP_SYS, CP_USER, CP_NICE, CP_INTR, CP_IDLE };
@@ -483,7 +481,6 @@
static int failcnt = 0;
static int relabel = 0;
static int last_disks = 0;
- static char pigs[] = "pigs";
static u_long bufmem;
struct buf_sysctl *buffers;
int mib[6];
@@ -498,21 +495,8 @@
cpuswap();
if (display_mode == TIME) {
drvswap();
- etime = cur.cp_etime;
- /* < 5 ticks - ignore this trash */
- if ((etime * hertz) < 1.0) {
- if (failcnt++ <= MAXFAIL)
- return;
- clear();
- mvprintw(2, 10, "The alternate system clock has died!");
- mvprintw(3, 10, "Reverting to ``pigs'' display.");
- move(CMDLINE, 0);
- refresh();
- failcnt = 0;
- sleep(5);
- command(pigs);
+ if (toofast(&failcnt))
return;
- }
} else
etime = 1.0;
Home |
Main Index |
Thread Index |
Old Index