Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp1434755ybi; Wed, 17 Jul 2019 15:24:50 -0700 (PDT) X-Google-Smtp-Source: APXvYqw8vAeJegckLvdsRKbN8URko3JYmrsl2aAl7C1f6izeRImiXwn3pfWhy5pIY6I6hL1Pibb7 X-Received: by 2002:a17:90a:ac0e:: with SMTP id o14mr17893292pjq.142.1563402290430; Wed, 17 Jul 2019 15:24:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563402290; cv=none; d=google.com; s=arc-20160816; b=rcmgZbB5xRJytKGbzJuZyqNGSLgf7JPDZtvgAH4X8Kyii3JJJTiowso7LGUmOsagyn gHE3NVYCzRNAOU8Ib6n8zPVVKcyMCwUlCtwcFl3VGE6+bu+Vlu0K3QIRSYH59yeMx5+p 1OXxjSMZpsapxH+2RoFJ0y7svCACcydYM4rCeDHo+zxTopszyhKdND299BcQnGznBIRK iELuRfu/2y59JZ/b/zz8VQ64AlyPxomILqSUT9yfJeFtquvspEN+9SPTaZAdyDOJmKXy 792QoQiDKA986tRS3WMFOI+vxhbR3i4y4H3/wDR5bTfBgNW3pBJqTONQChxmkFZjtVmx GbbA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:references :mime-version:message-id:in-reply-to:date:dkim-signature; bh=hlgN2kJF8O2fjyDEv3zuJRNqQ1+92Wl3CueXhQyVzIU=; b=yzY+RUYCtd3Rw57Qu4KzaFbq/2Br49I2FL81VmrkQRj4CZDYkzZ3gMNpJytuM2XOKt bVvls1qpvjWYiLD3Wi/qffk5kxwjdC+g4qF1BKz7FB/VyfVOi4u+mj036JAUTYI3GShL +kto1Vk1ycVMnqTe//kBVsaKacZcuImhF98PYEg2VsCatp/9OP7tvgrYSdntplmsn3L6 Tn1lA4FZAqNp/LoG9Z+D4D69lQHsCH4YhQhxgGCBYk0GFGERLLDPPy3PpByPaJ84jRem Mo8nMOUN2eew+SDDIwxIGbWO2yocpg/XPEssE1FIR0J6znMNEX0bYDjg7hOymHRIh6DJ ohww== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=NnRzkWoN; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n1si24534045pgi.380.2019.07.17.15.24.34; Wed, 17 Jul 2019 15:24:50 -0700 (PDT) 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=@google.com header.s=20161025 header.b=NnRzkWoN; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730800AbfGQWYH (ORCPT + 99 others); Wed, 17 Jul 2019 18:24:07 -0400 Received: from mail-vk1-f202.google.com ([209.85.221.202]:40047 "EHLO mail-vk1-f202.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730024AbfGQWYE (ORCPT ); Wed, 17 Jul 2019 18:24:04 -0400 Received: by mail-vk1-f202.google.com with SMTP id p193so11804551vkd.7 for ; Wed, 17 Jul 2019 15:24:04 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=hlgN2kJF8O2fjyDEv3zuJRNqQ1+92Wl3CueXhQyVzIU=; b=NnRzkWoN5/S27nZtGN8yKD37RUeIb30TAYui+l8MKkJjjOT5PipUtajEOAMDk3YNoc 8PTBCgW0yWc1MCot3JFGVlX5HzIjsbmZczGK5SNXBXM6xPTUEjTFyzzAUFh66LXRZ2yf V49f5emTq5XuK2SSmMsDaN20WSehh/hCsKJ+cnTyJvPTXH6CtdFx0vRDarSfmgThKmdz bNj4bz2ocVw0o9Loue41WzGw0CyLlFFVs/s8DwT3wOQgsYug5wJZjnxA0QwV55V6XxDF JRjsdyUDNLiB5KUNQtrXX51GVqXwEjhJvFrupEnXsyMIpNF0B3yA23l9dvCmdFsRQZ2u Zo+g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=hlgN2kJF8O2fjyDEv3zuJRNqQ1+92Wl3CueXhQyVzIU=; b=QiezB5FE2sn74A4k3qjGTweh6ybQ36At6iOe1taVqbiIqwqZF1JPMJJ2lLTo8YmYhH jxuVyuOJNAk1+eD7/gJAPN0/ZkF7moUv4XMukXhol1RfAmGOVxWiyVxs8UhA40VIQ9O6 GbjxAi7kg0fML6/XhLiOivdfoj0Ajd2bVm+UDVGymwi9vKaQYA4Nx8L7etGaOV79SyiQ xGtVAmhkY8zxNlt9CAsN46fVonq0iwSccm0xR7nyg/GCgAgbALOd2zAfOwpF25RT4e5Q hPTYrAnrSwuvIv5rs2GJ3o7Bu02tf/1oYJoL7Vi8RFSq7p4dnJpOm2DQhZGwVI0y+JXe qmMQ== X-Gm-Message-State: APjAAAUZPujhmJAtP94K54cB6LENBWcw21RlGS6OGEc6zc8ZSqyDv5Kr UusQ4mFbjvd9W67oZoIFVfkhhBZWumFHo2o= X-Received: by 2002:a1f:6e8e:: with SMTP id j136mr17525706vkc.80.1563402243539; Wed, 17 Jul 2019 15:24:03 -0700 (PDT) Date: Wed, 17 Jul 2019 15:23:39 -0700 In-Reply-To: <20190717222340.137578-1-saravanak@google.com> Message-Id: <20190717222340.137578-5-saravanak@google.com> Mime-Version: 1.0 References: <20190717222340.137578-1-saravanak@google.com> X-Mailer: git-send-email 2.22.0.510.g264f2c817a-goog Subject: [PATCH v3 4/5] PM / devfreq: Cache OPP table reference in devfreq From: Saravana Kannan To: MyungJoo Ham , Kyungmin Park , Chanwoo Choi , Viresh Kumar , Nishanth Menon , Stephen Boyd , "Rafael J. Wysocki" Cc: Saravana Kannan , Sibi Sankar , kernel-team@android.com, linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The OPP table can be used often in devfreq. Trying to get it each time can be expensive, so cache it in the devfreq struct. Signed-off-by: Saravana Kannan Reviewed-by: Chanwoo Choi Acked-by: MyungJoo Ham --- drivers/devfreq/devfreq.c | 6 ++++++ include/linux/devfreq.h | 2 ++ 2 files changed, 8 insertions(+) diff --git a/drivers/devfreq/devfreq.c b/drivers/devfreq/devfreq.c index 784c08e4f931..7984b01d585d 100644 --- a/drivers/devfreq/devfreq.c +++ b/drivers/devfreq/devfreq.c @@ -594,6 +594,8 @@ static void devfreq_dev_release(struct device *dev) if (devfreq->profile->exit) devfreq->profile->exit(devfreq->dev.parent); + if (devfreq->opp_table) + dev_pm_opp_put_opp_table(devfreq->opp_table); mutex_destroy(&devfreq->lock); kfree(devfreq); } @@ -674,6 +676,10 @@ struct devfreq *devfreq_add_device(struct device *dev, devfreq->max_freq = devfreq->scaling_max_freq; devfreq->suspend_freq = dev_pm_opp_get_suspend_opp_freq(dev); + devfreq->opp_table = dev_pm_opp_get_opp_table(dev); + if (IS_ERR(devfreq->opp_table)) + devfreq->opp_table = NULL; + atomic_set(&devfreq->suspend_count, 0); dev_set_name(&devfreq->dev, "devfreq%d", diff --git a/include/linux/devfreq.h b/include/linux/devfreq.h index 2bae9ed3c783..1c05129f76c0 100644 --- a/include/linux/devfreq.h +++ b/include/linux/devfreq.h @@ -116,6 +116,7 @@ struct devfreq_dev_profile { * @profile: device-specific devfreq profile * @governor: method how to choose frequency based on the usage. * @governor_name: devfreq governor name for use with this devfreq + * @opp_table: Reference to OPP table of dev.parent, if one exists. * @nb: notifier block used to notify devfreq object that it should * reevaluate operable frequencies. Devfreq users may use * devfreq.nb to the corresponding register notifier call chain. @@ -153,6 +154,7 @@ struct devfreq { struct devfreq_dev_profile *profile; const struct devfreq_governor *governor; char governor_name[DEVFREQ_NAME_LEN]; + struct opp_table *opp_table; struct notifier_block nb; struct delayed_work work; -- 2.22.0.510.g264f2c817a-goog