From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1760725AbcBYOcs (ORCPT ); Thu, 25 Feb 2016 09:32:48 -0500 Received: from casper.infradead.org ([85.118.1.10]:34067 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1760202AbcBYOcr (ORCPT ); Thu, 25 Feb 2016 09:32:47 -0500 Date: Thu, 25 Feb 2016 15:32:43 +0100 From: Peter Zijlstra To: Boqun Feng Cc: linux-kernel@vger.kernel.org, Ingo Molnar , "Paul E. McKenney" , Josh Triplett , Steven Rostedt , Mathieu Desnoyers , Lai Jiangshan , sasha.levin@oracle.com Subject: Re: [RFC v2 0/6] Track RCU dereferences in RCU read-side critical sections Message-ID: <20160225143243.GP6357@twins.programming.kicks-ass.net> References: <1455602265-16490-1-git-send-email-boqun.feng@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1455602265-16490-1-git-send-email-boqun.feng@gmail.com> User-Agent: Mutt/1.5.21 (2012-12-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Feb 16, 2016 at 01:57:39PM +0800, Boqun Feng wrote: > As a characteristic of RCU, read-side critical sections have a very > loose connection with rcu_dereference()s, which is you can only be sure > about an rcu_dereference() might be called in some read-side critical > section, but if code gets complex, you may not be sure which read-side > critical section exactly, this might be also an problem for some other > locking mechanisms, that is the critical sections protecting data and > the data accesses protected are not clearly correlated. > > In this series, we are introducing LOCKED_ACCESS framework and based on > which, we implement the RCU_LOCKED_ACCESS functionality to give us a > clear hint: which rcu_dereference() happens in which RCU read-side > critical section. > > After this series applied, and if CONFIG_RCU_LOCKED_ACCESS=y, the proc > file /proc/locked_access/rcu will show all relationships collected so > far for rcu_read_lock() and their friends and rcu_dereference*(). > But why !? What does this bring us, why do I want to even look at these patches?