Re: [PATCH 4/5] printk: Minimize time zero output

From: Ingo Molnar
Date: Fri Feb 18 2011 - 02:34:17 EST



* Mike Travis <travis@xxxxxxx> wrote:

> Reduce the length for time zero messages by only printing "[0] ".
>
> v2: updated to apply to x86-tip
>
> Signed-off-by: Mike Travis <travis@xxxxxxx>
> Reviewed-by: Jack Steiner <steiner@xxxxxxx>
> Reviewed-by: Robin Holt <holt@xxxxxxx>
> ---
> kernel/printk.c | 8 +++++---
> 1 file changed, 5 insertions(+), 3 deletions(-)
>
> --- linux.orig/kernel/printk.c
> +++ linux/kernel/printk.c
> @@ -818,11 +818,13 @@ asmlinkage int vprintk(const char *fmt,
> unsigned long nanosec_rem;
>
> t = cpu_clock(printk_cpu);
> - nanosec_rem = do_div(t, 1000000000);
> - tlen = sprintf(tbuf, "[%5lu.%06lu] ",
> + if (likely(t)) {
> + nanosec_rem = do_div(t, 1000000000);
> + tlen = sprintf(tbuf, "[%5lu.%06lu] ",
> (unsigned long) t,
> nanosec_rem / 1000);

The excessive number of very ugly linebreaks in this statement should have told you
that the whole printk_time function wants to be broken out of vsprintk(), into a
helper function.

Please make it two patches: one cleanup-only patch that factors out the code, the
second one that modifies it materially.

Thanks,

Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/