summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbrian <brian@cvs.openbsd.org>1999-05-12 19:11:07 +0000
committerbrian <brian@cvs.openbsd.org>1999-05-12 19:11:07 +0000
commitc5f811de8dd1ee9290c880b3ba509a5b4dfd092f (patch)
treef419ac1ee7b39d534f4f7a186602a414dcca5e90
parentf5297990a67873f9cbd0e5995d34e959638ca275 (diff)
Adjust our first timer delta according to the return
from getitimer() so that times are correct for ``show timer''.
-rw-r--r--usr.sbin/ppp/ppp/timer.c17
1 files changed, 12 insertions, 5 deletions
diff --git a/usr.sbin/ppp/ppp/timer.c b/usr.sbin/ppp/ppp/timer.c
index 43f30b8193f..f631ac2a42a 100644
--- a/usr.sbin/ppp/ppp/timer.c
+++ b/usr.sbin/ppp/ppp/timer.c
@@ -17,7 +17,7 @@
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
* WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
*
- * $Id: timer.c,v 1.4 1999/05/09 20:04:04 brian Exp $
+ * $Id: timer.c,v 1.5 1999/05/12 19:11:06 brian Exp $
*
* TODO:
*/
@@ -25,6 +25,7 @@
#include <errno.h>
#include <signal.h>
#include <stdio.h>
+#include <string.h>
#include <sys/time.h>
#include <termios.h>
@@ -189,13 +190,19 @@ TimerService(void)
void
timer_Show(int LogLevel, struct prompt *prompt)
{
+ struct itimerval itimer;
struct pppTimer *pt;
- int rest = 0;
+ u_long rest = 0;
+
+ /* Adjust our first delta so that it reflects what's really happening */
+ if (TimerList && getitimer(ITIMER_REAL, &itimer) == 0)
+ TimerList->rest = itimer.it_value.tv_sec * SECTICKS +
+ itimer.it_value.tv_usec / TICKUNIT;
#define SECS(val) ((val) / SECTICKS)
#define HSECS(val) (((val) % SECTICKS) * 100 / SECTICKS)
#define DISP \
- "%s timer[%p]: freq = %ld.%02lds, next = %d.%02ds, state = %s\n", \
+ "%s timer[%p]: freq = %ld.%02lds, next = %lu.%02lus, state = %s\n", \
pt->name, pt, SECS(pt->load), HSECS(pt->load), SECS(rest), \
HSECS(rest), tState2Nam(pt->state)
@@ -227,7 +234,7 @@ timer_InitService(int restart)
itimer.it_value.tv_sec = TimerList->rest / SECTICKS;
itimer.it_value.tv_usec = (TimerList->rest % SECTICKS) * TICKUNIT;
if (setitimer(ITIMER_REAL, &itimer, NULL) == -1)
- log_Printf(LogERROR, "Unable to set itimer (%s)\n", sys_errlist[errno]);
+ log_Printf(LogERROR, "Unable to set itimer (%s)\n", strerror(errno));
}
}
@@ -239,6 +246,6 @@ timer_TermService(void)
itimer.it_interval.tv_usec = itimer.it_interval.tv_sec = 0;
itimer.it_value.tv_usec = itimer.it_value.tv_sec = 0;
if (setitimer(ITIMER_REAL, &itimer, NULL) == -1)
- log_Printf(LogERROR, "Unable to set itimer (%s)\n", sys_errlist[errno]);
+ log_Printf(LogERROR, "Unable to set itimer (%s)\n", strerror(errno));
sig_signal(SIGALRM, SIG_IGN);
}