Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp3654257img; Mon, 25 Mar 2019 15:01:12 -0700 (PDT) X-Google-Smtp-Source: APXvYqx/jRC1ejpgnpAFBQ6hftjL2hg9tO5GJkq+7zUkBBjcOBXPQpuo0lYXhsi6DLKCdrFJYvjs X-Received: by 2002:a63:158:: with SMTP id 85mr25924203pgb.351.1553551272414; Mon, 25 Mar 2019 15:01:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553551272; cv=none; d=google.com; s=arc-20160816; b=ZFpFBEnfADn9uqIqWcfhEAKSPV2DG+LFe60d7JEepgXo/ENSzwtcF7aPmHjfJlkDUP dZRZqli9emV83mCkM4nfs/i+EMpazCb4d5rDOnYuiixQ+07Evr+V+5xXG4g5novG/Nj8 GsXu2nbfGzqCeri0HFktA8Vlx+FQaDYyJeVvuZZYnpBeuBayladgWA27TORPPiwKb1uS yW+f08is485SnPwTWzZWTd0UC+F+ijQqgQ69MnEGL3u2OOt3XAOzh1fcfSfanvDrSoUY pg3nDLbUCJSGF3jTNpc9vVCncmucSd1pjrUlh+AO7QoYVAipMKtMZjYuH+vdF6um1pBa BmPg== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=QLAFA68lSANPPns8ihSYXWk2a4cargQcB+JN0UkXkTg=; b=S0DnGW3pkFn1vq4UseB6LQrRvicwER0UiKC2/aZiVWOQGs0c62F3x326ltrvJlOUw9 LNYAvuPgrTz2XB2ADoYmbNhbCc4dQCx4gqRAg7QXPZWd8Rt+hUFcr/9dFhLC1Mnzx41n MO1AoWLSYvO2cNp4F7DF+EMitdNUDQqqsxpGxhHUwIr/pGYb0Rtl/36Cmdv7ta/MSZg6 eth9Dhqmh0IRgQT0veD66Hgcfn/OLZL16r/HiFgoxPqlmsws7o6CgHUDaObfNYVQc6yn vGn/6wHgEBFCxpRriuug8z5uE92avROP0gkyBJpwl6Lws5UGLafvDEsnosXCbPEMlu0G EB+g== ARC-Authentication-Results: i=1; mx.google.com; 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 m18si4033612pls.18.2019.03.25.15.00.57; Mon, 25 Mar 2019 15:01:12 -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; 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 S1730578AbfCYV7H (ORCPT + 99 others); Mon, 25 Mar 2019 17:59:07 -0400 Received: from muru.com ([72.249.23.125]:42610 "EHLO muru.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729478AbfCYV7G (ORCPT ); Mon, 25 Mar 2019 17:59:06 -0400 Received: from hillo.muru.com (localhost [127.0.0.1]) by muru.com (Postfix) with ESMTP id 9C0DD81AE; Mon, 25 Mar 2019 21:59:18 +0000 (UTC) From: Tony Lindgren To: linux-omap@vger.kernel.org Cc: Dave Gerlach , Faiz Abbas , Greg Kroah-Hartman , Keerthy , Nishanth Menon , Peter Ujfalusi , Roger Quadros , Suman Anna , Tero Kristo , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: [PATCH 04/14] bus: ti-sysc: Move legacy platform data idling into separate functions Date: Mon, 25 Mar 2019 14:58:39 -0700 Message-Id: <20190325215849.13182-5-tony@atomide.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190325215849.13182-1-tony@atomide.com> References: <20190325215849.13182-1-tony@atomide.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Let's move the legacy idle and enable into separate functions to simplify PM runtime functions a bit. Signed-off-by: Tony Lindgren --- drivers/bus/ti-sysc.c | 78 +++++++++++++++++++++++++++---------------- 1 file changed, 50 insertions(+), 28 deletions(-) diff --git a/drivers/bus/ti-sysc.c b/drivers/bus/ti-sysc.c --- a/drivers/bus/ti-sysc.c +++ b/drivers/bus/ti-sysc.c @@ -622,9 +622,50 @@ static void sysc_show_registers(struct sysc *ddata) buf); } -static int __maybe_unused sysc_runtime_suspend(struct device *dev) +static int __maybe_unused sysc_runtime_suspend_legacy(struct device *dev, + struct sysc *ddata) +{ + struct ti_sysc_platform_data *pdata; + int error; + + pdata = dev_get_platdata(ddata->dev); + if (!pdata) + return 0; + + if (!pdata->idle_module) + return -ENODEV; + + error = pdata->idle_module(dev, &ddata->cookie); + if (error) + dev_err(dev, "%s: could not idle: %i\n", + __func__, error); + + return 0; +} + +static int __maybe_unused sysc_runtime_resume_legacy(struct device *dev, + struct sysc *ddata) { struct ti_sysc_platform_data *pdata; + int error; + + pdata = dev_get_platdata(ddata->dev); + if (!pdata) + return 0; + + if (!pdata->enable_module) + return -ENODEV; + + error = pdata->enable_module(dev, &ddata->cookie); + if (error) + dev_err(dev, "%s: could not enable: %i\n", + __func__, error); + + return 0; +} + +static int __maybe_unused sysc_runtime_suspend(struct device *dev) +{ struct sysc *ddata; int error = 0, i; @@ -634,19 +675,11 @@ static int __maybe_unused sysc_runtime_suspend(struct device *dev) return 0; if (ddata->legacy_mode) { - pdata = dev_get_platdata(ddata->dev); - if (!pdata) - return 0; - - if (!pdata->idle_module) - return -ENODEV; - - error = pdata->idle_module(dev, &ddata->cookie); - if (error) - dev_err(dev, "%s: could not idle: %i\n", - __func__, error); + error = sysc_runtime_suspend_legacy(dev, ddata); + if (!error) + ddata->enabled = false; - goto idled; + return error; } for (i = 0; i < ddata->nr_clocks; i++) { @@ -659,7 +692,6 @@ static int __maybe_unused sysc_runtime_suspend(struct device *dev) clk_disable(ddata->clocks[i]); } -idled: ddata->enabled = false; return error; @@ -667,7 +699,6 @@ static int __maybe_unused sysc_runtime_suspend(struct device *dev) static int __maybe_unused sysc_runtime_resume(struct device *dev) { - struct ti_sysc_platform_data *pdata; struct sysc *ddata; int error = 0, i; @@ -677,19 +708,11 @@ static int __maybe_unused sysc_runtime_resume(struct device *dev) return 0; if (ddata->legacy_mode) { - pdata = dev_get_platdata(ddata->dev); - if (!pdata) - return 0; + error = sysc_runtime_resume_legacy(dev, ddata); + if (!error) + ddata->enabled = true; - if (!pdata->enable_module) - return -ENODEV; - - error = pdata->enable_module(dev, &ddata->cookie); - if (error) - dev_err(dev, "%s: could not enable: %i\n", - __func__, error); - - goto awake; + return error; } for (i = 0; i < ddata->nr_clocks; i++) { @@ -704,7 +727,6 @@ static int __maybe_unused sysc_runtime_resume(struct device *dev) return error; } -awake: ddata->enabled = true; return error; -- 2.21.0