Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757370Ab2FYQxa (ORCPT ); Mon, 25 Jun 2012 12:53:30 -0400 Received: from perches-mx.perches.com ([206.117.179.246]:33233 "EHLO labridge.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1757184Ab2FYQx3 (ORCPT ); Mon, 25 Jun 2012 12:53:29 -0400 Message-ID: <1340643208.26404.13.camel@joe2Laptop> Subject: Re: [PATCH] printk: Add printk_flush() to force buffered text to console From: Joe Perches To: Ingo Molnar Cc: Andrew Morton , Steven Rostedt , LKML , Linus Torvalds , Greg Kroah-Hartman , "kay.sievers" , Fengguang Wu , Ingo Molnar Date: Mon, 25 Jun 2012 09:53:28 -0700 In-Reply-To: <20120625084545.GC24512@gmail.com> References: <1340322723.27036.220.camel@gandalf.stny.rr.com> <20120622145402.8047a669.akpm@linux-foundation.org> <20120623061313.GA21895@gmail.com> <1340437465.2274.5.camel@joe2Laptop> <20120625084545.GC24512@gmail.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.2.2- Content-Transfer-Encoding: 7bit Mime-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1965 Lines: 65 On Mon, 2012-06-25 at 10:45 +0200, Ingo Molnar wrote: > * Joe Perches wrote: > > > On Sat, 2012-06-23 at 08:13 +0200, Ingo Molnar wrote: > > > * Andrew Morton wrote: > > > > > > > On Thu, 21 Jun 2012 19:52:03 -0400 > > > > Steven Rostedt wrote: > > > > > > > > > But with the new printk() changes, text without a newline > > > > > gets buffered and does not print out to the console at the > > > > > location of the printk. > > > > > > > > uh, how about we fix that? The old behaviour was good, the > > > > new behaviour is noxious. > > > > > > Absolutely. > > > > > > pr_flush() really seems to be a workaround. > > > > I think the new behavior an overall improvement. > > It helps avoid multiple thread interleaving. > > > > I suggested a fix to enable a printk buffered/non-buffered > > mechanism with an optional printk_flush/pr_flush. > > > > https://lkml.org/lkml/2012/6/21/305 > > Ugh, so you suggest a global toggle to turn buffering on/off? Rather than adding a bunch of printk_flush() calls around the possibly many sites per file that need them, I'd rather see a code block surrounded by buffer(false)/buffer(true). I'd actually rather see the existing partial line uses like: printk("doing test_func: "); printk("%s\n", test_func(foo) ? "successful", "failed"); and printk("step 1") bar(); printk(" - step 2"); baz(); printk("completed\n"); changed to whole lines rather than adding a bunch of printk_flush() sites or the printk_buffering(on|off) blocks. Anyway, I suggested it shouldn't be merged awhile ago. https://lkml.org/lkml/2012/5/22/439 Making systemic printk changes is a slow business. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/