Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp19952595ybl; Sat, 4 Jan 2020 13:22:23 -0800 (PST) X-Google-Smtp-Source: APXvYqz8IkM2NYPTmMxn8fGEcug/gWQohP/JF2Uguvz08+vVOtwGvlHLSeIYCa/+Za8O9rncZ9uP X-Received: by 2002:a9d:6f8f:: with SMTP id h15mr101556362otq.1.1578172943766; Sat, 04 Jan 2020 13:22:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578172943; cv=none; d=google.com; s=arc-20160816; b=mETPsSiSCUKB1XCx1/tunscK1jj6XgC0LzRdDQRqR+eV1zirE1Bbc0jRCm+Ct+vGr7 gEKrkXuIqpmg3K07L1oJAUBU4O8DJFRQXVDu2F9OvnMJzpbn7+65+B1yUJ4N3iBCG6yR htnoWayShtYKemvwq5qAOgNaEfuUnGmZEs+AXYIOIS5r7mHsiw96YN9+DMkHT/RyUEtC WTZfXs32OfaDVBOWGyJmkprSYyArVD++FlhgzuImNaQo2zYeRqP5zHBLw3ZgJpODuEhf dtVbGrYw/U7lgkpfjFrBH9UCrzdoFUyICbdSn0jfsHnEWi55QqYRIvKG16xQIRm8tmEu 4SaQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=plpKbdiW72DXJOvU1TVKdnl0zL4VM/YG87vawclIn4g=; b=jE9Tucptwf3H3UeAd6md1FYKrcKnRHu7tmWJQLM+36BrPUPR1u2yIleBDZMA6F5nr4 R82IxvT05Blv6WeQ+g+YWyOsrE++ZgbjAa20LMkASq6i0VMvBy/pztj8rysKUW1vwnDP epLTbNu1NXOMtZeAFQ8uXa+urWUQlRVkrzUIBE4B6HJkTYbBytkQh9h9NAiheQwdzTV2 PK7QFrZxRJcmOdyoS9+fjB3uZaDtW9Dsn5ftqS32ZskH0PlIxfW96wSFMT2UkyXGWp38 xMpJdfcozopFZd8BZW8tRLLX86T8ztxrugVw37Oh9gfAj7CSCEHnN5jXmteekZBK6Nmy DoWQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=am5n50n1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c79si31086390oig.208.2020.01.04.13.22.11; Sat, 04 Jan 2020 13:22:23 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=am5n50n1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726263AbgADVVd (ORCPT + 99 others); Sat, 4 Jan 2020 16:21:33 -0500 Received: from mail-pg1-f196.google.com ([209.85.215.196]:34507 "EHLO mail-pg1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726204AbgADVVd (ORCPT ); Sat, 4 Jan 2020 16:21:33 -0500 Received: by mail-pg1-f196.google.com with SMTP id r11so25023504pgf.1 for ; Sat, 04 Jan 2020 13:21:33 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=plpKbdiW72DXJOvU1TVKdnl0zL4VM/YG87vawclIn4g=; b=am5n50n1oazIAUJ+wPBXku6ho9iqM+p9CB9klzmmA3vS9X9Fy65BjVdjbZadmAjSTF j7rspwpImjnIRTaPRl89iMez9Wwy0CEciZyQ+72J/Js5lZPUyCO6b6TQxTYvA33B/LUJ qW0Kx8ekLp+UQ+TwZjCvlGUFOndUeA4M/hX88= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=plpKbdiW72DXJOvU1TVKdnl0zL4VM/YG87vawclIn4g=; b=pXixZbUmazB2JN4uSck9EuWoYIvUPuvm0Mn54tz/OwZkRo8AhKhVvBG1jb2hcHr/1H sceEHOKnVLORgJfwhgI9GpFbMxxDeFBvrqLPfQ72i4X9a2plZY33Q9vNzECYcdr4pgPc r4lusc4QwOjxWu8fAz+83Ry0fY32CXuAEzPvXVmGPnDWikmQDrAu/njpEUdtigZCnrRY 4UOoWYcn5OQTtskGTbUtXIUOL9fCI60wOlTjrn9KSDNOvusQFngExTwLiU27/7u9IwYC YVnmM2PFDaRlkMK4Ne+Et270L0wO1NWbxrpC8OFVeE/UZnamGbYVIxN6cMnDrMcxw57O 0Jeg== X-Gm-Message-State: APjAAAXibVwTHxNYUmySs17eMn1ffjQGKjJOmU66GXNhnHEibK3MmueO t+Kq6nMgPrAGVePDMA6Dlc91aQ== X-Received: by 2002:aa7:96b7:: with SMTP id g23mr98998711pfk.108.1578172892874; Sat, 04 Jan 2020 13:21:32 -0800 (PST) Received: from localhost ([2620:15c:6:12:9c46:e0da:efbf:69cc]) by smtp.gmail.com with ESMTPSA id s18sm67570463pfh.179.2020.01.04.13.21.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 04 Jan 2020 13:21:32 -0800 (PST) Date: Sat, 4 Jan 2020 16:21:31 -0500 From: Joel Fernandes To: madhuparnabhowmik04@gmail.com Cc: stefanr@s5r6.in-berlin.de, paulmck@kernel.org, linux1394-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org, rcu@vger.kernel.org, linux-kernel-mentees@lists.linuxfoundation.org, frextrite@gmail.com Subject: Re: [PATCH] drivers: firewire: core-transaction: Pass lockdep condition to address_handler_list iterator Message-ID: <20200104212131.GN189259@google.com> References: <20200104144215.27590-1-madhuparnabhowmik04@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200104144215.27590-1-madhuparnabhowmik04@gmail.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Jan 04, 2020 at 08:12:15PM +0530, madhuparnabhowmik04@gmail.com wrote: > From: Madhuparna Bhowmik > > The address_handler_list is traversed with list_for_each_entry_rcu > with address_handler_list_lock held. > list_for_each_entry_rcu has built-in RCU and lock checking. > Use it for address_handler_list traversal. > > Signed-off-by: Madhuparna Bhowmik Reviewed-by: Joel Fernandes (Google) thanks, - Joel > --- > drivers/firewire/core-transaction.c | 9 ++++++--- > 1 file changed, 6 insertions(+), 3 deletions(-) > > diff --git a/drivers/firewire/core-transaction.c b/drivers/firewire/core-transaction.c > index 404a035f104d..a15e70027932 100644 > --- a/drivers/firewire/core-transaction.c > +++ b/drivers/firewire/core-transaction.c > @@ -61,6 +61,11 @@ > #define PHY_CONFIG_ROOT_ID(node_id) ((((node_id) & 0x3f) << 24) | (1 << 23)) > #define PHY_IDENTIFIER(id) ((id) << 30) > > +static DEFINE_SPINLOCK(address_handler_list_lock); > +static LIST_HEAD(address_handler_list); > + > +#define address_handler_list_lock_held() lock_is_held(&(address_handler_list_lock).dep_map) > + > /* returns 0 if the split timeout handler is already running */ > static int try_cancel_split_timeout(struct fw_transaction *t) > { > @@ -485,7 +490,7 @@ static struct fw_address_handler *lookup_overlapping_address_handler( > { > struct fw_address_handler *handler; > > - list_for_each_entry_rcu(handler, list, link) { > + list_for_each_entry_rcu(handler, list, link, address_handler_list_lock_held()) { > if (handler->offset < offset + length && > offset < handler->offset + handler->length) > return handler; > @@ -514,8 +519,6 @@ static struct fw_address_handler *lookup_enclosing_address_handler( > return NULL; > } > > -static DEFINE_SPINLOCK(address_handler_list_lock); > -static LIST_HEAD(address_handler_list); > > const struct fw_address_region fw_high_memory_region = > { .start = FW_MAX_PHYSICAL_RANGE, .end = 0xffffe0000000ULL, }; > -- > 2.17.1 >