|
@@ -9,7 +9,7 @@
|
|
|
#ifdef CONFIG_TASK_IO_ACCOUNTING
|
|
|
static inline void task_io_account_read(size_t bytes)
|
|
|
{
|
|
|
- current->ioac.read_bytes += bytes;
|
|
|
+ current->ioac.blk.read_bytes += bytes;
|
|
|
}
|
|
|
|
|
|
/*
|
|
@@ -18,12 +18,12 @@ static inline void task_io_account_read(size_t bytes)
|
|
|
*/
|
|
|
static inline unsigned long task_io_get_inblock(const struct task_struct *p)
|
|
|
{
|
|
|
- return p->ioac.read_bytes >> 9;
|
|
|
+ return p->ioac.blk.read_bytes >> 9;
|
|
|
}
|
|
|
|
|
|
static inline void task_io_account_write(size_t bytes)
|
|
|
{
|
|
|
- current->ioac.write_bytes += bytes;
|
|
|
+ current->ioac.blk.write_bytes += bytes;
|
|
|
}
|
|
|
|
|
|
/*
|
|
@@ -32,17 +32,25 @@ static inline void task_io_account_write(size_t bytes)
|
|
|
*/
|
|
|
static inline unsigned long task_io_get_oublock(const struct task_struct *p)
|
|
|
{
|
|
|
- return p->ioac.write_bytes >> 9;
|
|
|
+ return p->ioac.blk.write_bytes >> 9;
|
|
|
}
|
|
|
|
|
|
static inline void task_io_account_cancelled_write(size_t bytes)
|
|
|
{
|
|
|
- current->ioac.cancelled_write_bytes += bytes;
|
|
|
+ current->ioac.blk.cancelled_write_bytes += bytes;
|
|
|
}
|
|
|
|
|
|
-static inline void task_io_accounting_init(struct task_struct *tsk)
|
|
|
+static inline void task_io_accounting_init(struct proc_io_accounting *ioac)
|
|
|
{
|
|
|
- memset(&tsk->ioac, 0, sizeof(tsk->ioac));
|
|
|
+ memset(ioac, 0, sizeof(*ioac));
|
|
|
+}
|
|
|
+
|
|
|
+static inline void task_blk_io_accounting_add(struct proc_io_accounting *dst,
|
|
|
+ struct proc_io_accounting *src)
|
|
|
+{
|
|
|
+ dst->blk.read_bytes += src->blk.read_bytes;
|
|
|
+ dst->blk.write_bytes += src->blk.write_bytes;
|
|
|
+ dst->blk.cancelled_write_bytes += src->blk.cancelled_write_bytes;
|
|
|
}
|
|
|
|
|
|
#else
|
|
@@ -69,9 +77,37 @@ static inline void task_io_account_cancelled_write(size_t bytes)
|
|
|
{
|
|
|
}
|
|
|
|
|
|
-static inline void task_io_accounting_init(struct task_struct *tsk)
|
|
|
+static inline void task_io_accounting_init(struct proc_io_accounting *ioac)
|
|
|
+{
|
|
|
+}
|
|
|
+
|
|
|
+static inline void task_blk_io_accounting_add(struct proc_io_accounting *dst,
|
|
|
+ struct proc_io_accounting *src)
|
|
|
{
|
|
|
}
|
|
|
|
|
|
-#endif /* CONFIG_TASK_IO_ACCOUNTING */
|
|
|
-#endif /* __TASK_IO_ACCOUNTING_OPS_INCLUDED */
|
|
|
+#endif /* CONFIG_TASK_IO_ACCOUNTING */
|
|
|
+
|
|
|
+#ifdef CONFIG_TASK_XACCT
|
|
|
+static inline void task_chr_io_accounting_add(struct proc_io_accounting *dst,
|
|
|
+ struct proc_io_accounting *src)
|
|
|
+{
|
|
|
+ dst->chr.rchar += src->chr.rchar;
|
|
|
+ dst->chr.wchar += src->chr.wchar;
|
|
|
+ dst->chr.syscr += src->chr.syscr;
|
|
|
+ dst->chr.syscw += src->chr.syscw;
|
|
|
+}
|
|
|
+#else
|
|
|
+static inline void task_chr_io_accounting_add(struct proc_io_accounting *dst,
|
|
|
+ struct proc_io_accounting *src)
|
|
|
+{
|
|
|
+}
|
|
|
+#endif /* CONFIG_TASK_XACCT */
|
|
|
+
|
|
|
+static inline void task_io_accounting_add(struct proc_io_accounting *dst,
|
|
|
+ struct proc_io_accounting *src)
|
|
|
+{
|
|
|
+ task_chr_io_accounting_add(dst, src);
|
|
|
+ task_blk_io_accounting_add(dst, src);
|
|
|
+}
|
|
|
+#endif /* __TASK_IO_ACCOUNTING_OPS_INCLUDED */
|