(Adding Kay to cc's) Kay? any opinion on correctness?
On Thu, 2014-01-02 at 14:55 -0800, Andrew Morton wrote: > On Wed, 1 Jan 2014 17:44:06 +0530 Arun KS <arunks.li...@gmail.com> wrote: > > > >From d751f9a0cb6329ae3171f6e1cb85e4a3aa792d73 Mon Sep 17 00:00:00 2001 > > From: Arun KS <arun...@broadcom.com> > > Date: Wed, 1 Jan 2014 17:24:46 +0530 > > Subject: printk: flush conflicting continuation line > > > > An earlier newline was missing and current print is from different task. > > In this scenario flush the continuation line and store this line seperatly. > > > > This patch fix the below scenario of timestamp interleaving, > > <6>[ 28.154370 ] read_word_reg : reg[0x 3], reg[0x 4] data [0x 642] > > <6>[ 28.155428 ] uart disconnect > > <6>[ 31.947341 ] dvfs[cpufreq.c<275>]:plug-in cpu<1> done > > <4>[ 28.155445 ] UART detached : send switch state 201 > > <6>[ 32.014112 ] read_reg : reg[0x 3] data[0x21] > > > > ... > > > > --- a/kernel/printk/printk.c > > +++ b/kernel/printk/printk.c > > @@ -1604,7 +1604,10 @@ asmlinkage int vprintk_emit(int facility, int level, > > if (!(lflags & LOG_PREFIX)) > > stored = cont_add(facility, level, text, text_len); > > cont_flush(LOG_NEWLINE); > > - } > > + /* Flush conflicting buffer. An earlier newline was missing > > + * and current print is from different task */ > > + } else if (cont.len && cont.owner != current) > > + cont_flush(LOG_NEWLINE); > > > > if (!stored) > > log_store(facility, level, lflags, 0, > > Your email client makes a horrid mess of the patches :( > > I *think* it's right. But the code can be significantly simplified and > optimised. Please review: > > } else { > bool stored = false; > > /* > * If an earlier newline was missing and it was the same task, > * either merge it with the current buffer and flush, or if > * there was a race with interrupts (prefix == true) then just > * flush it out and store this line separately. > * If the preceding printk was from a different task and missed > * a newline, flush and append the newline. > */ > if (cont.len) { > if (cont.owner == current && !(lflags & LOG_PREFIX)) > stored = cont_add(facility, level, text, > text_len); > cont_flush(LOG_NEWLINE); > } > > if (!stored) > log_store(facility, level, lflags, 0, > dict, dictlen, text, text_len); > } > > > > --- a/kernel/printk/printk.c~printk-flush-conflicting-continuation-line-fix > +++ a/kernel/printk/printk.c > @@ -1595,15 +1595,15 @@ asmlinkage int vprintk_emit(int facility > * either merge it with the current buffer and flush, or if > * there was a race with interrupts (prefix == true) then just > * flush it out and store this line separately. > + * If the preceding printk was from a different task and missed > + * a newline, flush and append the newline. > */ > - if (cont.len && cont.owner == current) { > - if (!(lflags & LOG_PREFIX)) > - stored = cont_add(facility, level, text, > text_len); > - cont_flush(LOG_NEWLINE); > - /* Flush conflicting buffer. An earlier newline was missing > - * and current print is from different task */ > - } else if (cont.len && cont.owner != current) > + if (cont.len) { > + if (cont.owner == current && !(lflags & LOG_PREFIX)) > + stored = cont_add(facility, level, text, > + text_len); > cont_flush(LOG_NEWLINE); > + } > > if (!stored) > log_store(facility, level, lflags, 0, > _ -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/