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=-7.1 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT 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 31715C433E5 for ; Wed, 22 Jul 2020 11:01:43 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 099FB20771 for ; Wed, 22 Jul 2020 11:01:43 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="GfK17w9A" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726503AbgGVLBl (ORCPT ); Wed, 22 Jul 2020 07:01:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47690 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726390AbgGVLBl (ORCPT ); Wed, 22 Jul 2020 07:01:41 -0400 Received: from mail-wr1-x444.google.com (mail-wr1-x444.google.com [IPv6:2a00:1450:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 28402C0619DC for ; Wed, 22 Jul 2020 04:01:41 -0700 (PDT) Received: by mail-wr1-x444.google.com with SMTP id y3so1472154wrl.4 for ; Wed, 22 Jul 2020 04:01:41 -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:mime-version :content-transfer-encoding; bh=1sISKqG3zytnruvPe3/sMoutNe9YJtA5YhpTs8Hs22Q=; b=GfK17w9A7urar0bbCno8XvDiWdKYtCn/FkvPPArA+GEu1ZXhnvZ9bAoakVcJhb1LwB lJAYp1XvgXaOSu3TD6gMvEwpokTWVzY+8o/e4yDWUWImmsTeZ5eBCvp3ffROdkEXsCOC O7wNzG5tJKLjVlkL0IhrVBD26gbfXwfvzDXO9UkMBoeOwJPervPItYGXbfzI4yQHGSc8 c9kaNVZ2W8Q4AErxprcIx01PSnUQXWkcUQk7+f6VfHZMNAn1tSSoVqT0JzlHEKRALQ6x MuNIEfo7OLSYXpX/IJQKjmn+I1MtwyxTRCGxaSjFHCWwyoHfJbOFfTCZU6fvmms10wG/ lhlQ== 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:mime-version :content-transfer-encoding; bh=1sISKqG3zytnruvPe3/sMoutNe9YJtA5YhpTs8Hs22Q=; b=XN11JAd07ebL68+5bJ4sTfR99Yh4MfURhD6ozF+y61Lzc5PpM9rG9nLUVL0yostwwD tdnJ5g7li5tax+E0Z/MYLAJCLdV35C5ES7JrjWH8bHFyhuMTTxVWlodoH4hBrEACqUtm vQH+U/pJaRVRmWBYH9U4Rnl+fQmgLt+Sahw/tzTAgIwwVJJyQnSus/NrmtFDD6RKlBPs zKpzeoFa3h4XuQXYuTafXURzETDJJIpbuKebF2nbL8k6xAzhb62aewLky5x6SLaeRfos jXWeryoC/gX6eg/gO+7L/qMsKqOLNLd2npcktUU//HL8XOFITpUzSiJTklAzEv4H9zUR QKJQ== X-Gm-Message-State: AOAM5311LOylUVoZu8UZvO5m5p2ia8xvNO3TW3JnGK0SqaNc4FX8zboQ /8n+BWYhUVc+kSGUXBWMkLOncQ== X-Google-Smtp-Source: ABdhPJzvbJiEbZhTK9KtS+CuXvFxkQ841o0YWwDshK+1uhQj4fRq4YoTcgct5xjCsALL1vxZi3oyjw== X-Received: by 2002:adf:e8ca:: with SMTP id k10mr14176435wrn.110.1595415699849; Wed, 22 Jul 2020 04:01:39 -0700 (PDT) Received: from localhost.localdomain ([212.45.67.2]) by smtp.googlemail.com with ESMTPSA id y6sm41256164wrr.74.2020.07.22.04.01.38 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Wed, 22 Jul 2020 04:01:39 -0700 (PDT) From: Georgi Djakov To: linux-pm@vger.kernel.org Cc: saravanak@google.com, mdtipton@codeaurora.org, okukatla@codeaurora.org, bjorn.andersson@linaro.org, vincent.guittot@linaro.org, georgi.djakov@linaro.org, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 0/2] Add interconnect sync state support Date: Wed, 22 Jul 2020 14:01:37 +0300 Message-Id: <20200722110139.24778-1-georgi.djakov@linaro.org> X-Mailer: git-send-email 2.26.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-arm-msm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-arm-msm@vger.kernel.org Bootloaders often leave some system resources enabled such as clocks, regulators, interconnects etc. We want to keep these resources enabled until all their consumers are probed. These resources are often shared, so we must wait for all the consumers to come up, before deciding whether to turn them off or change the configuration. This patchset is trying to solve the above problem just for the on-chip interconnects. The problem is solved by allowing the interconnect providers to specify an initial bandwidth values, which are enforced during boot as floor values, while the requests from all consumers are being collected. Then the sync_state() callback is used to signal when all consumers have been probed, meaning that the floor bandwidth is not needed anymore and the framework is ready to re-aggregate and process all requests. v2: * Support initial values for both average and peak bandwidth (Mike) * Skip aggregating/setting for nodes that don't specify initial bw (Mike) * Drop patch 2/4: Add get_bw() callback (Mike) * Squash patches 3 and 4. v1: https://lore.kernel.org/lkml/20200709110705.30359-1-georgi.djakov@linaro.org/ Georgi Djakov (2): interconnect: Add sync state support interconnect: qcom: Use icc_sync_state in sdm845 and osm-3l drivers drivers/interconnect/core.c | 61 +++++++++++++++++++++++++++ drivers/interconnect/qcom/osm-l3.c | 3 ++ drivers/interconnect/qcom/sdm845.c | 3 ++ include/linux/interconnect-provider.h | 5 +++ 4 files changed, 72 insertions(+)