1. 13 7月, 2018 27 次提交
  2. 27 6月, 2018 3 次提交
    • P
      rcu: Exclude near-simultaneous RCU CPU stall warnings · 8c42b1f3
      Paul E. McKenney 提交于
      There is a two-jiffy delay between the time that a CPU will self-report
      an RCU CPU stall warning and the time that some other CPU will report a
      warning on behalf of the first CPU.  This has worked well in the past,
      but on busy systems, it is possible for the two warnings to overlap,
      which makes interpreting them extremely difficult.
      
      This commit therefore uses a cmpxchg-based timing decision that
      allows only one report in a given one-minute period (assuming default
      stall-warning Kconfig parameters).  This approach will of course fail
      if you are seeing minute-long vCPU preemption, but in that case the
      overlapping RCU CPU stall warnings are the least of your worries.
      Reported-by: NDmitry Vyukov <dvyukov@google.com>
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      8c42b1f3
    • B
      rcu: Use the proper lockdep annotation in dump_blkd_tasks() · ce11fae8
      Boqun Feng 提交于
      Sparse reported this:
      
      | kernel/rcu/tree_plugin.h:814:9: warning: incorrect type in argument 1 (different modifiers)
      | kernel/rcu/tree_plugin.h:814:9:    expected struct lockdep_map const *lock
      | kernel/rcu/tree_plugin.h:814:9:    got struct lockdep_map [noderef] *<noident>
      
      This is caused by using vanilla lockdep annotations on rcu_node::lock,
      and that requires accessing ->lock of rcu_node directly. However we need
      to keep rcu_node::lock __private to avoid breaking its extra ordering
      guarantee. And we have a dedicated lockdep annotation for
      rcu_node::lock, so use it.
      Signed-off-by: NBoqun Feng <boqun.feng@gmail.com>
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      ce11fae8
    • P
      rcu: Add debugging info to assertion · 4bc8d555
      Paul E. McKenney 提交于
      The WARN_ON_ONCE(rcu_preempt_blocked_readers_cgp()) in
      rcu_gp_cleanup() triggers (inexplicably, of course) every so often.
      This commit therefore extracts more information.
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      4bc8d555
  3. 26 6月, 2018 10 次提交