block: Make cfq_target_latency tunable through sysfs.
authorTao Ma <boyu.mt@taobao.com>
Sun, 1 Apr 2012 21:33:39 +0000 (14:33 -0700)
committerVarun Wadekar <vwadekar@nvidia.com>
Wed, 18 Apr 2012 15:00:34 +0000 (20:00 +0530)
commit49e4d4cf2713fb9e54751cb72979b58ce9818248
treee37a90d7552f4d9e437b550fb8294df5ca37d288
parent5366bef6a3ff3598d890527dcae8956c77c6f9a2
block: Make cfq_target_latency tunable through sysfs.

In cfq, when we calculate a time slice for a process(or a cfqq to
be precise), we have to consider the cfq_target_latency so that all the
sync request have an estimated latency(300ms) and it is controlled by
cfq_target_latency. But in some hadoop test, we have found that if
there are many processes doing sequential read(24 for example), the
throughput is bad because every process can only work for about 25ms
and the cfqq is switched. That leads to a higher disk seek. We can
achive the good throughput by setting low_latency=0, but then some
read's latency is too much for the application.

So this patch makes cfq_target_latency tunable through sysfs so that
we can tune it and find some magic number which is not bad for both
the throughput and the read latency.

Cc: Jens Axboe <axboe@kernel.dk>
Signed-off-by: Tao Ma <boyu.mt@taobao.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
block/cfq-iosched.c