From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1762414AbdEYV7p (ORCPT ); Thu, 25 May 2017 17:59:45 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:51611 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1758423AbdEYV7m (ORCPT ); Thu, 25 May 2017 17:59:42 -0400 Date: Thu, 25 May 2017 14:59:34 -0700 From: "Paul E. McKenney" To: linux-kernel@vger.kernel.org Cc: mingo@kernel.org, jiangshanlai@gmail.com, dipankar@in.ibm.com, akpm@linux-foundation.org, mathieu.desnoyers@efficios.com, josh@joshtriplett.org, tglx@linutronix.de, peterz@infradead.org, rostedt@goodmis.org, dhowells@redhat.com, edumazet@google.com, fweisbec@gmail.com, oleg@redhat.com, bobby.prani@gmail.com Subject: [PATCH tip/core/rcu 0/88] Commits for 4.13 Reply-To: paulmck@linux.vnet.ibm.com MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.5.21 (2010-09-15) X-TM-AS-GCONF: 00 x-cbid: 17052521-0052-0000-0000-0000020B33A5 X-IBM-SpamModules-Scores: X-IBM-SpamModules-Versions: BY=3.00007117; HX=3.00000241; KW=3.00000007; PH=3.00000004; SC=3.00000212; SDB=6.00865574; UDB=6.00429833; IPR=6.00645396; BA=6.00005375; NDR=6.00000001; ZLA=6.00000005; ZF=6.00000009; ZB=6.00000000; ZP=6.00000000; ZH=6.00000000; ZU=6.00000002; MB=3.00015583; XFM=3.00000015; UTC=2017-05-25 21:59:39 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 17052521-0053-0000-0000-000050B6801B Message-Id: <20170525215934.GA11578@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-05-25_17:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 suspectscore=1 malwarescore=0 phishscore=0 adultscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1703280000 definitions=main-1705250401 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello! This rather long series mostly removes unused features, shrinks the include/linux/rcupdate.h file's .i intermediate-output size, updates rcutorture testing, and supplies miscellaneous fixes. Branching proved impractical due to the large footprint of many of the commits, hence the long linear series. On the other hand, this series's diffstat summary line is as follows: 87 files changed, 1745 insertions(+), 4389 deletions(-) That is, there is a net removal of more than 2500 lines of code. The shrinking is near the end of the series, starting with patch 49. The patches in this series are as follows: 1-5. Adjust rcutorture testing to better cover SRCU. 6. Performance fix that prevents rcu_barrier() from starting needless grace periods. 7-8. Fix rcutorture bugs that were failing to test certain Kconfig options in some rcutorture scenarios. 9. Fix a long-standing counter-wrap bug in SRCU. 10. Fix a bug where preemptible RCU would fail to complain about blocking (as opposed to preemption) within an RCU read-side critical section. 11-12. Fix argument-checking bug in the rcuperf performance/scalability checking module and remove conflicting Kconfig options. 13. Remove obsolete references to the long-departed synchronize_kernel() RCU API member. 14. Upgrade rcuperf so that it can performance-test the asynchronous call_rcu() primitives. 15. Add a Kconfig-fragment file for Classic SRCU. 16. Make sync_rcu_preempt_exp_done() return bool instead of int. 17. Now that expedited RCU grace periods do not rely on stop-CPUs mechanisms and don't IPI idle/nohz_full CPUs, remove the checkpatch.pl warning about them. 18. Add an rcuperf test for dynamically initialized srcu_struct structures. 19. Clarify atomic_ops.rst definition of smp_mb__{before,after}_atomic(). 20. Add header comment to spin_unlock_wait() defining its semantics. 21. Fix typo in memory-barriers.txt, courtesy of Stan Drozd. 22. Add the ability to do rcuperf performance tests on tiny RCU flavors. 23. Make SRCU flavors announce themselves at boot. 24. Reduce the number of CPUs used in Classic SRCU testing. 25. Shrink Tiny SRCU a bit more by rearranging and shrinking fields in the srcu_struct. 26. Set more user-friendly kernel-boot parameter defaults. 27. Use /usr/bin/awk instead of /bin/awk, courtesy of Priyalee Kushwaha. 28. Add writer_holdoff boot parameter to rcuperf to test auto-expediting. 29. Add "git diff" output to rcutorture's testid.txt file to allow exact after-the-fact reconstruction of exactly what source code was tested. 30. Document SRCU auto-expediting requirement. 31. Add tail-recursion possibility to RCU requirements docuemntation. 32. Make CONFIG_PROVE_LOCKING kernels warn about failure to have preemption disabled in calls to rcu_sched_qs() and rcu_bh_qs(). 33-34. Improve dmesg record of non-default Kconfig and boot-parameter settings. 35. Make the exp_holdoff module parameter be static. 36. Add dmesg record of non-default auto-expedite holdoff times. 37-38. Add assertions to enforce lock-held and irq-disabled preconditions. 39. Make SRCU again be optional. 40. Inline __srcu_read_lock() to shrink Tiny SRCU. 41. Add DEBUG_OBJECTS_RCU_HEAD checking to SRCU callbacks. 42-43. Make synchronize_rcu_mult() check for duplicates, getting rid of an ugly #ifdef in sched_cpu_deactivate(). 44. Rename the nonsensical RCU_NOGP_WAKE flags to RCU_NOCB_WAKE_. 45. Add memory barriers for NOCB leader wakeup. 46. Add kconfig argument to rcutorture testing to avoid the need for lots of special-case Kconfig-fragment files. 47. Add comments explaining why rcu_node_tree.h and rcu_segcblist.h are visible external to the kernel/rcu directory. 48. Fix a bug in rcutorture where it would wait for kernels to complete running even though all builds failed for that batch. 49-57. Shrink include/linux/rcupdate.h to speed up kernel builds. 58. Improve the __call_rcu() debug-objects error message. 59-65. More shrinking include/linux/rcupdate.h to speed up kernel builds, including shrinking files included by this file. 66. Prevent sdp->srcu_gp_seq_needed counter wrap. 67. Shrink include/linux/srcu.h (and files it includes) to speed up kernel builds. 68. Move to trivial callback lists to further shrink Tiny SRCU. 69. Use consistent printing primitives within a given function in lockdep.c. 70. Refactor #includes from include/linux/rcupdate.h to reduce the amount of material included, in turn speeding up kernel builds. 71-73. Convert rnp->lock wrappers to macros for SRCU use, thus consolidating code. 72-80. Remove unused code and options. 81. Fix typo in code generating rcutorture statistics. 82-84. Remove more unused code and options. 85-86. Move RCU Kconfig options to kernel/rcu. 87-88. Remove yet more unused code and options. Thanx, Paul ------------------------------------------------------------------------ /include/linux/srcuclassic.h | 100 - /kernel/rcu/srcu.c | 669 ---------- /tools/testing/selftests/rcutorture/configs/rcu/SRCU-C | 11 /tools/testing/selftests/rcutorture/configs/rcuperf/SRCUCLASSIC | 16 Documentation/RCU/trace.txt | 535 ------- b/Documentation/RCU/00-INDEX | 2 b/Documentation/RCU/Design/Requirements/Requirements.html | 34 b/Documentation/RCU/checklist.txt | 8 b/Documentation/admin-guide/kernel-parameters.txt | 41 b/Documentation/core-api/atomic_ops.rst | 5 b/Documentation/dev-tools/sparse.rst | 6 b/Documentation/kernel-per-CPU-kthreads.txt | 31 b/Documentation/memory-barriers.txt | 2 b/Documentation/timers/NO_HZ.txt | 29 b/include/linux/compiler.h | 4 b/include/linux/rcu_node_tree.h | 4 b/include/linux/rcu_segcblist.h | 4 b/include/linux/rcupdate.h | 324 ---- b/include/linux/rcutiny.h | 181 -- b/include/linux/rcutree.h | 21 b/include/linux/spinlock.h | 20 b/include/linux/srcu.h | 29 b/include/linux/srcuclassic.h | 15 b/include/linux/srcutiny.h | 46 b/include/linux/srcutree.h | 13 b/include/trace/events/rcu.h | 1 b/init/Kconfig | 355 ----- b/kernel/locking/lockdep.c | 176 +- b/kernel/rcu/Kconfig | 244 +++ b/kernel/rcu/Kconfig.debug | 82 + b/kernel/rcu/Makefile | 2 b/kernel/rcu/rcu.h | 335 ++++- b/kernel/rcu/rcuperf.c | 129 + b/kernel/rcu/rcutorture.c | 21 b/kernel/rcu/srcu.c | 7 b/kernel/rcu/srcutiny.c | 85 - b/kernel/rcu/srcutree.c | 193 +- b/kernel/rcu/tiny.c | 54 b/kernel/rcu/tiny_plugin.h | 123 - b/kernel/rcu/tree.c | 195 +- b/kernel/rcu/tree.h | 151 -- b/kernel/rcu/tree_exp.h | 2 b/kernel/rcu/tree_plugin.h | 603 +-------- b/kernel/rcu/update.c | 77 + b/kernel/sched/core.c | 8 b/kernel/time/Kconfig | 50 b/lib/Kconfig.debug | 188 -- b/lib/Makefile | 3 b/scripts/checkpatch.pl | 17 b/tools/testing/selftests/rcutorture/bin/config_override.sh | 61 b/tools/testing/selftests/rcutorture/bin/configcheck.sh | 2 b/tools/testing/selftests/rcutorture/bin/kvm-build.sh | 13 b/tools/testing/selftests/rcutorture/bin/kvm-test-1-run.sh | 62 b/tools/testing/selftests/rcutorture/bin/kvm.sh | 38 b/tools/testing/selftests/rcutorture/configs/rcu/CFLIST | 4 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-C | 13 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-C.boot | 1 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-N | 2 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-P | 6 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-t | 10 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-t.boot | 1 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-u | 9 b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-u.boot | 1 b/tools/testing/selftests/rcutorture/configs/rcu/TINY02 | 5 b/tools/testing/selftests/rcutorture/configs/rcu/TREE01 | 5 b/tools/testing/selftests/rcutorture/configs/rcu/TREE01.boot | 4 b/tools/testing/selftests/rcutorture/configs/rcu/TREE02 | 5 b/tools/testing/selftests/rcutorture/configs/rcu/TREE03 | 4 b/tools/testing/selftests/rcutorture/configs/rcu/TREE03.boot | 4 b/tools/testing/selftests/rcutorture/configs/rcu/TREE04 | 4 b/tools/testing/selftests/rcutorture/configs/rcu/TREE05 | 4 b/tools/testing/selftests/rcutorture/configs/rcu/TREE05.boot | 3 b/tools/testing/selftests/rcutorture/configs/rcu/TREE06 | 4 b/tools/testing/selftests/rcutorture/configs/rcu/TREE06.boot | 3 b/tools/testing/selftests/rcutorture/configs/rcu/TREE07 | 6 b/tools/testing/selftests/rcutorture/configs/rcu/TREE08 | 1 b/tools/testing/selftests/rcutorture/configs/rcu/TREE08.boot | 1 b/tools/testing/selftests/rcutorture/configs/rcuperf/SRCUCLASSIC | 16 b/tools/testing/selftests/rcutorture/configs/rcuperf/TINY | 16 b/tools/testing/selftests/rcutorture/configs/rcuperf/TREE | 1 b/tools/testing/selftests/rcutorture/configs/rcuperf/TREE54 | 1 b/tools/testing/selftests/rcutorture/doc/TINY_RCU.txt | 1 b/tools/testing/selftests/rcutorture/doc/TREE_RCU-kconfig.txt | 34 b/tools/testing/selftests/rcutorture/formal/srcu-cbmc/modify_srcu.awk | 2 kernel/rcu/tree_trace.c | 494 ------- tools/testing/selftests/rcutorture/configs/rcu/TREE02-T | 21 tools/testing/selftests/rcutorture/configs/rcu/TREE08-T | 21 87 files changed, 1745 insertions(+), 4389 deletions(-)