1. 04 11月, 2014 1 次提交
  2. 08 9月, 2014 4 次提交
    • P
      rcu: Per-CPU operation cleanups to rcu_*_qs() functions · 284a8c93
      Paul E. McKenney 提交于
      The rcu_bh_qs(), rcu_preempt_qs(), and rcu_sched_qs() functions use
      old-style per-CPU variable access and write to ->passed_quiesce even
      if it is already set.  This commit therefore updates to use the new-style
      per-CPU variable access functions and avoids the spurious writes.
      This commit also eliminates the "cpu" argument to these functions because
      they are always invoked on the indicated CPU.
      Reported-by: NPeter Zijlstra <peterz@infradead.org>
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      284a8c93
    • P
      rcu: Add call_rcu_tasks() · 8315f422
      Paul E. McKenney 提交于
      This commit adds a new RCU-tasks flavor of RCU, which provides
      call_rcu_tasks().  This RCU flavor's quiescent states are voluntary
      context switch (not preemption!) and userspace execution (not the idle
      loop -- use some sort of schedule_on_each_cpu() if you need to handle the
      idle tasks.  Note that unlike other RCU flavors, these quiescent states
      occur in tasks, not necessarily CPUs.  Includes fixes from Steven Rostedt.
      
      This RCU flavor is assumed to have very infrequent latency-tolerant
      updaters.  This assumption permits significant simplifications, including
      a single global callback list protected by a single global lock, along
      with a single task-private linked list containing all tasks that have not
      yet passed through a quiescent state.  If experience shows this assumption
      to be incorrect, the required additional complexity will be added.
      Suggested-by: NSteven Rostedt <rostedt@goodmis.org>
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      8315f422
    • P
      rcu: Make TINY_RCU tinier by putting error checks under #ifdef · ade98624
      Paul E. McKenney 提交于
      The rcu_idle_enter_common() and rcu_idle_exit_common() functions contain
      error checks that have to the best of my knowledge have never triggered
      over the past several years.  These are nevertheless valuable when
      creating new architectures or doing other low-level changes, so the
      checks should not be deleted.  This commit instead places these checks
      under #ifdef CONFIG_RCU_TRACE so that they are executed only when
      specifically requested.
      
      The savings are significant:
      
      	Before:
      
      	   text    data     bss     dec     hex filename
      	   1749      39       0    1788     6fc /tmp/b/kernel/rcu/tiny.o
      	    632     152       0     784     310 /tmp/b/kernel/rcu/update.o
      				   ----
      				   2572
      
      	After:
      
      	   text    data     bss     dec     hex filename
      	   1281      37       0    1318     526 /tmp/b/kernel/rcu/tiny.o
      	    632     152       0     784     310 /tmp/b/kernel/rcu/update.o
      				   ----
      				   2102
      
      This amounts to 470 bytes, or 18% of the original.
      
      Switched from #ifdef to IS_ENABLED() on Josh Triplett's advice.
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      Reviewed-by: NJosh Triplett <josh@joshtriplett.org>
      ade98624
    • P
      rcu: Update tiny.c references to tree.c · fafb6e84
      Pranith Kumar 提交于
      This commit updates the references to rcutree.c which is now rcu/tree.c
      Signed-off-by: NPranith Kumar <bobby.prani@gmail.com>
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      fafb6e84
  3. 26 2月, 2014 1 次提交
    • P
      rcu: Ensure kernel/rcu/rcu.h can be sourced/used stand-alone · 5cb5c6e1
      Paul Gortmaker 提交于
      The kbuild test bot uncovered an implicit dependence on the
      trace header being present before rcu.h in ia64 allmodconfig
      that looks like this:
      
      In file included from kernel/ksysfs.c:22:0:
      kernel/rcu/rcu.h: In function '__rcu_reclaim':
      kernel/rcu/rcu.h:107:3: error: implicit declaration of function 'trace_rcu_invoke_kfree_callback' [-Werror=implicit-function-declaration]
      kernel/rcu/rcu.h:112:3: error: implicit declaration of function 'trace_rcu_invoke_callback' [-Werror=implicit-function-declaration]
      cc1: some warnings being treated as errors
      
      Looking at other rcu.h users, we can find that they all
      were sourcing the trace header in advance of rcu.h itself,
      as seen in the context of this diff.  There were also some
      inconsistencies as to whether it was or wasn't sourced based
      on the parent tracing Kconfig.
      
      Rather than "fix" it at each use site, and have inconsistent
      use based on whether "#ifdef CONFIG_RCU_TRACE" was used or not,
      lets just source the trace header just once, in the actual consumer
      of it, which is rcu.h itself.  We include it unconditionally, as
      build testing shows us that is a hard requirement for some files.
      Reported-by: Nkbuild test robot <fengguang.wu@intel.com>
      Signed-off-by: NPaul Gortmaker <paul.gortmaker@windriver.com>
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      5cb5c6e1
  4. 18 2月, 2014 1 次提交
  5. 16 10月, 2013 1 次提交
  6. 25 9月, 2013 2 次提交
  7. 24 9月, 2013 2 次提交
  8. 30 7月, 2013 1 次提交
    • S
      rcu: Add const annotation to char * for RCU tracepoints and functions · e66c33d5
      Steven Rostedt (Red Hat) 提交于
      All the RCU tracepoints and functions that reference char pointers do
      so with just 'char *' even though they do not modify the contents of
      the string itself. This will cause warnings if a const char * is used
      in one of these functions.
      
      The RCU tracepoints store the pointer to the string to refer back to them
      when the trace output is displayed. As this can be minutes, hours or
      even days later, those strings had better be constant.
      
      This change also opens the door to allow the RCU tracepoint strings and
      their addresses to be exported so that userspace tracing tools can
      translate the contents of the pointers of the RCU tracepoints.
      Signed-off-by: NSteven Rostedt <rostedt@goodmis.org>
      e66c33d5
  9. 11 6月, 2013 5 次提交
  10. 29 1月, 2013 1 次提交
  11. 09 1月, 2013 1 次提交
  12. 14 11月, 2012 1 次提交
  13. 23 9月, 2012 3 次提交
  14. 03 7月, 2012 1 次提交
  15. 22 2月, 2012 4 次提交
  16. 12 12月, 2011 7 次提交
  17. 31 10月, 2011 2 次提交
  18. 29 9月, 2011 2 次提交