| Andrew Morton | 7c3ab73 | 2006-12-10 02:19:19 -0800 | [diff] [blame] | 1 | /* | 
| Andrea Righi | 940389b | 2008-07-28 00:48:12 +0200 | [diff] [blame] | 2 | * task_io_accounting: a structure which is used for recording a single task's | 
| Andrew Morton | 7c3ab73 | 2006-12-10 02:19:19 -0800 | [diff] [blame] | 3 | * IO statistics. | 
|  | 4 | * | 
|  | 5 | * Don't include this header file directly - it is designed to be dragged in via | 
|  | 6 | * sched.h. | 
|  | 7 | * | 
| Francois Cami | e1f8e87 | 2008-10-15 22:01:59 -0700 | [diff] [blame] | 8 | * Blame Andrew Morton for all this. | 
| Andrew Morton | 7c3ab73 | 2006-12-10 02:19:19 -0800 | [diff] [blame] | 9 | */ | 
|  | 10 |  | 
| Andrea Righi | 940389b | 2008-07-28 00:48:12 +0200 | [diff] [blame] | 11 | struct task_io_accounting { | 
| Andrea Righi | 5995477 | 2008-07-27 17:29:15 +0200 | [diff] [blame] | 12 | #ifdef CONFIG_TASK_XACCT | 
| Andrea Righi | 5995477 | 2008-07-27 17:29:15 +0200 | [diff] [blame] | 13 | /* bytes read */ | 
|  | 14 | u64 rchar; | 
|  | 15 | /*  bytes written */ | 
|  | 16 | u64 wchar; | 
|  | 17 | /* # of read syscalls */ | 
|  | 18 | u64 syscr; | 
|  | 19 | /* # of write syscalls */ | 
|  | 20 | u64 syscw; | 
| Andrea Righi | 5995477 | 2008-07-27 17:29:15 +0200 | [diff] [blame] | 21 | #endif /* CONFIG_TASK_XACCT */ | 
|  | 22 |  | 
| Andrew Morton | 7c3ab73 | 2006-12-10 02:19:19 -0800 | [diff] [blame] | 23 | #ifdef CONFIG_TASK_IO_ACCOUNTING | 
| Andrew Morton | 7c3ab73 | 2006-12-10 02:19:19 -0800 | [diff] [blame] | 24 | /* | 
|  | 25 | * The number of bytes which this task has caused to be read from | 
|  | 26 | * storage. | 
|  | 27 | */ | 
|  | 28 | u64 read_bytes; | 
|  | 29 |  | 
|  | 30 | /* | 
|  | 31 | * The number of bytes which this task has caused, or shall cause to be | 
|  | 32 | * written to disk. | 
|  | 33 | */ | 
|  | 34 | u64 write_bytes; | 
|  | 35 |  | 
|  | 36 | /* | 
|  | 37 | * A task can cause "negative" IO too.  If this task truncates some | 
|  | 38 | * dirty pagecache, some IO which another task has been accounted for | 
|  | 39 | * (in its write_bytes) will not be happening.  We _could_ just | 
|  | 40 | * subtract that from the truncating task's write_bytes, but there is | 
|  | 41 | * information loss in doing that. | 
|  | 42 | */ | 
|  | 43 | u64 cancelled_write_bytes; | 
| Andrea Righi | 5995477 | 2008-07-27 17:29:15 +0200 | [diff] [blame] | 44 | #endif /* CONFIG_TASK_IO_ACCOUNTING */ | 
| Andrea Righi | 5995477 | 2008-07-27 17:29:15 +0200 | [diff] [blame] | 45 | }; |