mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-06-23 15:11:16 +00:00
[PATCH] per-task-delay-accounting: sync block I/O and swapin delay collection
Unlike earlier iterations of the delay accounting patches, now delays are only collected for the actual I/O waits rather than try and cover the delays seen in I/O submission paths. Account separately for block I/O delays incurred as a result of swapin page faults whose frequency can be affected by the task/process' rss limit. Hence swapin delays can act as feedback for rss limit changes independent of I/O priority changes. Signed-off-by: Shailabh Nagar <nagar@watson.ibm.com> Signed-off-by: Balbir Singh <balbir@in.ibm.com> Cc: Jes Sorensen <jes@sgi.com> Cc: Peter Chubb <peterc@gelato.unsw.edu.au> Cc: Erich Focht <efocht@ess.nec.de> Cc: Levent Serinol <lserinol@gmail.com> Cc: Jay Lan <jlan@engr.sgi.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
ca74e92b46
commit
0ff922452d
5 changed files with 66 additions and 0 deletions
|
@ -51,6 +51,7 @@
|
|||
#include <linux/times.h>
|
||||
#include <linux/acct.h>
|
||||
#include <linux/kprobes.h>
|
||||
#include <linux/delayacct.h>
|
||||
#include <asm/tlb.h>
|
||||
|
||||
#include <asm/unistd.h>
|
||||
|
@ -4534,9 +4535,11 @@ void __sched io_schedule(void)
|
|||
{
|
||||
struct rq *rq = &__raw_get_cpu_var(runqueues);
|
||||
|
||||
delayacct_blkio_start();
|
||||
atomic_inc(&rq->nr_iowait);
|
||||
schedule();
|
||||
atomic_dec(&rq->nr_iowait);
|
||||
delayacct_blkio_end();
|
||||
}
|
||||
EXPORT_SYMBOL(io_schedule);
|
||||
|
||||
|
@ -4545,9 +4548,11 @@ long __sched io_schedule_timeout(long timeout)
|
|||
struct rq *rq = &__raw_get_cpu_var(runqueues);
|
||||
long ret;
|
||||
|
||||
delayacct_blkio_start();
|
||||
atomic_inc(&rq->nr_iowait);
|
||||
ret = schedule_timeout(timeout);
|
||||
atomic_dec(&rq->nr_iowait);
|
||||
delayacct_blkio_end();
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue