From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-11.6 required=3.0 tests=DKIMWL_WL_MED,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT,USER_IN_DEF_DKIM_WL autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id C5870C5B57D for ; Wed, 3 Jul 2019 01:10:26 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 9F5AA20645 for ; Wed, 3 Jul 2019 01:10:26 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b="gD1H9uju" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727066AbfGCBK0 (ORCPT ); Tue, 2 Jul 2019 21:10:26 -0400 Received: from mail-pg1-f202.google.com ([209.85.215.202]:33187 "EHLO mail-pg1-f202.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727354AbfGCBKZ (ORCPT ); Tue, 2 Jul 2019 21:10:25 -0400 Received: by mail-pg1-f202.google.com with SMTP id k19so513402pgl.0 for ; Tue, 02 Jul 2019 18:10:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:message-id:mime-version:subject:from:to:cc; bh=+/NgGwFACy34LZMNgdF6kK1NINvGCtP2Z/MvjjI7Ew8=; b=gD1H9ujuBDHYxyQRM/QxbAM3l52LJlazN/k0bex99R3tQl+EKLtZtPVAAE3Y7PRS83 so+dRF8C5h0z3U2iTRMh+m0UC9PJQGeEpO4BN2p1AG2qg08y9u8qsKrA3a473FdvYzDQ 9o+1ImEqm49Ba4/rIxrNfFQ5a6gQtJ+MHqIL+IhQBci2U/KwaQwea/xCfZC4wGCQLv/A sJtLlgV5jRHx+WJoNEd5sJJvcr1P38owycNXEwhnHsiAUfil7US4V3sb0+0GfyeU08PO rlOg/95z7CY5CPeeNzBD6+wNSiJc9qFlzW/OXrkzUe8es9PaWmzgRcmL1CeX1BeGeC4Z mCug== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=+/NgGwFACy34LZMNgdF6kK1NINvGCtP2Z/MvjjI7Ew8=; b=Vp8Y06hICBOitL2ieG8H7t7xtFC7v5LnYluhwEp6JzM++Cp0mMJW1GgrjdxP1qJbVg kXL4/hiv5c1aK5YwofEhpcPJDyX/oCj5LKYULdKvby6gIzEyujNlgNMeZXE5YyLKcgY7 27CAaieI8I2eDRFR1g90SFrkQNf4UDDbHg+8UT3KZskgF5JSPjGaUhNo/58ROHkgKM66 FDFHj2RCu5TZMl4rbjE9IlZDr2jrDYVCYQ0YhXSV5ohJpTWrvakAtybKKQ1IA77Zwn+5 qTP44H/KAdNFaUbjn8UAiFJ0Tj47fSDZdH6f+OKxkZi9KqzRWOSB1wHYM/fNlmW+TxAR FqAA== X-Gm-Message-State: APjAAAXICyXlmlRZP9AK3xtHwoBN/fg+vQyPOoHuASyjJ5Te0eoKjjjC gLagHTdqAFvLIbrC+oN15QD+2zQKXKPtaJ4= X-Google-Smtp-Source: APXvYqxjLAm5FeB4krGVnJ8xrlNX//iGRKhBSPNoeTp221sbsHnxh0Xh8hiTM1YF3feQVjQjV1Qr19ueNgCNDpo= X-Received: by 2002:a63:7c0e:: with SMTP id x14mr33166685pgc.65.1562116224469; Tue, 02 Jul 2019 18:10:24 -0700 (PDT) Date: Tue, 2 Jul 2019 18:10:14 -0700 Message-Id: <20190703011020.151615-1-saravanak@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.22.0.410.gd8fdbe21b5-goog Subject: [PATCH v3 0/6] Introduce Bandwidth OPPs for interconnect paths From: Saravana Kannan To: Georgi Djakov , Rob Herring , Mark Rutland , Viresh Kumar , Nishanth Menon , Stephen Boyd , "Rafael J. Wysocki" Cc: Saravana Kannan , vincent.guittot@linaro.org, seansw@qti.qualcomm.com, daidavid1@codeaurora.org, Rajendra Nayak , sibis@codeaurora.org, bjorn.andersson@linaro.org, evgreen@chromium.org, kernel-team@android.com, linux-pm@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Sender: linux-pm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org Interconnects and interconnect paths quantify their performance levels in terms of bandwidth and not in terms of frequency. So similar to how we have frequency based OPP tables in DT and in the OPP framework, we need bandwidth OPP table support in the OPP framework and in DT. Since there can be more than one interconnect path used by a device, we also need a way to assign a bandwidth OPP table to an interconnect path. This patch series: - Adds opp-peak-KBps and opp-avg-KBps properties to OPP DT bindings - Adds interconnect-opp-table property to interconnect DT bindings - Adds OPP helper functions for bandwidth OPP tables - Adds icc_get_opp_table() to get the OPP table for an interconnect path So with the DT bindings added in this patch series, the DT for a GPU that does bandwidth voting from GPU to Cache and GPU to DDR would look something like this: gpu_cache_opp_table: gpu_cache_opp_table { compatible = "operating-points-v2"; gpu_cache_3000: opp-3000 { opp-peak-KBps = <3000>; opp-avg-KBps = <1000>; }; gpu_cache_6000: opp-6000 { opp-peak-KBps = <6000>; opp-avg-KBps = <2000>; }; gpu_cache_9000: opp-9000 { opp-peak-KBps = <9000>; opp-avg-KBps = <9000>; }; }; gpu_ddr_opp_table: gpu_ddr_opp_table { compatible = "operating-points-v2"; gpu_ddr_1525: opp-1525 { opp-peak-KBps = <1525>; opp-avg-KBps = <452>; }; gpu_ddr_3051: opp-3051 { opp-peak-KBps = <3051>; opp-avg-KBps = <915>; }; gpu_ddr_7500: opp-7500 { opp-peak-KBps = <7500>; opp-avg-KBps = <3000>; }; }; gpu_opp_table: gpu_opp_table { compatible = "operating-points-v2"; opp-shared; opp-200000000 { opp-hz = /bits/ 64 <200000000>; }; opp-400000000 { opp-hz = /bits/ 64 <400000000>; }; }; gpu@7864000 { ... operating-points-v2 = <&gpu_opp_table>, <&gpu_cache_opp_table>, <&gpu_ddr_opp_table>; interconnects = <&mmnoc MASTER_GPU_1 &bimc SLAVE_SYSTEM_CACHE>, <&mmnoc MASTER_GPU_1 &bimc SLAVE_DDR>; interconnect-names = "gpu-cache", "gpu-mem"; interconnect-opp-table = <&gpu_cache_opp_table>, <&gpu_ddr_opp_table> }; Cheers, Saravana Saravana Kannan (6): dt-bindings: opp: Introduce opp-peak-KBps and opp-avg-KBps bindings OPP: Add support for bandwidth OPP tables OPP: Add helper function for bandwidth OPP tables OPP: Add API to find an OPP table from its DT node dt-bindings: interconnect: Add interconnect-opp-table property interconnect: Add OPP table support for interconnects .../bindings/interconnect/interconnect.txt | 8 ++ Documentation/devicetree/bindings/opp/opp.txt | 15 +++- drivers/interconnect/core.c | 27 ++++++- drivers/opp/core.c | 51 +++++++++++++ drivers/opp/of.c | 76 ++++++++++++++++--- drivers/opp/opp.h | 4 +- include/linux/interconnect.h | 7 ++ include/linux/pm_opp.h | 26 +++++++ 8 files changed, 199 insertions(+), 15 deletions(-) -- 2.22.0.410.gd8fdbe21b5-goog