All of lore.kernel.org
 help / color / mirror / Atom feed
From: sbradshaw@micron.com (Sam Bradshaw)
Subject: [PATCH] NVMe: Adhere to request queue block accounting enable/disable
Date: Fri, 9 May 2014 13:23:55 -0700	[thread overview]
Message-ID: <536D395B.9030305@micron.com> (raw)
In-Reply-To: <alpine.LRH.2.03.1405091403540.5666@AMR>

Ugh.  Too many trees to keep straight!

Thanks for pointing that out, will resend momentarily.

On 05/09/2014 01:05 PM, Keith Busch wrote:

> The diff looks like the inverse of what you meant to send. :)
> 
> On Fri, 9 May 2014, Sam Bradshaw wrote:
>> Recently, a new sysfs control "iostats" was added to selectively
>> enable or disable io statistics collection for request queues.  This
>> patch hooks that control.
>>
>> IO statistics collection is rather expensive on large, multi-node
>> machines with drives pushing millions of iops.  Having the ability to
>> disable collection if not needed can improve throughput significantly.
>>
>> As a data point, on a quad E5-4640, I see more than 50% throughput
>> improvement when io statistics accounting is disabled during heavily
>> multi-threaded small block random read benchmarks where device
>> performance is in the million iops+ range.
>>
>> Signed-off-by: Sam Bradshaw <sbradshaw at micron.com>
>> ---
>> diff --git a/drivers/block/nvme-core.c b/drivers/block/nvme-core.c
>> index 3a25502..cd8a8bc 100644
>> --- a/drivers/block/nvme-core.c
>> +++ b/drivers/block/nvme-core.c
>> @@ -383,30 +383,25 @@ void nvme_free_iod(struct nvme_dev *dev, struct
>> nvme_iod *iod)
>> static void nvme_start_io_acct(struct bio *bio)
>> {
>>     struct gendisk *disk = bio->bi_bdev->bd_disk;
>> -    if (blk_queue_io_stat(disk->queue)) {
>> -        const int rw = bio_data_dir(bio);
>> -        int cpu = part_stat_lock();
>> -        part_round_stats(cpu, &disk->part0);
>> -        part_stat_inc(cpu, &disk->part0, ios[rw]);
>> -        part_stat_add(cpu, &disk->part0, sectors[rw],
>> -                            bio_sectors(bio));
>> -        part_inc_in_flight(&disk->part0, rw);
>> -        part_stat_unlock();
>> -    }
>> +    const int rw = bio_data_dir(bio);
>> +    int cpu = part_stat_lock();
>> +    part_round_stats(cpu, &disk->part0);
>> +    part_stat_inc(cpu, &disk->part0, ios[rw]);
>> +    part_stat_add(cpu, &disk->part0, sectors[rw], bio_sectors(bio));
>> +    part_inc_in_flight(&disk->part0, rw);
>> +    part_stat_unlock();
>> }
>>
>> static void nvme_end_io_acct(struct bio *bio, unsigned long start_time)
>> {
>>     struct gendisk *disk = bio->bi_bdev->bd_disk;
>> -    if (blk_queue_io_stat(disk->queue)) {
>> -        const int rw = bio_data_dir(bio);
>> -        unsigned long duration = jiffies - start_time;
>> -        int cpu = part_stat_lock();
>> -        part_stat_add(cpu, &disk->part0, ticks[rw], duration);
>> -        part_round_stats(cpu, &disk->part0);
>> -        part_dec_in_flight(&disk->part0, rw);
>> -        part_stat_unlock();
>> -    }
>> +    const int rw = bio_data_dir(bio);
>> +    unsigned long duration = jiffies - start_time;
>> +    int cpu = part_stat_lock();
>> +    part_stat_add(cpu, &disk->part0, ticks[rw], duration);
>> +    part_round_stats(cpu, &disk->part0);
>> +    part_dec_in_flight(&disk->part0, rw);
>> +    part_stat_unlock();
>> }
>>
>> static void bio_completion(struct nvme_queue *nvmeq, void *ctx,

      reply	other threads:[~2014-05-09 20:23 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-05-09 20:10 [PATCH] NVMe: Adhere to request queue block accounting enable/disable Sam Bradshaw
2014-05-09 20:05 ` Keith Busch
2014-05-09 20:23   ` Sam Bradshaw [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=536D395B.9030305@micron.com \
    --to=sbradshaw@micron.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.