Received: by 2002:ab2:1149:0:b0:1f3:1f8c:d0c6 with SMTP id z9csp80215lqz; Fri, 29 Mar 2024 09:07:39 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUzlgaC0DrGkKvxoSNpBmLoLtQDTtwXPpOP6MyruGS7ZGlL7fziM9na60Nyc837qIRLFYw3BG5hqdI4/vIshDykxmWqZp9Irucdr1Vpcw== X-Google-Smtp-Source: AGHT+IEDBtAGTwnwDP3WuD3/VNRy11LhYma0aAOjERCj7BUtH+Uor5E5UqZAPk8YgHvoeGJecNlK X-Received: by 2002:a05:6102:3093:b0:476:96f0:3bad with SMTP id l19-20020a056102309300b0047696f03badmr2067123vsb.19.1711728458945; Fri, 29 Mar 2024 09:07:38 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711728458; cv=pass; d=google.com; s=arc-20160816; b=FVePDxApIr3GWTaryb7SMLjb3HtvddRBuKztHJFlDnUCQ562HaSsc/+ielfc6E+M4t PzfLNSe/0dnHuzggk1ZZpgHgMYCIpM22zItXyYktdxcgZ/c+xVWrbJTGeL/E1Lez1zNh PPYriCY9wkBotJC6oEz8tTIIxBjjxwkDGPtigZIt68+67xIXS2hpAOIfzlxR+MIf27f1 tj7BEOtAbSLqQ5uJKu+QVzQs/yUc+MB3i0SKRJy28EGf0qmX2f+UFm8pH5717Eky5m7r i/uVoGweGF8U+Edj2fPGosnUEJSZytHS0rjJFtzs0CsS/O8pGwkvk2bzgZQNWBdzbpiS uCyQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:references:cc:to:subject:reply-to:from:user-agent :mime-version:list-unsubscribe:list-subscribe:list-id:precedence :date:message-id:dkim-signature; bh=NkjrKE6IuMRJrcH8UKGD1gXPrQ5QNm+lu1/8bGgH4ic=; fh=hvGbETDP9uNcMn8cZB1fnSxqjcCPBsNQIzO0Nx2JnnQ=; b=vgOBUSxvUC1GXItQs2zCuVG4/PUMT6LIoL2LdkabzH8K2h7FiuvcGIuLqrntajKjOq ioCuGsYoKR4LIAL9Mm64+qc7KPIhYc5exx4e9rF3AOVI50QMTEpexPyghKi43iThQECW NgIW/Hoxct/Mpi2T6nf6Bl1IAUR2Pp9dOYh3yvCNQg/Mka5tVrKUheJS26B52h8kU2CE RnangQHj30XHADRCe/K+9yMZHqPykKvbQ7sh44WR2BsJ01bPF3E7EL8aOCUeYNmDFcPK Q6dGTzObYtYsdKsym+Nf9S0LVWjrOwBQsICxXMNIrCEowEqCD1WzVAUDfahXDpEVtdy6 c66A==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=gXP3Yvn2; 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-125156-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-125156-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id s1-20020a056102108100b004785f4a638fsi135728vsr.21.2024.03.29.09.07.38 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 29 Mar 2024 09:07:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-125156-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=gXP3Yvn2; 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-125156-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-125156-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 ny.mirrors.kernel.org (Postfix) with ESMTPS id 1A5411C25A86 for ; Fri, 29 Mar 2024 16:07:32 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 72D6C85C62; Fri, 29 Mar 2024 16:07:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="gXP3Yvn2" Received: from mail-wr1-f46.google.com (mail-wr1-f46.google.com [209.85.221.46]) (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 2EB1B85620 for ; Fri, 29 Mar 2024 16:07:17 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.46 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711728439; cv=none; b=NI5tAvYFJ9OPU7/sUOeY13G6jFxe46urQahxsNAeqlFGbD7bWucqQOVZow6Dfoo8tMDxFv33apJuQRlKKutrB69mOHmfE2HxJQVyWW3XLLePOtP9Xznxf0f65h3A9+f2DEHIX/X5HibjaKRs61Yof3kgft8/d1t505DoRRqkfsU= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711728439; c=relaxed/simple; bh=uVZ8lncSEx9CgZgnVNmxK+Avk1jx1A/buaRNSBdBkc8=; h=Message-ID:Date:MIME-Version:From:Subject:To:Cc:References: In-Reply-To:Content-Type; b=bR7RKn+1uSU/p77dJWEorphiOKxaUM/mlAzW0SzQuaOA2jtKC9ObUVnihDPNIpuIHUAr7SkQBa5d49RtVOBEA13Zr0meUijc8OkAIrEuEzCEvJ2EnlRFEEiXhChI4jZNrNU4ugC4dkMIfJYbbiFeR5bUwNGzUYK4LlKcSRlfmBg= 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=gXP3Yvn2; arc=none smtp.client-ip=209.85.221.46 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-wr1-f46.google.com with SMTP id ffacd0b85a97d-341cf77b86bso1390286f8f.2 for ; Fri, 29 Mar 2024 09:07:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1711728435; x=1712333235; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:references:cc:to:subject:reply-to:from:user-agent :mime-version:date:message-id:from:to:cc:subject:date:message-id :reply-to; bh=NkjrKE6IuMRJrcH8UKGD1gXPrQ5QNm+lu1/8bGgH4ic=; b=gXP3Yvn2nCksWB2s+DQJfXyA3DLjho1vR825qPT5s3tzWzpW58ryo79uLPKRAf2maP xlf/UDF7v3OCcYWim1I6y7yrTdFatTtouQJzA86quESJSl0lLKWvEiLBuZ/lDwpkR57L OQXSGD9k8Cm+SkQx1qhRttL1HFx2m3B6iycF6lF0SF/XwnG5vPRqecm70Kc9hNqAxNxh EeGgsOF+msCM/1SYb4J927KoWPqpgeWM2vTJIsGeDI+HzlPCX906HtGbthqb2opxnw54 XYJ9//9sQ6T6fwKrI6gdxrzEUHFWjwGvEGBjpTnl+vZitgvMUUrHHferetWT2ffofYg/ 219g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1711728435; x=1712333235; h=content-transfer-encoding:in-reply-to:organization:autocrypt :content-language:references:cc:to:subject:reply-to:from:user-agent :mime-version:date:message-id:x-gm-message-state:from:to:cc:subject :date:message-id:reply-to; bh=NkjrKE6IuMRJrcH8UKGD1gXPrQ5QNm+lu1/8bGgH4ic=; b=pKtkm+g5OuAOuRaigzsFCBOOi62Jyulm+/fh+CE2y1jSysvj3KhnEx8OVhbDFB6hon fat3iIR5MsvL4dsIzF3zbJQwp/bp+tTFzwentyXl4Fd4qzIdjgD2h0QRMrricyx+gGbb FXYH4hMz5ITORb0NUq11cbbhqj8Ym5Z/oYEEwxhVBX6NBeAOiBFGnU2qc6GtZO5xOMa/ 9cZgScyafb3fJq5fFvtmRLxvTedumrtEXtWEplutYXLrTyIQdOM9F2XvjOcmBc0vUe1a RST/4obnrzf0oGHfJSw1eBucrl3/XGshruh+NXxBoSVhp1SHwRhkOgaRKvtrPIR87QN1 qmow== X-Forwarded-Encrypted: i=1; AJvYcCWrT+7a8ZmmeKPX1cfc33vH6FOArpjDT4K1CIYYNTfMyRil5IrQa6vhJdO+Ljyl6qj3v0UQe8eIX9xJFtuZUniZmymA5VXpgTxDSGm4 X-Gm-Message-State: AOJu0Yy6iEMZSyLMgWHG/odV/R2LWZ+S9vQC11aLv73CTGKbD59OLJwM Wzt8MyLCS0KemyFiRkKnojx4tLLe/gNVRG3HTVMuklCkYMeHcNslvrSrlNl/JRE= X-Received: by 2002:a5d:4b08:0:b0:341:8c2e:5001 with SMTP id v8-20020a5d4b08000000b003418c2e5001mr1696413wrq.64.1711728435308; Fri, 29 Mar 2024 09:07:15 -0700 (PDT) Received: from ?IPV6:2a01:e0a:982:cbb0:3cd8:c97b:1468:c232? ([2a01:e0a:982:cbb0:3cd8:c97b:1468:c232]) by smtp.gmail.com with ESMTPSA id k17-20020adff5d1000000b00341b7388dafsm4478433wrp.77.2024.03.29.09.07.14 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 29 Mar 2024 09:07:14 -0700 (PDT) Message-ID: <7424b114-05df-4603-88ac-ba59aec45c9e@linaro.org> Date: Fri, 29 Mar 2024 17:07:13 +0100 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird From: Neil Armstrong Reply-To: neil.armstrong@linaro.org Subject: Re: [PATCH v11 2/7] clk: meson: add vclk driver To: Jerome Brunet Cc: Rob Herring , Krzysztof Kozlowski , Conor Dooley , Kevin Hilman , Michael Turquette , Stephen Boyd , Martin Blumenstingl , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , Nicolas Belin , Jagan Teki , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-amlogic@lists.infradead.org, linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, dri-devel@lists.freedesktop.org References: <20240325-amlogic-v6-4-upstream-dsi-ccf-vim3-v11-0-04f55de44604@linaro.org> <20240325-amlogic-v6-4-upstream-dsi-ccf-vim3-v11-2-04f55de44604@linaro.org> <1jzfuh8bd7.fsf@starbuckisacylon.baylibre.com> Content-Language: en-US, fr Autocrypt: addr=neil.armstrong@linaro.org; keydata= xsBNBE1ZBs8BCAD78xVLsXPwV/2qQx2FaO/7mhWL0Qodw8UcQJnkrWmgTFRobtTWxuRx8WWP GTjuhvbleoQ5Cxjr+v+1ARGCH46MxFP5DwauzPekwJUD5QKZlaw/bURTLmS2id5wWi3lqVH4 BVF2WzvGyyeV1o4RTCYDnZ9VLLylJ9bneEaIs/7cjCEbipGGFlfIML3sfqnIvMAxIMZrvcl9 qPV2k+KQ7q+aXavU5W+yLNn7QtXUB530Zlk/d2ETgzQ5FLYYnUDAaRl+8JUTjc0CNOTpCeik 80TZcE6f8M76Xa6yU8VcNko94Ck7iB4vj70q76P/J7kt98hklrr85/3NU3oti3nrIHmHABEB AAHNKk5laWwgQXJtc3Ryb25nIDxuZWlsLmFybXN0cm9uZ0BsaW5hcm8ub3JnPsLAkQQTAQoA OwIbIwULCQgHAwUVCgkICwUWAgMBAAIeAQIXgBYhBInsPQWERiF0UPIoSBaat7Gkz/iuBQJk Q5wSAhkBAAoJEBaat7Gkz/iuyhMIANiD94qDtUTJRfEW6GwXmtKWwl/mvqQtaTtZID2dos04 YqBbshiJbejgVJjy+HODcNUIKBB3PSLaln4ltdsV73SBcwUNdzebfKspAQunCM22Mn6FBIxQ GizsMLcP/0FX4en9NaKGfK6ZdKK6kN1GR9YffMJd2P08EO8mHowmSRe/ExAODhAs9W7XXExw UNCY4pVJyRPpEhv373vvff60bHxc1k/FF9WaPscMt7hlkbFLUs85kHtQAmr8pV5Hy9ezsSRa GzJmiVclkPc2BY592IGBXRDQ38urXeM4nfhhvqA50b/nAEXc6FzqgXqDkEIwR66/Gbp0t3+r yQzpKRyQif3OwE0ETVkGzwEIALyKDN/OGURaHBVzwjgYq+ZtifvekdrSNl8TIDH8g1xicBYp QTbPn6bbSZbdvfeQPNCcD4/EhXZuhQXMcoJsQQQnO4vwVULmPGgtGf8PVc7dxKOeta+qUh6+ SRh3vIcAUFHDT3f/Zdspz+e2E0hPV2hiSvICLk11qO6cyJE13zeNFoeY3ggrKY+IzbFomIZY 4yG6xI99NIPEVE9lNBXBKIlewIyVlkOaYvJWSV+p5gdJXOvScNN1epm5YHmf9aE2ZjnqZGoM Mtsyw18YoX9BqMFInxqYQQ3j/HpVgTSvmo5ea5qQDDUaCsaTf8UeDcwYOtgI8iL4oHcsGtUX oUk33HEAEQEAAcLAXwQYAQIACQUCTVkGzwIbDAAKCRAWmrexpM/4rrXiB/sGbkQ6itMrAIfn M7IbRuiSZS1unlySUVYu3SD6YBYnNi3G5EpbwfBNuT3H8//rVvtOFK4OD8cRYkxXRQmTvqa3 3eDIHu/zr1HMKErm+2SD6PO9umRef8V82o2oaCLvf4WeIssFjwB0b6a12opuRP7yo3E3gTCS KmbUuLv1CtxKQF+fUV1cVaTPMyT25Od+RC1K+iOR0F54oUJvJeq7fUzbn/KdlhA8XPGzwGRy 4zcsPWvwnXgfe5tk680fEKZVwOZKIEuJC3v+/yZpQzDvGYJvbyix0lHnrCzq43WefRHI5XTT QbM0WUIBIcGmq38+OgUsMYu4NzLu7uZFAcmp6h8g Organization: Linaro In-Reply-To: <1jzfuh8bd7.fsf@starbuckisacylon.baylibre.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit On 29/03/2024 13:33, Jerome Brunet wrote: > > On Mon 25 Mar 2024 at 12:09, Neil Armstrong wrote: > >> The VCLK and VCLK_DIV clocks have supplementary bits. >> >> The VCLK gate has a "SOFT RESET" bit to toggle after the whole >> VCLK sub-tree rate has been set, this is implemented in >> the gate enable callback. >> >> The VCLK_DIV clocks as enable and reset bits used to disable >> and reset the divider, associated with CLK_SET_RATE_GATE it ensures >> the rate is set while the divider is disabled and in reset mode. >> >> The VCLK_DIV enable bit isn't implemented as a gate since it's part >> of the divider logic and vendor does this exact sequence to ensure >> the divider is correctly set. > > checkpatch reports a few easy CHECKs and one WARNING. > Could you please fix these ? > > Other than that, It looks OK. Ack thx Neil > >> >> Signed-off-by: Neil Armstrong >> --- >> drivers/clk/meson/Kconfig | 4 ++ >> drivers/clk/meson/Makefile | 1 + >> drivers/clk/meson/vclk.c | 141 +++++++++++++++++++++++++++++++++++++++++++++ >> drivers/clk/meson/vclk.h | 51 ++++++++++++++++ >> 4 files changed, 197 insertions(+) >> >> diff --git a/drivers/clk/meson/Kconfig b/drivers/clk/meson/Kconfig >> index 29ffd14d267b..8a9823789fa3 100644 >> --- a/drivers/clk/meson/Kconfig >> +++ b/drivers/clk/meson/Kconfig >> @@ -30,6 +30,10 @@ config COMMON_CLK_MESON_VID_PLL_DIV >> tristate >> select COMMON_CLK_MESON_REGMAP >> >> +config COMMON_CLK_MESON_VCLK >> + tristate >> + select COMMON_CLK_MESON_REGMAP >> + >> config COMMON_CLK_MESON_CLKC_UTILS >> tristate >> >> diff --git a/drivers/clk/meson/Makefile b/drivers/clk/meson/Makefile >> index 9ee4b954c896..9ba43fe7a07a 100644 >> --- a/drivers/clk/meson/Makefile >> +++ b/drivers/clk/meson/Makefile >> @@ -12,6 +12,7 @@ obj-$(CONFIG_COMMON_CLK_MESON_PLL) += clk-pll.o >> obj-$(CONFIG_COMMON_CLK_MESON_REGMAP) += clk-regmap.o >> obj-$(CONFIG_COMMON_CLK_MESON_SCLK_DIV) += sclk-div.o >> obj-$(CONFIG_COMMON_CLK_MESON_VID_PLL_DIV) += vid-pll-div.o >> +obj-$(CONFIG_COMMON_CLK_MESON_VCLK) += vclk.o >> >> # Amlogic Clock controllers >> >> diff --git a/drivers/clk/meson/vclk.c b/drivers/clk/meson/vclk.c >> new file mode 100644 >> index 000000000000..3ea813a0a995 >> --- /dev/null >> +++ b/drivers/clk/meson/vclk.c >> @@ -0,0 +1,141 @@ >> +// SPDX-License-Identifier: GPL-2.0 >> +/* >> + * Copyright (c) 2024 Neil Armstrong >> + */ >> + >> +#include >> +#include "vclk.h" >> + >> +/* The VCLK gate has a supplementary reset bit to pulse after ungating */ >> + >> +static inline struct meson_vclk_gate_data * >> +clk_get_meson_vclk_gate_data(struct clk_regmap *clk) >> +{ >> + return (struct meson_vclk_gate_data *)clk->data; >> +} >> + >> +static int meson_vclk_gate_enable(struct clk_hw *hw) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_gate_data *vclk = clk_get_meson_vclk_gate_data(clk); >> + >> + meson_parm_write(clk->map, &vclk->enable, 1); >> + >> + /* Do a reset pulse */ >> + meson_parm_write(clk->map, &vclk->reset, 1); >> + meson_parm_write(clk->map, &vclk->reset, 0); >> + >> + return 0; >> +} >> + >> +static void meson_vclk_gate_disable(struct clk_hw *hw) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_gate_data *vclk = clk_get_meson_vclk_gate_data(clk); >> + >> + meson_parm_write(clk->map, &vclk->enable, 0); >> +} >> + >> +static int meson_vclk_gate_is_enabled(struct clk_hw *hw) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_gate_data *vclk = clk_get_meson_vclk_gate_data(clk); >> + >> + return meson_parm_read(clk->map, &vclk->enable); >> +} >> + >> +const struct clk_ops meson_vclk_gate_ops = { >> + .enable = meson_vclk_gate_enable, >> + .disable = meson_vclk_gate_disable, >> + .is_enabled = meson_vclk_gate_is_enabled, >> +}; >> +EXPORT_SYMBOL_GPL(meson_vclk_gate_ops); >> + >> +/* The VCLK Divider has supplementary reset & enable bits */ >> + >> +static inline struct meson_vclk_div_data * >> +clk_get_meson_vclk_div_data(struct clk_regmap *clk) >> +{ >> + return (struct meson_vclk_div_data *)clk->data; >> +} >> + >> +static unsigned long meson_vclk_div_recalc_rate(struct clk_hw *hw, >> + unsigned long prate) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_div_data *vclk = clk_get_meson_vclk_div_data(clk); >> + >> + return divider_recalc_rate(hw, prate, meson_parm_read(clk->map, &vclk->div), >> + vclk->table, vclk->flags, vclk->div.width); >> +} >> + >> +static int meson_vclk_div_determine_rate(struct clk_hw *hw, >> + struct clk_rate_request *req) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_div_data *vclk = clk_get_meson_vclk_div_data(clk); >> + >> + return divider_determine_rate(hw, req, vclk->table, vclk->div.width, >> + vclk->flags); >> +} >> + >> +static int meson_vclk_div_set_rate(struct clk_hw *hw, unsigned long rate, >> + unsigned long parent_rate) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_div_data *vclk = clk_get_meson_vclk_div_data(clk); >> + int ret; >> + >> + ret = divider_get_val(rate, parent_rate, vclk->table, vclk->div.width, >> + vclk->flags); >> + if (ret < 0) >> + return ret; >> + >> + meson_parm_write(clk->map, &vclk->div, ret); >> + >> + return 0; >> +}; >> + >> +static int meson_vclk_div_enable(struct clk_hw *hw) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_div_data *vclk = clk_get_meson_vclk_div_data(clk); >> + >> + /* Unreset the divider when ungating */ >> + meson_parm_write(clk->map, &vclk->reset, 0); >> + meson_parm_write(clk->map, &vclk->enable, 1); >> + >> + return 0; >> +} >> + >> +static void meson_vclk_div_disable(struct clk_hw *hw) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_div_data *vclk = clk_get_meson_vclk_div_data(clk); >> + >> + /* Reset the divider when gating */ >> + meson_parm_write(clk->map, &vclk->enable, 0); >> + meson_parm_write(clk->map, &vclk->reset, 1); >> +} >> + >> +static int meson_vclk_div_is_enabled(struct clk_hw *hw) >> +{ >> + struct clk_regmap *clk = to_clk_regmap(hw); >> + struct meson_vclk_div_data *vclk = clk_get_meson_vclk_div_data(clk); >> + >> + return meson_parm_read(clk->map, &vclk->enable); >> +} >> + >> +const struct clk_ops meson_vclk_div_ops = { >> + .recalc_rate = meson_vclk_div_recalc_rate, >> + .determine_rate = meson_vclk_div_determine_rate, >> + .set_rate = meson_vclk_div_set_rate, >> + .enable = meson_vclk_div_enable, >> + .disable = meson_vclk_div_disable, >> + .is_enabled = meson_vclk_div_is_enabled, >> +}; >> +EXPORT_SYMBOL_GPL(meson_vclk_div_ops); >> + >> +MODULE_DESCRIPTION("Amlogic vclk clock driver"); >> +MODULE_AUTHOR("Neil Armstrong "); >> +MODULE_LICENSE("GPL v2"); >> diff --git a/drivers/clk/meson/vclk.h b/drivers/clk/meson/vclk.h >> new file mode 100644 >> index 000000000000..20b0b181db09 >> --- /dev/null >> +++ b/drivers/clk/meson/vclk.h >> @@ -0,0 +1,51 @@ >> +/* SPDX-License-Identifier: GPL-2.0 */ >> +/* >> + * Copyright (c) 2024 Neil Armstrong >> + */ >> + >> +#ifndef __VCLK_H >> +#define __VCLK_H >> + >> +#include "clk-regmap.h" >> +#include "parm.h" >> + >> +/** >> + * struct meson_vclk_gate_data - vclk_gate regmap backed specific data >> + * >> + * @enable: vclk enable field >> + * @reset: vclk reset field >> + * @flags: hardware-specific flags >> + * >> + * Flags: >> + * Same as clk_gate except CLK_GATE_HIWORD_MASK which is ignored >> + */ >> +struct meson_vclk_gate_data { >> + struct parm enable; >> + struct parm reset; >> + u8 flags; >> +}; >> + >> +extern const struct clk_ops meson_vclk_gate_ops; >> + >> +/** >> + * struct meson_vclk_div_data - vclk_div regmap back specific data >> + * >> + * @div: divider field >> + * @enable: vclk divider enable field >> + * @reset: vclk divider reset field >> + * @table: array of value/divider pairs, last entry should have div = 0 >> + * >> + * Flags: >> + * Same as clk_divider except CLK_DIVIDER_HIWORD_MASK which is ignored >> + */ >> +struct meson_vclk_div_data { >> + struct parm div; >> + struct parm enable; >> + struct parm reset; >> + const struct clk_div_table *table; >> + u8 flags; >> +}; >> + >> +extern const struct clk_ops meson_vclk_div_ops; >> + >> +#endif /* __VCLK_H */ > >