Received: by 2002:a89:2c3:0:b0:1ed:23cc:44d1 with SMTP id d3csp825653lqs; Tue, 5 Mar 2024 19:20:20 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCV747kZOF14MD9h1Z/jxI/HLNQKhr1wYmI4Ix0cXyZelyzj8UVXfe6aK/cWYZqdyWi+fBHb+n7+s2TdFoRSuydrKdwXWDRTtY4kjdPSyA== X-Google-Smtp-Source: AGHT+IGThQvZitVDRMGno6LD8kGIPsOCHS3UdGnw9k6vVGZfs51X0ijrWp+SDXkj7QczdpRZK5hi X-Received: by 2002:a05:6870:d696:b0:221:404e:78b5 with SMTP id z22-20020a056870d69600b00221404e78b5mr3417590oap.46.1709695220564; Tue, 05 Mar 2024 19:20:20 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1709695220; cv=pass; d=google.com; s=arc-20160816; b=To01IfrWtBL3+kvs/+3ud5N3ThcZV0yKh1FP7CO3oOXWiC3WjtL2q+8vrOOwSnKFh3 BZsBXrKPNQSWKxvWRrBjcZfDONfUpZMVTXvaemt4JT9q+9o+3eYqU1jS1HZFRz+9egt5 PG/lD5kwUo8s6wUTGmgfD+nbOzuJairkHOqXbON4XSgCEY+rIaJppW0EFUV+6uXHfIr4 2MgCU6r86zoC9rlc47XiKaP1aR/BZXGxkMddnNfUDMSm+CRFdQsTaAhMhyZv/UbfcTKP 8vq5Dm5rlntgl264zO7c1PP7uQqEw54n7HrYiUUiQ9bLA5vCqDEKHS9pMbMgZlWUDAl/ tjQg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:cc:to:subject:from:content-language :user-agent:mime-version:list-unsubscribe:list-subscribe:list-id :precedence:date:message-id:dkim-signature; bh=kZFeGCf76AtADk4ySWTFDtvJLdQB6MyBdHLu8Wy+eQQ=; fh=hqQTN1WzyOA3nEvo/ibIbuK/2MMqG+3hDkUH19rY21M=; b=Zk1H41CxDbouwTiecDvyYSTc4Irq7JepPUodIR+4W/uYYvKlSwJ4euFzY2EDkLiMFy 5vI01wjuLoaKoLdEgAWJYlSM6A6g37DXiXTQiJOkDr635zhKyi169DYdPIxW9X9S7AcM Ej1bHjXoX/28mZ/+7MPWzGPzQsBQDp0gQ+Ty1idroCQ+ENw9nSQpRiOnPc1v4qHZoTgr 3n/t6wVhHC1bTvamTFoANo0K+Qm8p1Xf6dpsaYn1yFK6V1tFbkgCWXBrXELN01D5hCAs iUhBcsLDMYsVz3PgfEtBbwInnVZFODTk9k7Q6hJKt0+q+O/6+rfvJXUQNhS1fIf5NikA VcUw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=GfFEzv0e; arc=pass (i=1 spf=pass spfdomain=linaro.org dkim=pass dkdomain=linaro.org dmarc=pass fromdomain=linaro.org); spf=pass (google.com: domain of linux-kernel+bounces-93281-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-93281-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id f8-20020a056a00238800b006e5f9972be6si6243348pfc.54.2024.03.05.19.20.20 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 05 Mar 2024 19:20:20 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-93281-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=GfFEzv0e; arc=pass (i=1 spf=pass spfdomain=linaro.org dkim=pass dkdomain=linaro.org dmarc=pass fromdomain=linaro.org); spf=pass (google.com: domain of linux-kernel+bounces-93281-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-93281-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 300AA2883E1 for ; Wed, 6 Mar 2024 03:20:20 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id C2CEB14008; Wed, 6 Mar 2024 03:20:12 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="GfFEzv0e" Received: from mail-lf1-f45.google.com (mail-lf1-f45.google.com [209.85.167.45]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EF2AF11CAB for ; Wed, 6 Mar 2024 03:20:09 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.167.45 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709695211; cv=none; b=nEyoN8zl3LdttwNOliohlhs8X6N/owF7vcqjwBd/CCcdRAi4eAUV+IpY+oMiiRa2GqqKeJfqLvmZpU+qA2PserdGLqT1zGkrFGgDi3QRbvoNMqpOjtHHUvPqyFkn1fbPvE7O7IukvGV4T4y29vPigP6BrcRyh10fWLRS6N3gdgs= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709695211; c=relaxed/simple; bh=dhjl/66VWnVN0bdWsBsnU2UZhUlkVYAIVb3mMRkadbU=; h=Message-ID:Date:MIME-Version:From:Subject:To:Cc:Content-Type; b=D1T46EPZFbA0wl/eqbkbkgSMAT7M+k2YYzwT7KxRgGwjb3zuDSrYZl3OD+Hn6+AuTZFwFBsWrfI3IPCnQOgqicF9ZLpNZL4jOJqeQdPWEl5Wl0pM2vHWpUxFQNf3pdZbkCMspV5yFBbQxwg8NDAH6BF8YlHsyMc8X+SjrWDNh/c= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org; spf=pass smtp.mailfrom=linaro.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b=GfFEzv0e; arc=none smtp.client-ip=209.85.167.45 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linaro.org Received: by mail-lf1-f45.google.com with SMTP id 2adb3069b0e04-51320ca689aso7743989e87.2 for ; Tue, 05 Mar 2024 19:20:09 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1709695208; x=1710300008; darn=vger.kernel.org; h=content-transfer-encoding:cc:to:subject:from:content-language :user-agent:mime-version:date:message-id:from:to:cc:subject:date :message-id:reply-to; bh=kZFeGCf76AtADk4ySWTFDtvJLdQB6MyBdHLu8Wy+eQQ=; b=GfFEzv0eORd3z/RLUyefzlo6EERmXBBgaFzCOrtrpK9k47I1Krw5C4rjUzD+kmyJzN y3yT/o2Ur24M9dTrTWXLnybByajats0Oo2QAyTDYrNIEZ/nTGmdUxnDLGIUZGbc6j025 zPSXMi0T/0gcJwcoO4TrnSP6hptTTcs2oxArnQyj76EOL3TErQxxYJSZH1Xge2yutXGq CRaF8HgQU5y+1BldjGxIJWZoj426eTwpSKvkqrRUhDnko3Y6RO3fQoJT1ZfRHTQHc/gm FoNx+Ox52fj2F1aeHaaeuDmLeCUMM47QywYRlI5OAyrkJs37eR5K16EIeJqXWART7cMM OxFw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1709695208; x=1710300008; h=content-transfer-encoding:cc:to:subject:from:content-language :user-agent:mime-version:date:message-id:x-gm-message-state:from:to :cc:subject:date:message-id:reply-to; bh=kZFeGCf76AtADk4ySWTFDtvJLdQB6MyBdHLu8Wy+eQQ=; b=w0CIVXYToULTLhYffOgjFcK1J1iPCww7yfl6XhuS/OawwvtuFxJINmE1MgZvlP5dRv JPhyfBHVt/rfDtEMcqZya+5IBCqQiO1zNrUJ/3260Hs5/4PGuxk1DVPydo25oRP9r7Bt Zq9z3cJibquljFMqR1WwgthewVzeGQKr8QYV8hMQwls43JRxnV2ga3nrGd5OIM086S3r TQHe1fN4EbFJ+WizJNLfiyCEUPs0iB8yGj3vsSOr9BkQeU3G+FvLYp+Uxcvb4+Foj1Gg vaR/QV7NcWPjKTZwumRuC+i2qt47TWLNjfcVooUza6kmZNT3GnrR/6cE+S34/oYKuLlm Nnlw== X-Forwarded-Encrypted: i=1; AJvYcCUfmDusSxOrVZCe/0RuJ/2GOG2hrRP7j5CMQd9OJLNEWj8grLhzDNB6I1IANxKZDFyHa43L7pM7nlqDpNNsxImW3GohHcwEu/6r3Jsa X-Gm-Message-State: AOJu0YzkTOA0Rkj5h9+ViJDmDlCgeR74aZMRr9S0zaEFjbXw2BTheEnr H2IbS+NmW/LfkmobOimYedvOHt/o0XI8Y1cIS51Ou6c8O01IPqTQXEA5RF1uHgk= X-Received: by 2002:a05:6512:31d2:b0:513:32e2:141b with SMTP id j18-20020a05651231d200b0051332e2141bmr2773526lfe.67.1709695207886; Tue, 05 Mar 2024 19:20:07 -0800 (PST) Received: from [192.168.2.107] ([79.115.63.35]) by smtp.gmail.com with ESMTPSA id lf7-20020a170907174700b00a44d66a16efsm4557052ejc.2.2024.03.05.19.20.06 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 05 Mar 2024 19:20:07 -0800 (PST) Message-ID: Date: Wed, 6 Mar 2024 03:20:05 +0000 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Content-Language: en-US From: Tudor Ambarus Subject: samsung: clk: re-parent MUX to OSCCLK at run-time To: Sylwester Nawrocki , Chanwoo Choi , Alim Akhtar Cc: Sam Protsenko , Krzysztof Kozlowski , linux-samsung-soc@vger.kernel.org, linux-clk@vger.kernel.org, "linux-kernel@vger.kernel.org" , linux-arm-kernel , Peter Griffin , =?UTF-8?Q?Andr=C3=A9_Draszik?= , William McVicker , kernel-team@android.com Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Hi, Trying to get some feedback from the samsung experts. Please consider the following: --------------------------------------------- | CMU_PERIC0 | | | | MUX_USI | | | | |\ | OSCCLK ---|->| \ | | | \ | | | M | | | | U |--> DIV_CLK_PERIC0_USI*_ --> GATE_USI | | | X | (1 ~ 16) | | | / | DIV_CLKCMU_PERIC0_IP ---|->| / | (1 ~ 16) | | |/ | | | | | | | | | MUX_I3C | | | | | | |\ | --|->| \ | | | \ | | | M | | | | U |--> DIV_CLK_PERIC0_I3C --> GATE_I3C | | | X | | | | / | OSCCLK ---|->| / | | |/ | | | --------------------------------------------- Is it fine to re-parent the MUX_USI from above to OSCCLK at run-time, during normal operation mode? Experimentally I determined that it's fine, but the datasheet that I'm reading mentions OSCCLK just in the low-power mode context: i/ CMU ... "Communicates with Power Management Unit (PMU) to stop clocks or switch OSC clock before entering a Low-Power mode to reduce power consumption by minimizing clock toggling". ii/ "All CMUs have MUXs to change the OSCCLK during power-down mode". Re-parenting the MUX to OSCCLK allows lower clock rates for the USI blocks than the DIV_CLK_PERIC0_USI can offer. For a USI clock rate below 6.25 MHz I have to either reparent MUX_USI to OSCCLK, or to propagate the clock rate to the common divider DIV_CLKCMU_PERIC0_IP. I find the propagation to the common DIV less desirable as a low USI clock rate affects I3C by lowering its clock rate too. Worse, if the common bus divider is not protected (using CLK_SET_RATE_GATE), USI can lower the I3C clock rate without I3C noticing. Either re-parenting the MUX_USI to OSCCLK, or propagating the clock rate to DIV_CLKCMU_PERIC0_IP allows the same clock ranges. The first with the benefit of not affecting the clock rate of I3C for USI clock rates below 6.25 MHz. Is it fine to re-parent MUX_USI to OSCCLK at run-time? If no feedback is received I lean towards propagating the USI clock rate to the common divider, but by protecting it with CLK_SET_RATE_GATE. Feel free to add in To: or Cc: whoever might be interested. Thanks, ta