From mboxrd@z Thu Jan 1 00:00:00 1970 From: Frank Rowand Subject: Re: [PATCH] of: use hash based search in of_find_node_by_phandle Date: Fri, 26 Jan 2018 13:29:59 -0800 Message-ID: References: <1516875247-19599-1-git-send-email-cpandya@codeaurora.org> <5a7793df-725e-608d-778b-cb81fde0cc64@gmail.com> <13846fcb-3aa2-a4fb-1bd8-e624855f105d@codeaurora.org> <2ac0d70d-074d-5eff-77e9-29d1a246a3ef@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Return-path: In-Reply-To: <2ac0d70d-074d-5eff-77e9-29d1a246a3ef@gmail.com> Content-Language: en-US Sender: linux-arm-msm-owner@vger.kernel.org To: Chintan Pandya , robh+dt@kernel.org, devicetree@vger.kernel.org Cc: linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org List-Id: devicetree@vger.kernel.org On 01/26/18 13:27, Frank Rowand wrote: > On 01/26/18 00:22, Chintan Pandya wrote: >> >> >> On 1/26/2018 1:24 AM, Frank Rowand wrote: >>> On 01/25/18 02:14, Chintan Pandya wrote: >>>> of_find_node_by_phandle() takes a lot of time finding >>>> 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. >>> Please give me a pointer to the code that is doing >>> this search. >>> >>> -Frank >> You can refer include/linux/of.h >> >> #define for_each_of_allnodes_from(from, dn) \ >>         for (dn = __of_find_all_nodes(from); dn; dn = __of_find_all_nodes(dn)) >> #define for_each_of_allnodes(dn) for_each_of_allnodes_from(NULL, dn) >> >> where __of_find_all_nodes() does >> >> struct device_node *__of_find_all_nodes(struct device_node *prev) >> { >>         struct device_node *np; >>         if (!prev) { >>                 np = of_root; >>         } else if (prev->child) { >>                 np = prev->child; >>         } else { >>                 /* Walk back up looking for a sibling, or the end of the structure */ >>                 np = prev; >>                 while (np->parent && !np->sibling) >>                         np = np->parent; >>                 np = np->sibling; /* Might be null at the end of the tree */ >>         } >>         return np; >> } >> > > Let me restate my question. > > Can you point me to the driver code that is invoking > the search? > > -Frank > And also the .dts devicetree source file that you are seeing large overhead with.