From patchwork Thu Nov 5 01:41:53 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Viresh Kumar X-Patchwork-Id: 56012 Delivered-To: patch@linaro.org Received: by 10.112.61.134 with SMTP id p6csp126838lbr; Wed, 4 Nov 2015 17:42:31 -0800 (PST) X-Received: by 10.66.155.197 with SMTP id vy5mr4043687pab.109.1446687751561; Wed, 04 Nov 2015 17:42:31 -0800 (PST) Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id ct3si6072756pad.103.2015.11.04.17.42.31; Wed, 04 Nov 2015 17:42:31 -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; 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; dkim=neutral (body hash did not verify) header.i=@linaro_org.20150623.gappssmtp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1031614AbbKEBmV (ORCPT + 28 others); Wed, 4 Nov 2015 20:42:21 -0500 Received: from mail-pa0-f45.google.com ([209.85.220.45]:36177 "EHLO mail-pa0-f45.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1031565AbbKEBmS (ORCPT ); Wed, 4 Nov 2015 20:42:18 -0500 Received: by pacdm15 with SMTP id dm15so45816471pac.3 for ; Wed, 04 Nov 2015 17:42:17 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro_org.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :in-reply-to:references; bh=/R0du/A4kDIoDjzyciy/zszZboupxZQRS+QWVU0nkgU=; b=OI9FlLCeOwl974OrnKaeiW+E3K4xLVHOmz9eU2XreY6Xp3mJc6tY8nlqVvHKmhdZxI HszhF6zlE4mzbFmUd2q6ZH15PvVb+dDKTCeTH1UTRLzeSw+KDWdxrin2ciTTtjn68cTV fNmaMAStnYvtWXEdHwBiGIKzZxbD1umBHkBMvNT+2W8vtBul/rfx1DbLexVm8htj8dX1 AjP5hmLxxE3ojhyRLHWmbc9LdnDSFMIaRfg2DSNpnmvWfy21Ex8hHDEfM0ubkk39RXQp p3hKshU5o+5NBW+Q3HoBfzVX/rzjasRfU+ifYEFn35vNGxp0PBLnXs5Kex6o6FqQtQ0Z EhjQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:in-reply-to:references; bh=/R0du/A4kDIoDjzyciy/zszZboupxZQRS+QWVU0nkgU=; b=PHPq5nSl2gUYhj23JYYvi6r9DcezDnbzzsVI25HaYZDTvd18RLqEsCKhQnXzVlJF6q qgqaEm1bxjMypuM/xRyEOEICsLAnqn7YtjVoKO/lIsQdVmCfR0fls37TYRs72cYrdvF4 kfEn7sd8WFC/ORotAjuqAZHTdb4vR9e7W1ffDgu+WLtXZB8oMeXb+KZBJ8zRDUgNjGeS 30C1zPe4XNPi7inA2Q+ibPYo+O21Rwj10pkJaUKOHMD4Hzl5Ca+obbCe68BwSkxs7qL/ m2INXxVOr1939qlrYPtjaohJoR8wM3YA0BerOYCAXRJRo1ZDbAdqd32TITJiALdEV5RY c6ng== X-Gm-Message-State: ALoCoQla9RVxc6YWnWvk8N0f4cpxdsEJRnNa4vfnDquDoQ5dLIm5e+k61AWVQzqxFFZeDb2EAcYr X-Received: by 10.68.135.73 with SMTP id pq9mr6053946pbb.53.1446687737355; Wed, 04 Nov 2015 17:42:17 -0800 (PST) Received: from localhost ([122.172.111.169]) by smtp.gmail.com with ESMTPSA id yp5sm4383059pac.38.2015.11.04.17.42.16 (version=TLSv1.2 cipher=RC4-SHA bits=128/128); Wed, 04 Nov 2015 17:42:16 -0800 (PST) From: Viresh Kumar To: Rafael Wysocki , robh+dt@kernel.org, sboyd@codeaurora.org, lee.jones@linaro.org Cc: linaro-kernel@lists.linaro.org, linux-pm@vger.kernel.org, mark.rutland@arm.com, pawel.moll@arm.com, ijc+devicetree@hellion.org.uk, galak@codeaurora.org, nm@ti.com, devicetree@vger.kernel.org, b.zolnierkie@samsung.com, m.szyprowski@samsung.com, Viresh Kumar , linux-kernel@vger.kernel.org (open list), "Rafael J. Wysocki" Subject: [PATCH V2 2/5] PM / OPP: Add {opp-microvolt|opp-microamp|turbo-mode|opp-suspend}- binding Date: Thu, 5 Nov 2015 07:11:53 +0530 Message-Id: <17a4388be606f21fe1d31b23180d41f6cabdd4b5.1446687367.git.viresh.kumar@linaro.org> X-Mailer: git-send-email 2.6.2.198.g614a2ac In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Depending on the version of hardware or its properties, which are only known at runtime, various properties of the OPP can change. For example, an OPP with frequency 1.2 GHz, may have different voltage/current requirements based on the version of the hardware it is running on. Similarly, it may or may not be a turbo or suspend OPP on those circumstances. In order to not replicate the same OPP tables for varying values of all such fields, this commit introduces the concept of opp-property-. The can be chosen by the platform at runtime, and OPPs will be initialized depending on that name string. Currently support is extended for the following properties: - opp-microvolt- - opp-microamp- - turbo-mode- - opp-suspend- If the name string isn't provided by the platform, or if it is provided but doesn't match the properties present in the OPP node, we will fall back to the original properties without the - string, if they are available. Reviewed-by: Stephen Boyd Signed-off-by: Viresh Kumar --- Documentation/devicetree/bindings/opp/opp.txt | 58 +++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) -- 2.6.2.198.g614a2ac -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ diff --git a/Documentation/devicetree/bindings/opp/opp.txt b/Documentation/devicetree/bindings/opp/opp.txt index d072fa0ffbd4..61c6f25cf8e2 100644 --- a/Documentation/devicetree/bindings/opp/opp.txt +++ b/Documentation/devicetree/bindings/opp/opp.txt @@ -100,6 +100,14 @@ properties. Entries for multiple regulators must be present in the same order as regulators are specified in device's DT node. +- opp-microvolt-: Named opp-microvolt property. This is exactly similar to + the above opp-microvolt property, but allows multiple voltage ranges to be + provided for the same OPP. At runtime, the platform can pick a and + matching opp-microvolt- property will be enabled for all OPPs. If the + platform doesn't pick a specific or the doesn't match with any + opp-microvolt- properties, then opp-microvolt property shall be used, if + present. + - opp-microamp: The maximum current drawn by the device in microamperes considering system specific parameters (such as transients, process, aging, maximum operating temperature range etc.) as necessary. This may be used to @@ -112,6 +120,9 @@ properties. for few regulators, then this should be marked as zero for them. If it isn't required for any regulator, then this property need not be present. +- opp-microamp-: Named opp-microamp property. Similar to + opp-microvolt- property, but for microamp instead. + - clock-latency-ns: Specifies the maximum possible transition latency (in nanoseconds) for switching to this OPP from any other OPP. @@ -120,9 +131,15 @@ properties. frequency for a short duration of time limited by the device's power, current and thermal limits. +- turbo-mode-: Named turbo-mode property. Similar to opp-microvolt- + property, but for turbo mode instead. + - opp-suspend: Marks the OPP to be used during device suspend. Only one OPP in the table should have this. +- opp-suspend-: Named opp-suspend property. Similar to + opp-microvolt- property, but for suspend opp instead. + - opp-supported-hw: This enables us to select only a subset of OPPs from the larger OPP table, based on what version of the hardware we are running on. We still can't have multiple nodes with the same opp-hz value in OPP table. @@ -528,3 +545,44 @@ Example 6: opp-supported-hw }; }; }; + +Example 7: opp-microvolt-, opp-microamp-, turbo-mode-, +opp-suspend-: +(example: device with two possible microvolt ranges: slow and fast) + +/ { + cpus { + cpu@0 { + compatible = "arm,cortex-a7"; + ... + + operating-points-v2 = <&cpu0_opp_table>; + }; + }; + + cpu0_opp_table: opp_table0 { + compatible = "operating-points-v2"; + opp-shared; + + opp00 { + opp-hz = /bits/ 64 <1000000000>; + opp-microvolt-slow = <900000 915000 925000>; + opp-microvolt-fast = <970000 975000 985000>; + opp-microamp-slow = <70000>; + opp-microamp-fast = <71000>; + turbo-mode-slow; /* Will be used as turbo only if 'slow' is chosen */ + opp-suspend-slow; /* Will be used as suspend-opp only if 'slow' is chosen */ + }; + + opp01 { + opp-hz = /bits/ 64 <1200000000>; + opp-microvolt-slow = <900000 915000 925000>, /* Supply vcc0 */ + <910000 925000 935000>; /* Supply vcc1 */ + opp-microvolt-fast = <970000 975000 985000>, /* Supply vcc0 */ + <960000 965000 975000>; /* Supply vcc1 */ + opp-microamp = <70000>; /* Will be used for both slow/fast */ + turbo-mode; /* Always used as turbo */ + opp-suspend-fast; /* Will be used as suspend opp only if 'fast' is chosen */ + }; + }; +};