From patchwork Tue May 23 04:02:10 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Viresh Kumar X-Patchwork-Id: 100348 Delivered-To: patch@linaro.org Received: by 10.140.96.100 with SMTP id j91csp138001qge; Mon, 22 May 2017 21:02:21 -0700 (PDT) X-Received: by 10.98.32.18 with SMTP id g18mr29707057pfg.153.1495512141887; Mon, 22 May 2017 21:02:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1495512141; cv=none; d=google.com; s=arc-20160816; b=TfqUuyHbUw7VmQ/jKIMIgEa1LHRQgLCrNuiapJvmiu8NqI1m2VmQah0My0jFDZSaDz dzyEC2CaogpvnnNIOyNzd05w8lhYEjhhwfkjkv5duS1+xtUmFy2qmOwvOiyWMlHJ0exU pJYDsdIzMA9dWI2q1lsqs+JjoR1rNlSmJx9hEgDiCc8gOWEwveFD00y8bMBd9TQlKHqg LtEIZZDHVnZoYVm1SOHuYeA/J2xAn6/6cxOcu31nsHUXSj7VeNx+j6kEJQtF5Y5Kq724 /zZbvsXpvFxQmNxthtWmy3Tj5BCX5ngIOiqBbQL33e9KRpxanMj0LB3O/pT5L8v4vQX5 +lJg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=KlVF05LuOFYyV6WL9y/H3RCglRHP9/KdKT+n+jynnlw=; b=ic9QJwxdJdXzW9Kt4LOVW+JR8imKMrDdt+Fe0+4XYBdE/MXFrC7h3lgJoRfAGYCBW6 hWMy8ZNaVG12aOVPi6JHaIrPUQHunV3qXcq1Jr00yp5cOvVEtDg1UEEniYe6MVNpMTk+ 6tkKo7mqryKIv4QKqrNS63SM/e1hiH2KTuK99XRnFHJmd8cCLWhgC0E7/BIslKfqofAI lmtDmXq3ShQX/usJA25M0tghgSvFr1GvrIC/uvIH8qLZu+JhFxpMBAStcjsvAR74SOS1 s6tSt/fqRueX/EWxS3a8ijBx3X9J1DKAkfO4snda8pl+tbMDrUzSt0cU1SHtu6pTfQ+c QEOQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org; spf=pass (google.com: best guess record for domain of linux-pm-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-pm-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g23si19539687pli.273.2017.05.22.21.02.21; Mon, 22 May 2017 21:02:21 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-pm-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=@linaro.org; spf=pass (google.com: best guess record for domain of linux-pm-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-pm-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751237AbdEWECU (ORCPT + 14 others); Tue, 23 May 2017 00:02:20 -0400 Received: from mail-pf0-f177.google.com ([209.85.192.177]:33066 "EHLO mail-pf0-f177.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751222AbdEWECT (ORCPT ); Tue, 23 May 2017 00:02:19 -0400 Received: by mail-pf0-f177.google.com with SMTP id e193so101321934pfh.0 for ; Mon, 22 May 2017 21:02:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=KlVF05LuOFYyV6WL9y/H3RCglRHP9/KdKT+n+jynnlw=; b=XbJUdwObjCjRwowXOm+dlujFIyKuBlQpgO0Miv0s0Y0ja7XRqOoG/c4kY+4czMyJNv U7/asTOeESABSxpGbWKmwwY6igJxp1/PDzFpJrXPV0nn5aCnooDIQrUI3MKdiQFM/O6z ewSLkCdFB/OKxxYoJVcsrr5vPhW0A45l7KfPM= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=KlVF05LuOFYyV6WL9y/H3RCglRHP9/KdKT+n+jynnlw=; b=DsYfaolvOB8dpKjny+6aHiPdxCBsK28TY5Ky5bllzJgy+IKV6ZwZlROQOYWtiW3jJX ExOEGvAWDG5OdXg1lswaIJ/n+sRTNuH/fUlccgXpau+GW5Q+XlaW3tfk2m0uRsgQ+PV2 Klu8WCe7UCeOeCdegBjqN8Kd/aLjOgKyRIzTCer1ZVN6YpakyVCRGYVBnTU+Nm89hZC/ 0xnhAJckB1MTmV8YJNwJE3DSWjxPOQq6SjBh/aywLTGCj0jvIF3aLynGzDZJLTEAy9hH ZFHhWCwzIL3sdPG2rPUkEy4Li6oSO07xPKqGYTP/o6MbnchaoTtSRZq6faIGYDYnFJ5r XQkQ== X-Gm-Message-State: AODbwcBOY/a1TTQJvSqsIkdYIjr7NDJsa/tS6zxPGhQiejZO2PL2O0rC 0ez5lnckU6oKgSHw X-Received: by 10.98.71.214 with SMTP id p83mr29031861pfi.236.1495512138331; Mon, 22 May 2017 21:02:18 -0700 (PDT) Received: from localhost ([122.167.143.58]) by smtp.gmail.com with ESMTPSA id z21sm31765812pgc.15.2017.05.22.21.02.17 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 22 May 2017 21:02:17 -0700 (PDT) From: Viresh Kumar To: Rafael Wysocki , Viresh Kumar , Nishanth Menon , Stephen Boyd Cc: Viresh Kumar , linaro-kernel@lists.linaro.org, linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, Vincent Guittot Subject: [PATCH V2 1/4] PM / OPP: Reorganize _generic_set_opp_regulator() Date: Tue, 23 May 2017 09:32:10 +0530 Message-Id: X-Mailer: git-send-email 2.13.0.70.g6367777092d9 In-Reply-To: References: Sender: linux-pm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org The code was overly complicated here because of the limitations that we had with RCUs (Couldn't use opp-table and OPPs outside RCU protected section and can't call sleep-able routines from within that). But that is long gone now. Reorganize _generic_set_opp_regulator() in order to avoid using "struct dev_pm_set_opp_data" and copying data into it for the case where opp_table->set_opp is not set. Signed-off-by: Viresh Kumar Reviewed-by: Stephen Boyd --- drivers/base/power/opp/core.c | 73 ++++++++++++++++++++----------------------- 1 file changed, 34 insertions(+), 39 deletions(-) -- 2.13.0.70.g6367777092d9 diff --git a/drivers/base/power/opp/core.c b/drivers/base/power/opp/core.c index dae61720b314..c4590fc017ba 100644 --- a/drivers/base/power/opp/core.c +++ b/drivers/base/power/opp/core.c @@ -543,17 +543,18 @@ _generic_set_opp_clk_only(struct device *dev, struct clk *clk, return ret; } -static int _generic_set_opp(struct dev_pm_set_opp_data *data) +static int _generic_set_opp_regulator(const struct opp_table *opp_table, + struct device *dev, + unsigned long old_freq, + unsigned long freq, + struct dev_pm_opp_supply *old_supply, + struct dev_pm_opp_supply *new_supply) { - struct dev_pm_opp_supply *old_supply = data->old_opp.supplies; - struct dev_pm_opp_supply *new_supply = data->new_opp.supplies; - unsigned long old_freq = data->old_opp.rate, freq = data->new_opp.rate; - struct regulator *reg = data->regulators[0]; - struct device *dev= data->dev; + struct regulator *reg = opp_table->regulators[0]; int ret; /* This function only supports single regulator per device */ - if (WARN_ON(data->regulator_count > 1)) { + if (WARN_ON(opp_table->regulator_count > 1)) { dev_err(dev, "multiple regulators are not supported\n"); return -EINVAL; } @@ -566,7 +567,7 @@ static int _generic_set_opp(struct dev_pm_set_opp_data *data) } /* Change frequency */ - ret = _generic_set_opp_clk_only(dev, data->clk, old_freq, freq); + ret = _generic_set_opp_clk_only(dev, opp_table->clk, old_freq, freq); if (ret) goto restore_voltage; @@ -580,12 +581,12 @@ static int _generic_set_opp(struct dev_pm_set_opp_data *data) return 0; restore_freq: - if (_generic_set_opp_clk_only(dev, data->clk, freq, old_freq)) + if (_generic_set_opp_clk_only(dev, opp_table->clk, freq, old_freq)) dev_err(dev, "%s: failed to restore old-freq (%lu Hz)\n", __func__, old_freq); restore_voltage: /* This shouldn't harm even if the voltages weren't updated earlier */ - if (old_supply->u_volt) + if (old_supply) _set_opp_voltage(dev, reg, old_supply); return ret; @@ -603,10 +604,7 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) { struct opp_table *opp_table; unsigned long freq, old_freq; - int (*set_opp)(struct dev_pm_set_opp_data *data); struct dev_pm_opp *old_opp, *opp; - struct regulator **regulators; - struct dev_pm_set_opp_data *data; struct clk *clk; int ret, size; @@ -661,38 +659,35 @@ int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq) dev_dbg(dev, "%s: switching OPP: %lu Hz --> %lu Hz\n", __func__, old_freq, freq); - regulators = opp_table->regulators; - /* Only frequency scaling */ - if (!regulators) { + if (!opp_table->regulators) { ret = _generic_set_opp_clk_only(dev, clk, old_freq, freq); - goto put_opps; - } + } else if (!opp_table->set_opp) { + ret = _generic_set_opp_regulator(opp_table, dev, old_freq, freq, + IS_ERR(old_opp) ? NULL : old_opp->supplies, + opp->supplies); + } else { + struct dev_pm_set_opp_data *data; - if (opp_table->set_opp) - set_opp = opp_table->set_opp; - else - set_opp = _generic_set_opp; - - data = opp_table->set_opp_data; - data->regulators = regulators; - data->regulator_count = opp_table->regulator_count; - data->clk = clk; - data->dev = dev; - - data->old_opp.rate = old_freq; - size = sizeof(*opp->supplies) * opp_table->regulator_count; - if (IS_ERR(old_opp)) - memset(data->old_opp.supplies, 0, size); - else - memcpy(data->old_opp.supplies, old_opp->supplies, size); + data = opp_table->set_opp_data; + data->regulators = opp_table->regulators; + data->regulator_count = opp_table->regulator_count; + data->clk = clk; + data->dev = dev; - data->new_opp.rate = freq; - memcpy(data->new_opp.supplies, opp->supplies, size); + data->old_opp.rate = old_freq; + size = sizeof(*opp->supplies) * opp_table->regulator_count; + if (IS_ERR(old_opp)) + memset(data->old_opp.supplies, 0, size); + else + memcpy(data->old_opp.supplies, old_opp->supplies, size); - ret = set_opp(data); + data->new_opp.rate = freq; + memcpy(data->new_opp.supplies, opp->supplies, size); + + ret = opp_table->set_opp(data); + } -put_opps: dev_pm_opp_put(opp); put_old_opp: if (!IS_ERR(old_opp))