diff options
| author | Poul-Henning Kamp <phk@FreeBSD.org> | 1999-11-29 11:29:04 +0000 |
|---|---|---|
| committer | Poul-Henning Kamp <phk@FreeBSD.org> | 1999-11-29 11:29:04 +0000 |
| commit | 8f04f6c729c7859869de928d7c592d0a6fc72700 (patch) | |
| tree | c02d9de311eee0fa512e7e3ee082476d5cd5ab67 /sys/kern/kern_resource.c | |
| parent | ab1c0de5edf8ed28315d8e8cd3d9a18c79647e0d (diff) | |
Notes
Diffstat (limited to 'sys/kern/kern_resource.c')
| -rw-r--r-- | sys/kern/kern_resource.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/sys/kern/kern_resource.c b/sys/kern/kern_resource.c index fde934e96169..495175ed935b 100644 --- a/sys/kern/kern_resource.c +++ b/sys/kern/kern_resource.c @@ -49,6 +49,7 @@ #include <sys/resourcevar.h> #include <sys/malloc.h> #include <sys/proc.h> +#include <sys/time.h> #include <vm/vm.h> #include <vm/vm_param.h> @@ -519,8 +520,13 @@ calcru(p, up, sp, ip) * quantum, which is much greater than the sampling error. */ microuptime(&tv); - tu += (tv.tv_usec - switchtime.tv_usec) + - (tv.tv_sec - switchtime.tv_sec) * (int64_t)1000000; + if (timevalcmp(&tv, &switchtime, <)) + printf("microuptime() went backwards (%ld.%06ld -> %ld,%06ld)\n", + switchtime.tv_sec, switchtime.tv_usec, + tv.tv_sec, tv.tv_usec); + else + tu += (tv.tv_usec - switchtime.tv_usec) + + (tv.tv_sec - switchtime.tv_sec) * (int64_t)1000000; } ptu = p->p_stats->p_uu + p->p_stats->p_su + p->p_stats->p_iu; if (tu < ptu || (int64_t)tu < 0) { |
