Re: [Patch 7/8] Enhanced partition statistics: procfs

From: Randy Dunlap
Date: Thu Dec 13 2007 - 12:12:54 EST


On Thu, 13 Dec 2007 17:18:04 +0100 Jerome Marchand wrote:

> Reports enhanced partition statistics in /proc/diskstats.

> Signed-off-by: Jerome Marchand <jmarchan@xxxxxxxxxx>
> ---
> genhd.c | 27 +++++++++++++++++++++------
> 1 file changed, 21 insertions(+), 6 deletions(-)
> diff -urNp -X linux-2.6/Documentation/dontdiff linux-2.6.orig/block/genhd.c linux-2.6/block/genhd.c
> --- linux-2.6.orig/block/genhd.c 2007-12-04 17:37:31.000000000 +0100
> +++ linux-2.6/block/genhd.c 2007-12-05 13:52:55.000000000 +0100
> @@ -655,12 +655,27 @@ static int diskstats_show(struct seq_fil
> for (n = 0; n < gp->minors - 1; n++) {
> struct hd_struct *hd = gp->part[n];
>
> - if (hd && hd->nr_sects)
> - seq_printf(s, "%4d %4d %s %u %u %u %u\n",
> - gp->major, n + gp->first_minor + 1,
> - disk_name(gp, n + 1, buf),
> - hd->ios[0], hd->sectors[0],
> - hd->ios[1], hd->sectors[1]);
> + if (!hd || !hd->nr_sects) continue;

Don't put if () and following statement on same line.

> +
> + preempt_disable();
> + part_round_stats(hd);
> + preempt_enable();
> + seq_printf(s, "%4d %4d %s %lu %lu %llu "
> + "%u %lu %lu %llu %u %u %u %u\n",
> + gp->major, n + gp->first_minor + 1,
> + disk_name(gp, n + 1, buf),
> + part_stat_read(hd, ios[0]),
> + part_stat_read(hd, merges[0]),
> + (unsigned long long)part_stat_read(hd, sectors[0]),
> + jiffies_to_msecs(part_stat_read(hd, ticks[0])),
> + part_stat_read(hd, ios[1]),
> + part_stat_read(hd, merges[1]),
> + (unsigned long long)part_stat_read(hd, sectors[1]),
> + jiffies_to_msecs(part_stat_read(hd, ticks[1])),
> + hd->in_flight,
> + jiffies_to_msecs(part_stat_read(hd, io_ticks)),
> + jiffies_to_msecs(part_stat_read(hd, time_in_queue))
> + );
> }
>
> return 0;
>
> --

The format of the /proc file is not changed except to add data
at the end of each line. Is that correct?

---
~Randy
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/