diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-12-30 16:10:19 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-12-30 16:10:19 -0800 | 
| commit | 5f34fe1cfc1bdd8b4711bbe37421fba4ed0d1ed4 (patch) | |
| tree | 85b21c8bb0e53005bd970d648ca093acfd0584a3 /init | |
| parent | eca1bf5b4fab56d2feb1572d34d59fcd92ea7df3 (diff) | |
| parent | 6638101c1124c19c8a65b1645e4ecd09e0572f3e (diff) | |
Merge branch 'core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip
* 'core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip: (63 commits)
  stacktrace: provide save_stack_trace_tsk() weak alias
  rcu: provide RCU options on non-preempt architectures too
  printk: fix discarding message when recursion_bug
  futex: clean up futex_(un)lock_pi fault handling
  "Tree RCU": scalable classic RCU implementation
  futex: rename field in futex_q to clarify single waiter semantics
  x86/swiotlb: add default swiotlb_arch_range_needs_mapping
  x86/swiotlb: add default phys<->bus conversion
  x86: unify pci iommu setup and allow swiotlb to compile for 32 bit
  x86: add swiotlb allocation functions
  swiotlb: consolidate swiotlb info message printing
  swiotlb: support bouncing of HighMem pages
  swiotlb: factor out copy to/from device
  swiotlb: add arch hook to force mapping
  swiotlb: allow architectures to override phys<->bus<->phys conversions
  swiotlb: add comment where we handle the overflow of a dma mask on 32 bit
  rcu: fix rcutorture behavior during reboot
  resources: skip sanity check of busy resources
  swiotlb: move some definitions to header
  swiotlb: allow architectures to override swiotlb pool allocation
  ...
Fix up trivial conflicts in
  arch/x86/kernel/Makefile
  arch/x86/mm/init_32.c
  include/linux/hardirq.h
as per Ingo's suggestions.
Diffstat (limited to 'init')
| -rw-r--r-- | init/Kconfig | 86 | 
1 files changed, 83 insertions, 3 deletions
| diff --git a/init/Kconfig b/init/Kconfig index 8a63c404ef4..13627191a60 100644 --- a/init/Kconfig +++ b/init/Kconfig @@ -936,10 +936,90 @@ source "block/Kconfig"  config PREEMPT_NOTIFIERS  	bool +choice +	prompt "RCU Implementation" +	default CLASSIC_RCU +  config CLASSIC_RCU -	def_bool !PREEMPT_RCU +	bool "Classic RCU"  	help  	  This option selects the classic RCU implementation that is  	  designed for best read-side performance on non-realtime -	  systems.  Classic RCU is the default.  Note that the -	  PREEMPT_RCU symbol is used to select/deselect this option. +	  systems. + +	  Select this option if you are unsure. + +config TREE_RCU +	bool "Tree-based hierarchical RCU" +	help +	  This option selects the RCU implementation that is +	  designed for very large SMP system with hundreds or +	  thousands of CPUs. + +config PREEMPT_RCU +	bool "Preemptible RCU" +	depends on PREEMPT +	help +	  This option reduces the latency of the kernel by making certain +	  RCU sections preemptible. Normally RCU code is non-preemptible, if +	  this option is selected then read-only RCU sections become +	  preemptible. This helps latency, but may expose bugs due to +	  now-naive assumptions about each RCU read-side critical section +	  remaining on a given CPU through its execution. + +endchoice + +config RCU_TRACE +	bool "Enable tracing for RCU" +	depends on TREE_RCU || PREEMPT_RCU +	help +	  This option provides tracing in RCU which presents stats +	  in debugfs for debugging RCU implementation. + +	  Say Y here if you want to enable RCU tracing +	  Say N if you are unsure. + +config RCU_FANOUT +	int "Tree-based hierarchical RCU fanout value" +	range 2 64 if 64BIT +	range 2 32 if !64BIT +	depends on TREE_RCU +	default 64 if 64BIT +	default 32 if !64BIT +	help +	  This option controls the fanout of hierarchical implementations +	  of RCU, allowing RCU to work efficiently on machines with +	  large numbers of CPUs.  This value must be at least the cube +	  root of NR_CPUS, which allows NR_CPUS up to 32,768 for 32-bit +	  systems and up to 262,144 for 64-bit systems. + +	  Select a specific number if testing RCU itself. +	  Take the default if unsure. + +config RCU_FANOUT_EXACT +	bool "Disable tree-based hierarchical RCU auto-balancing" +	depends on TREE_RCU +	default n +	help +	  This option forces use of the exact RCU_FANOUT value specified, +	  regardless of imbalances in the hierarchy.  This is useful for +	  testing RCU itself, and might one day be useful on systems with +	  strong NUMA behavior. + +	  Without RCU_FANOUT_EXACT, the code will balance the hierarchy. + +	  Say N if unsure. + +config TREE_RCU_TRACE +	def_bool RCU_TRACE && TREE_RCU +	select DEBUG_FS +	help +	  This option provides tracing for the TREE_RCU implementation, +	  permitting Makefile to trivially select kernel/rcutree_trace.c. + +config PREEMPT_RCU_TRACE +	def_bool RCU_TRACE && PREEMPT_RCU +	select DEBUG_FS +	help +	  This option provides tracing for the PREEMPT_RCU implementation, +	  permitting Makefile to trivially select kernel/rcupreempt_trace.c. | 
