Poul-Henning Kamp 7194d335cf Run a revision of the devstat interface:
Kernel:

Change statistics to use the *uptime() timescale (ie: relative to
boottime) rather than the UTC aligned timescale.  This makes the
device statistics code oblivious to clock steps.

Change timestamps to bintime format, they are cheaper.

Remove the "busy_count", and replace it with two counter fields:
"start_count" and "end_count", which are updated in the down and
up paths respectively.  This removes the locking constraint on
devstat.

Add a timestamp argument to devstat_start_transaction(), this will
normally be a timestamp set by the *_bio() function in bp->bio_t0.
Use this field to calculate duration of I/O operations.

Add two timestamp arguments to devstat_end_transaction(), one is
the current time, a NULL pointer means "take timestamp yourself",
the other is the timestamp of when this transaction started (see
above).

Change calculation of busy_time to operate on "the salami principle":
Only when we are idle, which we can determine by the start+end
counts being identical, do we update the "busy_from" field in the
down path.  In the up path we accumulate the timeslice in busy_time
and update busy_from.

Change the byte_* and num_* fields into two arrays: bytes[] and
operations[].

Userland:

Change the misleading "busy_time" name to be called "snap_time" and
make the time long double since that is what most users need anyway,
fill it using clock_gettime(CLOCK_MONOTONIC) to put it on the same
timescale as the kernel fields.

Change devstat_compute_etime() to operate on struct bintime.

Remove the version 2 legacy interface: the change to bintime makes
compatibility far too expensive.

Fix a bug in systat's "vm" page where boot relative busy times would
be bogus.

Bump __FreeBSD_version to 500107

Review & Collaboration by:	ken
2003-03-15 21:59:06 +00:00
..
2002-07-17 15:35:31 +00:00
2002-07-14 18:23:22 +00:00
2002-07-14 18:23:22 +00:00
2002-05-30 13:33:59 +00:00
2003-02-28 21:04:17 +00:00
2002-03-22 01:22:50 +00:00
2002-09-04 23:29:10 +00:00
2002-12-12 13:26:32 +00:00
2002-02-01 16:33:40 +00:00
2003-01-04 17:09:27 +00:00
2002-12-11 17:26:53 +00:00
2002-12-30 09:46:58 +00:00
2002-09-04 23:29:10 +00:00
2002-11-26 17:33:37 +00:00
2002-08-14 11:38:30 +00:00
2002-11-26 17:33:37 +00:00
2002-11-26 10:51:47 +00:00
2003-03-03 11:51:30 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2002-11-26 10:57:57 +00:00
2002-06-30 05:25:07 +00:00
2003-03-12 14:37:01 +00:00
2002-06-30 05:25:07 +00:00
2002-06-30 05:25:07 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2002-06-30 05:25:07 +00:00
2002-06-15 09:42:17 +00:00
2002-12-27 12:15:40 +00:00
2003-02-04 18:26:08 +00:00
2002-09-04 23:29:10 +00:00
2002-12-05 08:50:00 +00:00
2002-09-04 23:29:10 +00:00
2002-06-30 05:25:07 +00:00
2002-11-26 11:25:04 +00:00
2002-06-30 05:25:07 +00:00
2002-06-30 05:25:07 +00:00
2002-06-30 05:25:07 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2002-12-27 12:15:40 +00:00
2003-02-04 18:26:08 +00:00
2003-02-03 04:15:53 +00:00
2002-09-04 23:29:10 +00:00
2002-12-27 12:15:40 +00:00
2002-09-04 23:29:10 +00:00
2002-12-27 12:15:40 +00:00
2002-07-16 05:38:26 +00:00
2002-09-04 23:29:10 +00:00
2002-07-14 15:12:00 +00:00
2002-12-27 12:15:40 +00:00
2002-08-19 03:07:56 +00:00
2002-07-14 18:23:22 +00:00
2002-04-20 12:18:28 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2002-03-22 01:42:45 +00:00
2002-09-04 23:29:10 +00:00
2002-04-20 12:18:28 +00:00
2002-04-20 12:18:28 +00:00
2002-11-26 17:33:37 +00:00
2002-04-20 12:18:28 +00:00
2002-12-27 12:15:40 +00:00
2002-09-04 23:29:10 +00:00
2002-11-26 17:33:37 +00:00
2002-12-27 12:15:40 +00:00
2002-12-24 13:41:48 +00:00
2003-02-16 14:13:23 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2002-03-22 01:42:45 +00:00
2003-02-20 15:09:52 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2003-02-24 22:53:26 +00:00
2002-11-26 17:33:37 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2002-09-04 23:29:10 +00:00
2003-02-21 08:46:44 +00:00
2002-11-26 17:33:37 +00:00
2002-11-26 17:33:37 +00:00
2002-12-30 09:48:40 +00:00
2003-02-24 17:10:32 +00:00
2002-09-04 23:29:10 +00:00
2002-04-20 12:18:28 +00:00
2002-04-20 12:18:28 +00:00
2002-04-20 12:18:28 +00:00