lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20150421195529.GA17864@linux.vnet.ibm.com>
Date:	Tue, 21 Apr 2015 12:55:29 -0700
From:	"Paul E. McKenney" <paulmck@...ux.vnet.ibm.com>
To:	linux-kernel@...r.kernel.org
Cc:	mingo@...nel.org, laijs@...fujitsu.com, dipankar@...ibm.com,
	akpm@...ux-foundation.org, mathieu.desnoyers@...icios.com,
	josh@...htriplett.org, tglx@...utronix.de, peterz@...radead.org,
	rostedt@...dmis.org, dhowells@...hat.com, edumazet@...gle.com,
	dvhart@...ux.intel.com, fweisbec@...il.com, oleg@...hat.com,
	bobby.prani@...il.com
Subject: [PATCH tip/core/rcu 0/12] RCU Kconfig fixes for v4.2

Hello!

This patch series reduces the number of questions that RCU asks Kconfig
users.  After this series is applied, removing the RCU-related definitions
from .config and running "make oldconfig" results in only the following:

RCU Implementation
> 1. Tree-based hierarchical RCU (TREE_RCU) (NEW)
choice[1]: 1
Make expert-level adjustments to RCU configuration (RCU_EXPERT) [N/y/?] (NEW)

Those expert users wishing to tune RCU answer Y to this question.

The patches in this series are as follows:

1.	Drive TASKS_RCU directly from Kconfig, for example, by having
	RCU_TORTURE_TESTS select it.

2.	Remove CONFIG_TASKS_RCU=y from the three TASKS_RCU test
	scenarios, since this is set by virtue of having rcutorture
	configured.

3.	Drive RCU_USER_QS directly from Kconfig, relying on the fact
	that NO_HZ_FULL selects it.

4.	Convert CONFIG_RCU_FANOUT_EXACT to a boot parameter, where it
	is used by rcutorture.

5.	Update rcutorture test scenarios to use the boot parameter
	created in #4 instead of the Kconfig parameter.

6.	Create a boot parameter to do a diagnostic dump of the shape
	of the rcu_node combining tree, which is useful for verifying
	that intended changes to that tree actually happened.

7.	Create an RCU_EXPERT Kconfig parameter and hide the
	RCU_FAST_NO_HZ, RCU_BOOST, CONTEXT_TRACKING_FORCE, and
	RCU_NOCB_CPU boolean parameters behind it.

8.	Make rcutorture test scenarios force RCU_EXPERT, but have
	SRCU-P, TASKS03, and TREE09 retain !RCU_EXPERT in order to
	test the vanilla configuration.

9.	Remove the dependency of RCU_FANOUT_LEAF on RCU_FANOUT.

10.	Change RCU to allow it to tolerate an undefined RCU_FANOUT,
	and then hide RCU_FANOUT behind RCU_EXPERT.

11.	Change RCU to allow it to tolerate an undefined RCU_FANOUT_LEAF,
	and then hide RCU_FANOUT_LEAF behind RCU_EXPERT.

12.	Change RCU to allow it to tolerate an undefined RCU_KTHREAD_PRIO,
	and then hide RCU_KTHREAD_PRIO behind RCU_EXPERT.

							Thanx, Paul

------------------------------------------------------------------------

 b/Documentation/kernel-parameters.txt                          |   11 +
 b/init/Kconfig                                                 |   62 ++++------
 b/kernel/rcu/tree.c                                            |   50 ++++++--
 b/kernel/rcu/tree.h                                            |   29 ++++
 b/kernel/rcu/tree_plugin.h                                     |   14 +-
 b/lib/Kconfig.debug                                            |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-N        |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/TASKS01       |    2 
 b/tools/testing/selftests/rcutorture/configs/rcu/TASKS02       |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/TASKS03       |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE01        |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE02        |    2 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE02-T      |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE03        |    2 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE04        |    2 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE05        |    2 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE06        |    2 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE06.boot   |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE07        |    2 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE08        |    2 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE08-T      |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE08-T.boot |    1 
 b/tools/testing/selftests/rcutorture/configs/rcu/TREE08.boot   |    1 
 23 files changed, 127 insertions(+), 65 deletions(-)

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ