Received: by 2002:a05:7412:3784:b0:e2:908c:2ebd with SMTP id jk4csp1303452rdb; Mon, 2 Oct 2023 05:51:41 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEP8sMLOcuPsGuyktpYlt+07bQrMLF2nT6CSUHYzBvjeKadKPPNQ760+09Ey2UQH6Kpds1E X-Received: by 2002:a17:902:da8d:b0:1c0:d7a9:1c48 with SMTP id j13-20020a170902da8d00b001c0d7a91c48mr12117299plx.49.1696251101086; Mon, 02 Oct 2023 05:51:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1696251101; cv=none; d=google.com; s=arc-20160816; b=GqK6rQtirQYelZXReU4QHqiAOr2MIRF3Y/WUhfj26Gcs/v7jrzaDweAOudDp4okpac Z87+PI05Wdf5f7zaA7YD+uaa6PP0IEknCe9Nc7SCLttLHLPgUm8hQY4TSnrZvo/IJl6f DLYgfvtfd37+vSJVNC1Uj57jPV9kXmOok3ysQ9yJbtmJRlXtBk8nelDLKN53wAy6s8LV f+2CdRKQCgteun8QYz0h/zjwQ0h1Vu6LTzCvzvzZEkveIpV67pFdplH4dfM4Hcx/jOIa QT8U1pY8gnjgesncNf3k5EFNW8bk2Q14Cbe6yEtpmy8zLwsUt6kvBQOr0tDUjzDWBmpA ro1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:content-transfer-encoding:mime-version :message-id:date:subject:from:dkim-signature; bh=a+Ccx9PHxjjim4MCiySQlvJuRSaLuBjXA+j1gxO9c74=; fh=4lN4E9827fGYwa6vjzoE+jRMn55X5nnh/n8g5iW7XVM=; b=TtLvEsbQRfzQA8HZa9IKkTOmgdHuBkZm4al5kSDltOCgtUVAwgLLdHCO2vJMujbVkL J0UJOWor2BgNo5Nws4BqpiYTZ0L0H/WVx3PU6buQNqvqrTSFNzsQZs52lP+QC54xwNfe Cr2A/REUeUt2/arqmMljDhs1uww+L6f7GvnX+Nsx0pRPZkFHNLBMmIRNxlFyBqv9NNdB 5RSlomQhgCiqhOVDPhpbJBRYkS+8PMC4Grl4lJA0rlhD/R5hRdW2IfbjftUjSGvaMAv3 MlHrCtCH5IeQnbmcLCYQEcuBYEA0SdQhcj+Y6fpWrUCXztUn5QooUBbQvEgFiDZBY7G7 uwXw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=KBIESpwQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from agentk.vger.email (agentk.vger.email. [23.128.96.32]) by mx.google.com with ESMTPS id s17-20020a170902ea1100b001bf01fee6bcsi20787622plg.610.2023.10.02.05.51.40 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 02 Oct 2023 05:51:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) client-ip=23.128.96.32; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=KBIESpwQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by agentk.vger.email (Postfix) with ESMTP id AF0488057E40; Mon, 2 Oct 2023 02:24:17 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236075AbjJBJXw (ORCPT + 99 others); Mon, 2 Oct 2023 05:23:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50570 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236054AbjJBJXu (ORCPT ); Mon, 2 Oct 2023 05:23:50 -0400 Received: from mail-wm1-x32c.google.com (mail-wm1-x32c.google.com [IPv6:2a00:1450:4864:20::32c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EDD9883; Mon, 2 Oct 2023 02:23:47 -0700 (PDT) Received: by mail-wm1-x32c.google.com with SMTP id 5b1f17b1804b1-406619b53caso23534445e9.1; Mon, 02 Oct 2023 02:23:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1696238626; x=1696843426; darn=vger.kernel.org; h=cc:to:content-transfer-encoding:mime-version:message-id:date :subject:from:from:to:cc:subject:date:message-id:reply-to; bh=a+Ccx9PHxjjim4MCiySQlvJuRSaLuBjXA+j1gxO9c74=; b=KBIESpwQs58xycoewYWjewlTZYa/5l4L/cVHzKrAwXL/pOtO2eHewys7jha0hETHb2 xlWX2wj4o/52wGlJYnZAUApQU4b8BMhHukZr5q+u4sSTAAuHOTWOOnFjvqAAyr2BaTn2 Q0Ud4G/gI8WaxxMsnKT+NohN7CZ2kjO0DgQbmgQxoB++WyneVyFMmSjnX8m1IiV6xxC4 quogZYIt+YjiDxorSFHLXlQyV1m++A2o2srLUfXQcPPWFwSwIlqIy+QNe5quY9KvnSCj FY6U3DWstdkufq2Q9Acff57mjQtM0N1rNZyO5qd9OLrCWXxjmimvhACsIeUqaQ/RzGrX 1Ztw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1696238626; x=1696843426; h=cc:to:content-transfer-encoding:mime-version:message-id:date :subject:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=a+Ccx9PHxjjim4MCiySQlvJuRSaLuBjXA+j1gxO9c74=; b=nKc3eMvjWAG9cxuzqZ/yKI1zKQ5LTXleobr+whg51DW3oLn1skzgp6MaDeC3BXzlj5 fo8e8QPGLLg5guyJhAoisQmno/2xJOTGibkic8VCROIQbBnZROFOy9pCxvig6ysUsvM1 Pe3LlDdULoRUBOa9qr1w8rj3/zZBg7c2e7rogpx+MsuI8TWbKXiPoF8XQKznFqmQU5LM GY/RkPKKkKAO0fyWbxgokIggk8/CYeAKz16eaA1Fc7oDc3NkhVgjoEmITLzeZEIy0b44 UCiVKE/3l/ZTVetkNavpGAKKqfedCJ93hZ8p1TiLigsrae8n633P1eKN5gu5qmZJdpYq LrDw== X-Gm-Message-State: AOJu0YwHq7eO73l+JuVyX1EtO0xzqzXGIe0MDGlzMi47WaSYr1/Jthdt y6zBzVVqbk2+mdPyiCrooNd9xBQZn0U= X-Received: by 2002:a05:600c:2946:b0:401:4542:5edd with SMTP id n6-20020a05600c294600b0040145425eddmr10517340wmd.34.1696238625927; Mon, 02 Oct 2023 02:23:45 -0700 (PDT) Received: from [127.0.1.1] ([91.230.2.244]) by smtp.gmail.com with ESMTPSA id o30-20020a05600c511e00b003fef5e76f2csm6156589wms.0.2023.10.02.02.23.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 02 Oct 2023 02:23:45 -0700 (PDT) From: Benjamin Bara Subject: [PATCH RFC 0/4] clk: re-set required rates during clk_set_rate() Date: Mon, 02 Oct 2023 11:23:31 +0200 Message-Id: <20231002-ccf-set-multiple-v1-0-2df5e9eb3738@skidata.com> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-B4-Tracking: v=1; b=H4sIABOMGmUC/6tWKk4tykwtVrJSqFYqSi3LLM7MzwNyDHUUlJIzE vPSU3UzU4B8JSMDI2MDSyNz3eTkNN3i1BLd3NKcksyCnFRd42QjS0MTQ7O0ZEsLJaC2gqLUtMw KsJHRSkFuzkqxtbUAcqlFvWcAAAA= To: Maxime Ripard , Michael Turquette , Stephen Boyd Cc: Frank Oltmanns , Adam Ford , linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org, Benjamin Bara X-Mailer: b4 0.12.3 X-Spam-Status: No, score=-0.6 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (agentk.vger.email [0.0.0.0]); Mon, 02 Oct 2023 02:24:17 -0700 (PDT) Hi! This is a spin-off of my initial series[1] with the core-related parts picked out. Without the core part, the rest of the series only partly makes sense, therefore I wanted to clarify the state of this first. That's also the reason why it is marked as RFC for now. Background: The CCF is currently very rigid in terms of dealing with multiple rate changes in a single clk_set_rate() call. However, with the CLK_SET_RATE_PARENT property, it is very likely that a shared clock has a couple of children which are changed "by accident" when the common parent is changed. These children might be clock inputs of hardware modules, which might have set a required rate previously. These required rates are most likely still expected after the parent has been changed by another clock (e.g. a sibling). Currently, it is not very trivial to get these required rates inside of a clock driver's {determine,round}_rate() op. Therefore, I think the core should also participate in the process of ensuring that consumer-set requirements are still fulfilled after a rate has changed. Idea: The idea is to have three rates set per clock, which need to be considered during the whole process: 1. req_rate: This is the rate required by a consumer. It is set during a clk_set_rate() call. 2. new_rate: This is the "new planned rate" for the clock, which it will set, once the "finding new rates" process is finished. 3. req_rate_tmp: This rate is set if the clock is "required to change" during the process. It basically means that the clock is an ancestor of a rate-change trigger. With these available, the core is able to validate the changed subtree in a more simple way. It also allows us to re-enter calc_new_rates(), which is one of the key components of clk_set_rate(). Thanks & regards Benjamin [1] https://lore.kernel.org/lkml/20230918-imx8mp-dtsi-v1-0-1d008b3237c0@skidata.com/ --- Benjamin Bara (4): clk: only set req_rate if it is set by consumer clk: reset new_rates for next run clk: introduce req_rate_tmp clk: consider rates when calculating subtree drivers/clk/clk.c | 125 ++++++++++++++++++++++++++++++++++++++++++++++-------- 1 file changed, 107 insertions(+), 18 deletions(-) --- base-commit: df964ce9ef9fea10cf131bf6bad8658fde7956f6 change-id: 20230927-ccf-set-multiple-3c291416fc98 Best regards, -- Benjamin Bara