From dbb69e525e073474073e02b8abea6484442fcda9 Mon Sep 17 00:00:00 2001 From: Brian Somers Date: Fri, 6 Aug 1999 01:34:03 +0000 Subject: [PATCH] If the clock is put back, ensure that we don't end up dividing by zero when calculating our throughput --- usr.sbin/ppp/throughput.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/usr.sbin/ppp/throughput.c b/usr.sbin/ppp/throughput.c index dd1b24f8bf6..af3b09a8a24 100644 --- a/usr.sbin/ppp/throughput.c +++ b/usr.sbin/ppp/throughput.c @@ -23,7 +23,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: throughput.c,v 1.9 1999/05/08 11:07:47 brian Exp $ + * $Id: throughput.c,v 1.10 1999/08/05 10:32:15 brian Exp $ */ #include @@ -75,6 +75,15 @@ throughput_uptime(struct pppThroughput *t) time_t downat; downat = t->downtime ? t->downtime : time(NULL); + if (t->uptime && downat < t->uptime) { + /* Euch ! The clock's gone back ! */ + int i; + + for (i = 0; i < t->SamplePeriod; i++) + t->SampleOctets[i] = 0; + t->nSample = 0; + t->uptime = downat; + } return t->uptime ? downat - t->uptime : 0; }