csa
[Top] [All Lists]

[PATCH 2.6.8.1 1/4] CSA csa_io: accounting IO data gathering

To: LKML <linux-kernel@xxxxxxxxxxxxxxx>
Subject: [PATCH 2.6.8.1 1/4] CSA csa_io: accounting IO data gathering
From: Jay Lan <jlan@xxxxxxxxxxxx>
Date: Thu, 09 Sep 2004 12:06:58 -0700
Cc: Andrew Morton <akpm@xxxxxxxx>, lse-tech <lse-tech@xxxxxxxxxxxxxxxxxxxxx>, Guillaume Thouvenin <guillaume.thouvenin@xxxxxxxx>, CSA-ML <csa@xxxxxxxxxxx>, Arthur Corliss <corliss@xxxxxxxxxxxxxxxx>, Tim Schmielau <tim@xxxxxxxxxxxxxxxxxxxxxx>, Erik Jacobson <erikj@xxxxxxxxxxxxxxxxxx>, Limin Gu <limin@xxxxxxxxxxxx>, John Hesterberg <jh@xxxxxxx>
Sender: csa-bounce@xxxxxxxxxxx
User-agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.2.1) Gecko/20030225
Linux Comprehensive System Accounting (CSA) is a set of C programs and
shell scripts that, like other accounting packages, provide methods for
collecting per-process resource usage data, monitoring disk usage, and
charging fees to specific login accounts.

The CSA patchset includes csa_io, csa_mm, csa_eop and csa_module.
Patches csa_io, csa_mm, and csa_eop are responsible for system
accounting data collection and are independent of each other.

The csa_io is a patch that gathers I/O activity data.

Please find CSA project at http://oss.sgi.com/projects/csa. This set of
csa patches has been tested with the pagg and job kernel patches.
The information of pagg and job project can be found at
http://oss.sgi.com/projects/pagg/


Signed-off-by: Jay Lan <jlan@xxxxxxx>
Index: linux/drivers/block/ll_rw_blk.c
===================================================================
--- linux.orig/drivers/block/ll_rw_blk.c        2004-08-13 22:36:16.000000000 
-0700
+++ linux/drivers/block/ll_rw_blk.c     2004-09-03 17:15:06.000000000 -0700
@@ -1674,6 +1674,7 @@
 {
        DEFINE_WAIT(wait);
        struct request *rq;
+       unsigned long start_wait = jiffies;
 
        generic_unplug_device(q);
        do {
@@ -1702,6 +1703,7 @@
                finish_wait(&rl->wait[rw], &wait);
        } while (!rq);
 
+       current->bwtime += (unsigned long) jiffies - start_wait;
        return rq;
 }
 
Index: linux/fs/read_write.c
===================================================================
--- linux.orig/fs/read_write.c  2004-08-13 22:37:15.000000000 -0700
+++ linux/fs/read_write.c       2004-09-03 12:59:18.000000000 -0700
@@ -216,8 +216,11 @@
                                ret = file->f_op->read(file, buf, count, pos);
                        else
                                ret = do_sync_read(file, buf, count, pos);
-                       if (ret > 0)
+                       if (ret > 0) {
                                dnotify_parent(file->f_dentry, DN_ACCESS);
+                               current->rchar += ret;
+                       }
+                       current->syscr++;
                }
        }
 
@@ -260,8 +263,11 @@
                                ret = file->f_op->write(file, buf, count, pos);
                        else
                                ret = do_sync_write(file, buf, count, pos);
-                       if (ret > 0)
+                       if (ret > 0) {
                                dnotify_parent(file->f_dentry, DN_MODIFY);
+                               current->wchar += ret;
+                       }
+                       current->syscw++;
                }
        }
 
@@ -540,6 +546,10 @@
                fput_light(file, fput_needed);
        }
 
+       if (ret > 0) {
+               current->rchar += ret;
+       }
+       current->syscr++;
        return ret;
 }
 
@@ -558,6 +568,10 @@
                fput_light(file, fput_needed);
        }
 
+       if (ret > 0) {
+               current->wchar += ret;
+       }
+       current->syscw++;
        return ret;
 }
 
@@ -636,6 +650,13 @@
 
        retval = in_file->f_op->sendfile(in_file, ppos, count, file_send_actor, 
out_file);
 
+       if (retval > 0) {
+               current->rchar += retval;
+               current->wchar += retval;
+       }
+       current->syscr++;
+       current->syscw++;
+
        if (*ppos > max)
                retval = -EOVERFLOW;
 
Index: linux/kernel/fork.c
===================================================================
--- linux.orig/kernel/fork.c    2004-09-03 12:59:18.000000000 -0700
+++ linux/kernel/fork.c 2004-09-03 16:21:20.000000000 -0700
@@ -964,6 +964,8 @@
 
        p->utime = p->stime = 0;
        p->cutime = p->cstime = 0;
+       p->rchar = p->wchar = p->syscr = p->syscw = 0;
+       p->bwtime = 0;
        p->lock_depth = -1;             /* -1 = no lock */
        p->start_time = get_jiffies_64();
        p->security = NULL;
Index: linux/include/linux/sched.h
===================================================================
--- linux.orig/include/linux/sched.h    2004-09-03 12:59:18.000000000 -0700
+++ linux/include/linux/sched.h 2004-09-03 16:18:31.000000000 -0700
@@ -523,6 +523,9 @@
        unsigned long ptrace_message;
        siginfo_t *last_siginfo; /* For ptrace use.  */
 
+/* i/o counters(bytes read/written, #syscalls, waittime */
+        unsigned long rchar, wchar, syscr, syscw, bwtime;
+
 #ifdef CONFIG_NUMA
        struct mempolicy *mempolicy;
        short il_next;          /* could be shared with used_math */
<Prev in Thread] Current Thread [Next in Thread>