Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit d3620822 authored by Steven Rostedt's avatar Steven Rostedt Committed by Greg Kroah-Hartman
Browse files

printk: Optimize if statement logic where newline exists

In reviewing Kay's fix up patch: "printk: Have printk() never buffer its
data", I found two if statements that could be combined and optimized.

Put together the two 'cont.len && cont.owner == current' if statements
into a single one, and check if we need to call cont_add(). This also
removes the unneeded double cont_flush() calls.

Link: http://lkml.kernel.org/r/1340869133.876.10.camel@mop



Signed-off-by: default avatarSteven Rostedt <rostedt@goodmis.org>
Cc: Kay Sievers <kay@vrfy.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 084681d1
Loading
Loading
Loading
Loading
+6 −7
Original line number Original line Diff line number Diff line
@@ -1496,14 +1496,13 @@ asmlinkage int vprintk_emit(int facility, int level,
		bool stored = false;
		bool stored = false;


		/*
		/*
		 * Flush the conflicting buffer. An earlier newline was missing,
		 * If an earlier newline was missing and it was the same task,
		 * or we race with a continuation line from an interrupt.
		 * 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 (cont.len && prefix && cont.owner == current)
			cont_flush();

		/* Merge with our buffer if possible; flush it in any case */
		if (cont.len && cont.owner == current) {
		if (cont.len && cont.owner == current) {
			if (!prefix)
				stored = cont_add(facility, level, text, text_len);
				stored = cont_add(facility, level, text, text_len);
			cont_flush();
			cont_flush();
		}
		}