static DEFINE_PER_CPU(unsigned long, watchdog_report_ts);
 static DEFINE_PER_CPU(struct hrtimer, watchdog_hrtimer);
 static DEFINE_PER_CPU(bool, softlockup_touch_sync);
-static DEFINE_PER_CPU(bool, soft_watchdog_warn);
 static DEFINE_PER_CPU(unsigned long, hrtimer_interrupts);
 static DEFINE_PER_CPU(unsigned long, hrtimer_interrupts_saved);
 static unsigned long soft_lockup_nmi_warn;
                if (kvm_check_and_clear_guest_paused())
                        return HRTIMER_RESTART;
 
-               /* only warn once */
-               if (__this_cpu_read(soft_watchdog_warn) == true)
-                       return HRTIMER_RESTART;
-
                if (softlockup_all_cpu_backtrace) {
                        /* Prevent multiple soft-lockup reports if one cpu is already
                         * engaged in dumping cpu back traces
                         */
-                       if (test_and_set_bit(0, &soft_lockup_nmi_warn)) {
-                               /* Someone else will report us. Let's give up */
-                               __this_cpu_write(soft_watchdog_warn, true);
+                       if (test_and_set_bit(0, &soft_lockup_nmi_warn))
                                return HRTIMER_RESTART;
-                       }
                }
 
                /* Start period for the next softlockup warning. */
                add_taint(TAINT_SOFTLOCKUP, LOCKDEP_STILL_OK);
                if (softlockup_panic)
                        panic("softlockup: hung tasks");
-               __this_cpu_write(soft_watchdog_warn, true);
-       } else
-               __this_cpu_write(soft_watchdog_warn, false);
+       }
 
        return HRTIMER_RESTART;
 }