Skip to content

Commit

Permalink
[PATCH] delay accounting: temporarily enable by default
Browse files Browse the repository at this point in the history
Enable delay accounting by default so that feature gets coverage testing
without requiring special measures.

Earlier, it was off by default and had to be enabled via a boot time param.
 This patch reverses the default behaviour to improve coverage testing.  It
can be removed late in the kernel development cycle if its believed users
shouldn't have to incur any cost if they don't want delay accounting.  Or
it can be retained forever if the utility of the stats is deemed common
enough to warrant keeping the feature on.

Signed-off-by: Shailabh Nagar <nagar@watson.ibm.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
  • Loading branch information
Shailabh Nagar authored and Linus Torvalds committed Jul 31, 2006
1 parent d94a041 commit 163ecdf
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 12 deletions.
10 changes: 6 additions & 4 deletions Documentation/accounting/delay-accounting.txt
Original file line number Diff line number Diff line change
Expand Up @@ -64,11 +64,13 @@ Compile the kernel with
CONFIG_TASK_DELAY_ACCT=y
CONFIG_TASKSTATS=y

Enable the accounting at boot time by adding
the following to the kernel boot options
delayacct
Delay accounting is enabled by default at boot up.
To disable, add
nodelayacct
to the kernel boot options. The rest of the instructions
below assume this has not been done.

and after the system has booted up, use a utility
After the system has booted up, use a utility
similar to getdelays.c to access the delays
seen by a given task or a task group (tgid).
The utility also allows a given command to be
Expand Down
4 changes: 2 additions & 2 deletions Documentation/kernel-parameters.txt
Original file line number Diff line number Diff line change
Expand Up @@ -448,8 +448,6 @@ running once the system is up.
Format: <area>[,<node>]
See also Documentation/networking/decnet.txt.

delayacct [KNL] Enable per-task delay accounting

dhash_entries= [KNL]
Set number of hash buckets for dentry cache.

Expand Down Expand Up @@ -1031,6 +1029,8 @@ running once the system is up.

nocache [ARM]

nodelayacct [KNL] Disable per-task delay accounting

nodisconnect [HW,SCSI,M68K] Disables SCSI disconnects.

noexec [IA-64]
Expand Down
4 changes: 2 additions & 2 deletions include/linux/delayacct.h
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ static inline void delayacct_tsk_init(struct task_struct *tsk)
{
/* reinitialize in case parent's non-null pointer was dup'ed*/
tsk->delays = NULL;
if (unlikely(delayacct_on))
if (delayacct_on)
__delayacct_tsk_init(tsk);
}

Expand All @@ -80,7 +80,7 @@ static inline void delayacct_blkio_end(void)
static inline int delayacct_add_tsk(struct taskstats *d,
struct task_struct *tsk)
{
if (likely(!delayacct_on) || !tsk->delays)
if (!delayacct_on || !tsk->delays)
return 0;
return __delayacct_add_tsk(d, tsk);
}
Expand Down
8 changes: 4 additions & 4 deletions kernel/delayacct.c
Original file line number Diff line number Diff line change
Expand Up @@ -19,15 +19,15 @@
#include <linux/sysctl.h>
#include <linux/delayacct.h>

int delayacct_on __read_mostly; /* Delay accounting turned on/off */
int delayacct_on __read_mostly = 1; /* Delay accounting turned on/off */
kmem_cache_t *delayacct_cache;

static int __init delayacct_setup_enable(char *str)
static int __init delayacct_setup_disable(char *str)
{
delayacct_on = 1;
delayacct_on = 0;
return 1;
}
__setup("delayacct", delayacct_setup_enable);
__setup("nodelayacct", delayacct_setup_disable);

void delayacct_init(void)
{
Expand Down

0 comments on commit 163ecdf

Please sign in to comment.