Received: by 10.223.176.46 with SMTP id f43csp349614wra; Thu, 25 Jan 2018 23:25:15 -0800 (PST) X-Google-Smtp-Source: AH8x225u1oStK/AU28uDtV5V7n62GOj/o00DRkv9AWyFH52QXoViBYY1AM/PMet0/zDQ8xYaBEWO X-Received: by 2002:a17:902:12f:: with SMTP id 44-v6mr12032337plb.403.1516951515844; Thu, 25 Jan 2018 23:25:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516951515; cv=none; d=google.com; s=arc-20160816; b=Edb2sUt1HWQ1xVVDAOceYs0JNrhmn7sn3VptaJ3gJ7V8bFXceXfnsDShCr9LAqwwy0 +n+wlT/xVSgWThpMorT1WPiRyGRkyST7lXa1bYwssKioRQly7mNLoBLHEzTNQcgoiI6/ abIfWA3OMfhmHNH0BQD5K1F6X5PZ6KppThrI7jjaD2wIuJXgNZ6dIYIu7IHXmpWoPCIq evCq8FpZXrqw7DnsmV/Yvl8Q+6qIGsLpR+IKEuIDrW2mcUP/lzUCaeSxKUl1qzZwwOAj EjwpXZyVKd3bA+pVrXoTRA7GIdFen7JMek01bmW9HfD3iDVYxgNu85lTtVNhNxUGkZh5 c3gQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature:arc-authentication-results; bh=50PJOJpqGCR2idXHdjvczvoox+rAd8mRuPDRNrd43F4=; b=FC8Ig8w43Zrw5v7dzutcfAAjyqdMZ4icRWR78sci/gJnUfn3ZsruFj5y5Nmja6dKlc ACPSviIbaRrwiitnCZX2VxBfGVTi864UKRj5yVov3uIONPFFRCqyAVll4zXSJdyJVfRw 05IESY3EVOwlFbQ5V5Uw+Czpibsw5W93SVX223kUN/waIHSDMiMf5BCIo+2/IqiOeLgt cMuMbGEs6k9wdDJ9pDPMhvuwDSlX+G9+WPoqKOwinlwyhXvC3gZ5WJtRN1v9Z33EAJzr oRSqX11NdLw4Uby6QUFhx4psiqB6ko6GsWKl8t1YxKjqO+QieRmcz/apvzebAt2Vhf+0 xACg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=VUirLcI0; dkim=pass header.i=@codeaurora.org header.s=default header.b=ShPinNwe; 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 v4-v6si3332212plp.746.2018.01.25.23.25.01; Thu, 25 Jan 2018 23:25:15 -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=@codeaurora.org header.s=default header.b=VUirLcI0; dkim=pass header.i=@codeaurora.org header.s=default header.b=ShPinNwe; 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 S1752002AbeAZHXP (ORCPT + 99 others); Fri, 26 Jan 2018 02:23:15 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:34152 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751724AbeAZHWw (ORCPT ); Fri, 26 Jan 2018 02:22:52 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 1007160A24; Fri, 26 Jan 2018 07:22:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1516951372; bh=MdY7D3me3c2O42XAr50bgqIHwuhm0oCkuGbtxRg8tAQ=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=VUirLcI0TkdpBSz9mfUUxEqn0j/hgL6qhDVA45y99dCCbeimUNGpvqAywIZ7ytxUV 8pBcUdqhznfVZwB5bFMiWstLrnPvotwXqewFV1msj9ITx9t/wBN6ZJudizVloqx3ge LpAKdMcdonFMsrKqiZg6n/ETFwU73VBaq4XyG9a8= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from [192.168.2.11] (unknown [183.83.202.249]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: cpandya@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id CFBC66047C; Fri, 26 Jan 2018 07:22:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1516951370; bh=MdY7D3me3c2O42XAr50bgqIHwuhm0oCkuGbtxRg8tAQ=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=ShPinNweDoNEERJOvLBuVJhloPEByzFp0Q8hzf1xrKY9mI/MQpKWlewodUID6aUKT ylQzkQwrbjGK4KLy5UB2F2lI+qx0hf6I5U5eM3phXpupyI4QXlPktYzZJsvja92bQk c13Wwz48uevn6h8gWo+FqvYH02wL2dXWV0z6dc6o= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org CFBC66047C Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=cpandya@codeaurora.org Subject: Re: [PATCH] of: use hash based search in of_find_node_by_phandle To: Rob Herring Cc: Frank Rowand , "open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE BINDINGS" , "linux-kernel@vger.kernel.org" , linux-arm-msm References: <1516875247-19599-1-git-send-email-cpandya@codeaurora.org> From: Chintan Pandya Message-ID: Date: Fri, 26 Jan 2018 12:52:43 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.5.2 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/25/2018 8:20 PM, Rob Herring wrote: > On Thu, Jan 25, 2018 at 4:14 AM, Chintan Pandya wrote: >> of_find_node_by_phandle() takes a lot of time finding > Got some numbers for what is "a lot of time"? On my SDM device, I see total saving of 400ms during boot time. For some clients whose node is quite deeper, they see 1ms time taken by this API. > >> right node when your intended device is too right-side >> in the fdt. Reason is, we search each device serially >> from the fdt, starting from left-most to right-most. > By right side, you mean a deep path? Yes, will correct this if original is confusing. > >> Implement, device-phandle relation in hash-table so >> that look up can be faster. >> >> Change-Id: I4a2bc7eff6de142e4f91a7bf474893a45e61c128 > Run checkpatch.pl Sure. My bad. > >> @@ -61,6 +62,7 @@ struct device_node { >> struct kobject kobj; >> unsigned long _flags; >> void *data; >> + struct hlist_node hash; > Always base your patches on the latest -rc at least. This won't apply. Ok, sure. > > This grows struct device_node for every single node which we recently > worked on to shrink (which is why this won't apply). So I'm now > sensitive to anything that grows it. I'd really prefer something out > of band. > > I'd guess that there's really only a few phandle lookups that occur > over and over. On my system, there are ~6.7k calls of this API during boot. > The clock controller, interrupt controller, etc. What > if you just had a simple array of previously found nodes for a cache > and of_find_node_by_phandle can check that array first. Probably 8-16 > entries would be enough. I clearly see repeat calling with same phandle. But I have few hundreds of nodes. I see hashing as generic optimization which applies equally good to all sized DT. Using ~4KB more size to save 400 ms is a good trade-off, I believe. Chintan Pandya -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project