Received: by 10.223.176.5 with SMTP id f5csp1822215wra; Wed, 31 Jan 2018 12:08:21 -0800 (PST) X-Google-Smtp-Source: AH8x224R+bmCRCqiHLzQTdF3eMIznTof7R/sY6F9S5mHT7Z7t8R7eyMdBS2qLxhx+j6R33pZ5a0+ X-Received: by 10.101.64.196 with SMTP id u4mr1077558pgp.336.1517429301108; Wed, 31 Jan 2018 12:08:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517429301; cv=none; d=google.com; s=arc-20160816; b=Y0m3x/mZXwAPs4NFaSDnDDruBoONEY06Fp4wBjOaz31lboQIudh5Rz9YT4gNpV+oSP I/off5X6DvxXwgppxmHC8D+HLWoLClX4bTNbG9Zsh3Ee7O8OpthgRza0KHIOeUt6tiQg AmV5VeYxZVRATkj/qRR+Ouw5aVhgc1bKONpyb2BqRBR+deCv9/+fytfBOjCVQqmmzLa+ Sg06Fjx3Rm9dVfPILtQpnLPbVw7NOtt1VDzK+ooM2B38kgnqH0aMugiq4RMWIPieLbbL KnhDrGNOHfyPha8TSx81Ei350jRMyGFFTO79y5uxq7YuOAi9ph70YtMzTKGQFw01V1g+ XiXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject:dkim-signature :arc-authentication-results; bh=4UAiLzq8V36hsmRhnIs+N/fR9OFf0/6gMlAyRquvy2c=; b=vhjVk6/1nQlnFq9UDBuH3TxJwm2M7OjhPnpg1iVaonov+Am4DwN1IecJlUf5p5WQyY t7s6hq18B9WIfcmpdqtpOXFICTkYVX37gDY8Aj9IBaQdrsEsNETzj8XbJRYmztbBK0d4 +8lbaRU/XOkCI+lhxw/mrRzXqnozwFSR9D2HU4JsPzkYjvjlJavjM0wI4ZSOPajOwirR GICpHOw0jnFFSspoXzZc3LODPzdVFtXCkfRLBYLflZmeXNiBLVMl8iKwnaWJVIhzQ/s5 eZvURgUTAxAyY+ofduZNHQ7GRoxpq/Rn2E6M2U63GcRUFT9zI0n6JXWTUnDvgCwNBBEu sN8Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Mt2udfjd; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f2si129521pgv.244.2018.01.31.12.08.05; Wed, 31 Jan 2018 12:08:21 -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=@gmail.com header.s=20161025 header.b=Mt2udfjd; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751559AbeAaUHg (ORCPT + 99 others); Wed, 31 Jan 2018 15:07:36 -0500 Received: from mail-pf0-f193.google.com ([209.85.192.193]:37118 "EHLO mail-pf0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751326AbeAaUHe (ORCPT ); Wed, 31 Jan 2018 15:07:34 -0500 Received: by mail-pf0-f193.google.com with SMTP id p1so13788928pfh.4; Wed, 31 Jan 2018 12:07:34 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:from:to:cc:references:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=4UAiLzq8V36hsmRhnIs+N/fR9OFf0/6gMlAyRquvy2c=; b=Mt2udfjd0pnfgmRvCvqp2l5yHBfwDxj10gMEf0zvjRA10q1sKasM1RWDoWRUBvfu2z x9xU3uLt0fMjYN55KulQj/YvzikcGwItcaAqbwh5mGp7LDu26z/YVwTFdAs7Sqdz1E4X leseBSErxXAVr7bZZlA/mI/Kw0CrWm198sIorijtczC6FmQPf5H7hAdnVBxBtpT9HN5c 09DHfhi/8bb1g2dTdE12qjZDz782Pj53v4RQdORjVRXAGsnc72+9MIHNHUveQijYxvFN pBa/PCfBrfDPuRHyxEuj7ck0wVBoajlIjeDmwuQE89jV+3L43G5ehn9HaUUOelslCSLJ Rneg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:from:to:cc:references:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=4UAiLzq8V36hsmRhnIs+N/fR9OFf0/6gMlAyRquvy2c=; b=TPb7wbBRyExaUZ5w47vbPKTkLWb6EWcSUxXDupNq5h/YDIOgIDdqgGgrH7Hat+yyzd usE7DpFRPHzW2nvu/6Fc7OKk1x32DblICvAIE5giOo8vX7GYVELZA2JjoUb6IaQyXkQm l9XG2eFE2hDSgvcFdIX9FH5yP86mqC0xe6RYPJb91H4uN0e5vef67JGs8JlL+cUplvYJ VZ8yORPurFxGF/tKhF9O4dB8iHpGC52AL+JcH7OEdz5OOoBpx0l6rP2XPwk8TmX4zlk8 BNdwedGT3Cn8CMkyTsMWx9N+BKvzymuqeFhTPpQO1rySn7V95EntdtNfj/MB6OVTvpw6 jQVw== X-Gm-Message-State: AKwxytedJDJGGEUSr7Eq4fanw/dR1rr+K9j0rGylS0odzURiJ3u4LWa3 T4p2zMd7SLxgn7azTWnc5yM= X-Received: by 10.98.58.5 with SMTP id h5mr34179310pfa.169.1517429254006; Wed, 31 Jan 2018 12:07:34 -0800 (PST) Received: from [192.168.1.70] (c-73-93-215-6.hsd1.ca.comcast.net. [73.93.215.6]) by smtp.gmail.com with ESMTPSA id k90sm41577392pfk.171.2018.01.31.12.07.33 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 31 Jan 2018 12:07:33 -0800 (PST) Subject: Re: [PATCH] of: cache phandle nodes to decrease cost of of_find_node_by_phandle() From: Frank Rowand To: Rob Herring , cpandya@codeaurora.org Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org References: <1517428977-25653-1-git-send-email-frowand.list@gmail.com> Message-ID: <4d849dcd-5186-fe60-97dd-8481846aac4e@gmail.com> Date: Wed, 31 Jan 2018 12:07:32 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <1517428977-25653-1-git-send-email-frowand.list@gmail.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Rob, Please ignore this one. My signed-off is below the first "---". -Frank On 01/31/18 12:02, frowand.list@gmail.com wrote: > From: Frank Rowand > > Create a cache of the nodes that contain a phandle property. Use this > cache to find the node for a given phandle value instead of scanning > the devicetree to find the node. If the phandle value is not found > in the cache, of_find_node_by_phandle() will fall back to the tree > scan algorithm. > > The cache is initialized in of_core_init(). > > The cache is freed via a late_initcall_sync(). > > --- > > Some of_find_by_phandle() calls may occur before the cache is > initialized or after it is freed. For example, for the qualcomm > qcom-apq8074-dragonboard, 11 calls occur before the initialization > and 80 occur after the cache is freed (out of 516 total calls.) > > Signed-off-by: Frank Rowand > --- > drivers/of/base.c | 85 ++++++++++++++++++++++++++++++++++++++++++++++--- > drivers/of/of_private.h | 5 +++ > drivers/of/resolver.c | 21 ------------ > 3 files changed, 86 insertions(+), 25 deletions(-) > > diff --git a/drivers/of/base.c b/drivers/of/base.c > index 26618ba8f92a..c3091d0e391f 100644 > --- a/drivers/of/base.c > +++ b/drivers/of/base.c > @@ -95,10 +95,14 @@ int __weak of_node_to_nid(struct device_node *np) > } > #endif > > +static void of_populate_phandle_cache(void); > + > void __init of_core_init(void) > { > struct device_node *np; > > + of_populate_phandle_cache(); > + > /* Create the kset, and register existing nodes */ > mutex_lock(&of_mutex); > of_kset = kset_create_and_add("devicetree", NULL, firmware_kobj); > @@ -990,6 +994,72 @@ int of_modalias_node(struct device_node *node, char *modalias, int len) > } > EXPORT_SYMBOL_GPL(of_modalias_node); > > +phandle live_tree_max_phandle(void) > +{ > + struct device_node *node; > + phandle max_phandle; > + unsigned long flags; > + > + raw_spin_lock_irqsave(&devtree_lock, flags); > + max_phandle = 0; > + for_each_of_allnodes(node) { > + if (node->phandle != OF_PHANDLE_ILLEGAL && > + node->phandle > max_phandle) > + max_phandle = node->phandle; > + } > + raw_spin_unlock_irqrestore(&devtree_lock, flags); > + > + return max_phandle; > +} > + > +static struct device_node **phandle_cache; > +static u32 max_phandle_cache; > + > +static int __init of_free_phandle_cache(void) > +{ > + max_phandle_cache = 0; > + kfree(phandle_cache); > + phandle_cache = NULL; > + > + return 0; > +} > +late_initcall_sync(of_free_phandle_cache); > + > +static void of_populate_phandle_cache(void) > +{ > + unsigned long flags; > + phandle max_phandle; > + u32 nodes = 0; > + struct device_node *np; > + > + if (phandle_cache) > + return; > + > + max_phandle = live_tree_max_phandle(); > + > + raw_spin_lock_irqsave(&devtree_lock, flags); > + > + for_each_of_allnodes(np) > + nodes++; > + > + /* sanity cap for malformed tree */ > + if (max_phandle > nodes) > + max_phandle = nodes; > + > + phandle_cache = kzalloc((max_phandle + 1) * sizeof(*phandle_cache), > + GFP_KERNEL); > + > + for_each_of_allnodes(np) > + if (np->phandle != OF_PHANDLE_ILLEGAL && > + np->phandle <= max_phandle && > + np->phandle) > + phandle_cache[np->phandle] = np; > + > + max_phandle_cache = max_phandle; > + > + raw_spin_unlock_irqrestore(&devtree_lock, flags); > +} > + > /** > * of_find_node_by_phandle - Find a node given a phandle > * @handle: phandle of the node to find > @@ -999,16 +1069,23 @@ int of_modalias_node(struct device_node *node, char *modalias, int len) > */ > struct device_node *of_find_node_by_phandle(phandle handle) > { > - struct device_node *np; > + struct device_node *np = NULL; > unsigned long flags; > > if (!handle) > return NULL; > > raw_spin_lock_irqsave(&devtree_lock, flags); > - for_each_of_allnodes(np) > - if (np->phandle == handle) > - break; > + > + if (handle <= max_phandle_cache) > + np = phandle_cache[handle]; > + > + if (!np || np->phandle != handle) { > + for_each_of_allnodes(np) > + if (np->phandle == handle) > + break; > + } > + > of_node_get(np); > raw_spin_unlock_irqrestore(&devtree_lock, flags); > return np; > diff --git a/drivers/of/of_private.h b/drivers/of/of_private.h > index 92a9a3687446..77005978d60a 100644 > --- a/drivers/of/of_private.h > +++ b/drivers/of/of_private.h > @@ -135,6 +135,11 @@ extern void __of_update_property_sysfs(struct device_node *np, > extern void __of_sysfs_remove_bin_file(struct device_node *np, > struct property *prop); > > +/* illegal phandle value (set when unresolved) */ > +#define OF_PHANDLE_ILLEGAL 0xdeadbeef > + > +extern phandle live_tree_max_phandle(void); > + > /* iterators for transactions, used for overlays */ > /* forward iterator */ > #define for_each_transaction_entry(_oft, _te) \ > diff --git a/drivers/of/resolver.c b/drivers/of/resolver.c > index cfaeef5f6cb1..0384ce8fdc3b 100644 > --- a/drivers/of/resolver.c > +++ b/drivers/of/resolver.c > @@ -22,27 +22,6 @@ > > #include "of_private.h" > > -/* illegal phandle value (set when unresolved) */ > -#define OF_PHANDLE_ILLEGAL 0xdeadbeef > - > -static phandle live_tree_max_phandle(void) > -{ > - struct device_node *node; > - phandle phandle; > - unsigned long flags; > - > - raw_spin_lock_irqsave(&devtree_lock, flags); > - phandle = 0; > - for_each_of_allnodes(node) { > - if (node->phandle != OF_PHANDLE_ILLEGAL && > - node->phandle > phandle) > - phandle = node->phandle; > - } > - raw_spin_unlock_irqrestore(&devtree_lock, flags); > - > - return phandle; > -} > - > static void adjust_overlay_phandles(struct device_node *overlay, > int phandle_delta) > { >