The checked criterion is loop-independent and we hold the lock necessary
to do the check also outside the loop. So, move that piece of code more
towards the end where the result is used.

Signed-off-by: Jan H. Schönherr <schn...@cs.tu-berlin.de>
---
 kernel/printk.c | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

diff --git a/kernel/printk.c b/kernel/printk.c
index 7328348..4f3c355 100644
--- a/kernel/printk.c
+++ b/kernel/printk.c
@@ -2060,10 +2060,6 @@ again:
                int level;
 
                raw_spin_lock_irqsave(&logbuf_lock, flags);
-               if (seen_seq != log_next_seq) {
-                       wake_klogd = true;
-                       seen_seq = log_next_seq;
-               }
 
                if (console_seq < log_first_seq) {
                        /* messages are gone, move to first one */
@@ -2124,6 +2120,10 @@ skip:
         */
        raw_spin_lock(&logbuf_lock);
        retry = console_seq != log_next_seq;
+       if (seen_seq != log_next_seq) {
+               wake_klogd = true;
+               seen_seq = log_next_seq;
+       }
        raw_spin_unlock_irqrestore(&logbuf_lock, flags);
 
        if (retry && console_trylock())
-- 
1.8.0.1.20.g7c65b2e.dirty

--
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/

Reply via email to