Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp653248ybl; Thu, 12 Dec 2019 02:44:08 -0800 (PST) X-Google-Smtp-Source: APXvYqwIIwN/D50KK4d8o6dU782pJEI4EgStwTCI2kO7eYricyco4yZw4+3i2wRX0Y+yOeG1mIhd X-Received: by 2002:a05:6830:14c7:: with SMTP id t7mr7552369otq.72.1576147448488; Thu, 12 Dec 2019 02:44:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576147448; cv=none; d=google.com; s=arc-20160816; b=brRwqwy1KmdLoOnOlA5Z88NsCeH1pjw2dBxaAD7lv8SUT4tACi1O7cfp/U23P3bzmf Ct+M0NqllccvgIZGcIXExoZfxBgN8SYwarp90Ueek3+GaLJlRrxzAg5u0oIn2U6hRSKd G/lu8RSkGEay4GbnuSuu4GYI0tMr3gjTXMZHv6moQHXTzNxBbQh3U+2MxZ8QF6V1/988 /GhcKUer5/qf4h6cXAT50Vp9ILGOcSKfz+uTkxjIwRP6MLonB+UNLolXgXPSdd6C2y47 MiDfTuRiE2IPkTiNHnFDDgyRuJ2cx4WYkY1F61GGfko5L8vXkaMNfxZITI+LoTUq7Jnl 7BBw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:in-reply-to :subject:cc:to:from:user-agent:references:dkim-signature; bh=NwJ0oTGZuRxZkY7FPkDG0utaplsdV34Y7sdD0NWno4U=; b=iMfqn/NTF9gRacNkEV3Td325aMXbrXfDJT18LjqmxU9M9G3tqtjvnxB1n0b/r7IVbw grvgKk+gmhmlzzqiV3+TFEnQWDHk4lARx7C4GdAGOVuVzpYpeAHJPy7s8T6YHzALIJiS q0UDEVR4b818QogPmx1TFWPFs1NoCB7oG9uus5pTKUWbmU2Gj+56jTRmaCldTZ+S6GNL v5RhDbpgue5BdqRSkmE5iG+3IYgDmJmGLLX3vX5at/303McY160jCk63x6iCiHeavOKA uhmRIwNd86JOMgbffTHByastF2WMYZx6uBK9egdauMH2QLfOHYzQsNCY9Rn52v6tlFkJ aAAA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=2FNV18jL; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o4si2760944otp.200.2019.12.12.02.43.55; Thu, 12 Dec 2019 02:44:08 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=2FNV18jL; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728784AbfLLKms (ORCPT + 99 others); Thu, 12 Dec 2019 05:42:48 -0500 Received: from mail-wm1-f66.google.com ([209.85.128.66]:33293 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728679AbfLLKms (ORCPT ); Thu, 12 Dec 2019 05:42:48 -0500 Received: by mail-wm1-f66.google.com with SMTP id d139so3306804wmd.0 for ; Thu, 12 Dec 2019 02:42:45 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=references:user-agent:from:to:cc:subject:in-reply-to:date :message-id:mime-version; bh=NwJ0oTGZuRxZkY7FPkDG0utaplsdV34Y7sdD0NWno4U=; b=2FNV18jLbPprUFdwa1E3EPZJvNcRpcGTF5Xq8mm1oqBiMQqLNB+k/dzFSxqn5JC/Sm XR/TF3we6E7R2zS4AHJ2y4U4pF2Xd/QKX9/i3FU4xHvA1FZrc2xLzA3xV7M/j+6rzHSH szWZI/jzh/pTHnsdlFC4EYfsHqBkx+gidBNxJVa0ujlu7cvrrRGGjmZivNh6zGV5jf9n 0aBsKySkraFZLIRvLlxmfBzYmAPD6mvOFYPREhDQ+OoseCrZgTCAA8JERWY7IulczqXV MU1XY7q1Pk04EyfpIwiKx2414StOW1uCGLtZiuKa2Xko/2x0hMqt0lEPxMwy07+dxaX6 ku7g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:references:user-agent:from:to:cc:subject :in-reply-to:date:message-id:mime-version; bh=NwJ0oTGZuRxZkY7FPkDG0utaplsdV34Y7sdD0NWno4U=; b=VyUO8W14WUH1X0gMPYD5W8NCDzG4NE/nG+OsS3VVNuO0yws6KyFf0MjWcxpdUYSf9i muHfuFbNiQ2xEoVyxABB0K9uAuoWJ7IvLB3oRHbR/iLTPtKoGDmzfhh9zq7TcoIeqYtY kHZkVGUD+Z51Y0u4E4EdGI8cbPFbkVruOglRdz17bjXmIU7ojxoKT3+NxYY36/NyFKhL hS/L0tLFe3U3m0gqh212H5fQ6vxkK4nPVcdgvPy9riIZ/hbIdr6B3pzKnSmxFRRUD2wF nfeYs7uslIkkUNFHYN6VULAwjYgwy0ZaUwO0O7863UvkO5U+XYcV4FUMmA6j0yclkdp0 zzow== X-Gm-Message-State: APjAAAUd3q+cSGE2j0lGWK7fVAjbhICD7YUsJSHHiYwtreYiGoV4aUcV iPUrLbkf1p7b7ToJpSI+zrTJ6A== X-Received: by 2002:a05:600c:2215:: with SMTP id z21mr6016522wml.55.1576147364186; Thu, 12 Dec 2019 02:42:44 -0800 (PST) Received: from localhost (laubervilliers-658-1-213-31.w90-63.abo.wanadoo.fr. [90.63.244.31]) by smtp.gmail.com with ESMTPSA id t1sm5832585wma.43.2019.12.12.02.42.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 12 Dec 2019 02:42:43 -0800 (PST) References: <20191206074052.15557-1-jian.hu@amlogic.com> <20191206074052.15557-5-jian.hu@amlogic.com> <1j5zilltwc.fsf@starbuckisacylon.baylibre.com> User-agent: mu4e 1.3.3; emacs 26.2 From: Jerome Brunet To: Jian Hu , Neil Armstrong Cc: Kevin Hilman , "Rob Herring" , Martin Blumenstingl , Michael Turquette , Stephen Boyd , Qiufang Dai , Jianxin Pan , Victor Wan , Chandle Zou , linux-clk@vger.kernel.org, linux-amlogic@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v4 4/6] clk: meson: a1: add support for Amlogic A1 PLL clock driver In-reply-to: <1j5zilltwc.fsf@starbuckisacylon.baylibre.com> Date: Thu, 12 Dec 2019 11:42:43 +0100 Message-ID: <1j4ky5lt98.fsf@starbuckisacylon.baylibre.com> MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu 12 Dec 2019 at 11:28, Jerome Brunet wrote: > On Fri 06 Dec 2019 at 08:40, Jian Hu wrote: > >> The Amlogic A1 clock includes three drivers: >> pll clocks, peripheral clocks, CPU clocks. >> sys pll and CPU clocks will be sent in next patch. >> >> Unlike the previous series, there is no EE/AO domain >> in A1 CLK controllers. >> >> Signed-off-by: Jian Hu >> --- >> drivers/clk/meson/Kconfig | 10 ++ >> drivers/clk/meson/Makefile | 1 + >> drivers/clk/meson/a1-pll.c | 334 +++++++++++++++++++++++++++++++++++++ >> drivers/clk/meson/a1-pll.h | 56 +++++++ >> 4 files changed, 401 insertions(+) >> create mode 100644 drivers/clk/meson/a1-pll.c >> create mode 100644 drivers/clk/meson/a1-pll.h >> >> diff --git a/drivers/clk/meson/Kconfig b/drivers/clk/meson/Kconfig >> index dabeb435d067..14e7936ae18e 100644 >> --- a/drivers/clk/meson/Kconfig >> +++ b/drivers/clk/meson/Kconfig >> @@ -93,6 +93,16 @@ config COMMON_CLK_AXG_AUDIO >> Support for the audio clock controller on AmLogic A113D devices, >> aka axg, Say Y if you want audio subsystem to work. >> >> +config COMMON_CLK_A1_PLL >> + bool >> + depends on ARCH_MESON >> + select COMMON_CLK_MESON_EE_CLKC >> + select COMMON_CLK_MESON_REGMAP >> + select COMMON_CLK_MESON_PLL >> + help >> + Support for the PLL clock controller on Amlogic A113L device, >> + aka a1. Say Y if you want PLL to work. >> + >> config COMMON_CLK_G12A >> bool >> depends on ARCH_MESON >> diff --git a/drivers/clk/meson/Makefile b/drivers/clk/meson/Makefile >> index 3939f218587a..71d3b8e6fb8a 100644 >> --- a/drivers/clk/meson/Makefile >> +++ b/drivers/clk/meson/Makefile >> @@ -16,6 +16,7 @@ obj-$(CONFIG_COMMON_CLK_MESON_VID_PLL_DIV) += vid-pll-div.o >> >> obj-$(CONFIG_COMMON_CLK_AXG) += axg.o axg-aoclk.o >> obj-$(CONFIG_COMMON_CLK_AXG_AUDIO) += axg-audio.o >> +obj-$(CONFIG_COMMON_CLK_A1_PLL) += a1-pll.o >> obj-$(CONFIG_COMMON_CLK_GXBB) += gxbb.o gxbb-aoclk.o >> obj-$(CONFIG_COMMON_CLK_G12A) += g12a.o g12a-aoclk.o >> obj-$(CONFIG_COMMON_CLK_MESON8B) += meson8b.o >> diff --git a/drivers/clk/meson/a1-pll.c b/drivers/clk/meson/a1-pll.c >> new file mode 100644 >> index 000000000000..b248ac81ddd8 >> --- /dev/null >> +++ b/drivers/clk/meson/a1-pll.c >> @@ -0,0 +1,334 @@ >> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT) >> +/* >> + * Copyright (c) 2019 Amlogic, Inc. All rights reserved. >> + * Author: Jian Hu >> + */ >> + >> +#include >> +#include >> +#include >> +#include "a1-pll.h" >> +#include "clk-pll.h" >> +#include "meson-eeclk.h" >> + >> +static struct clk_regmap a1_fixed_pll_dco = { >> + .data = &(struct meson_clk_pll_data){ >> + .en = { >> + .reg_off = ANACTRL_FIXPLL_CTRL0, >> + .shift = 28, >> + .width = 1, >> + }, >> + .m = { >> + .reg_off = ANACTRL_FIXPLL_CTRL0, >> + .shift = 0, >> + .width = 8, >> + }, >> + .n = { >> + .reg_off = ANACTRL_FIXPLL_CTRL0, >> + .shift = 10, >> + .width = 5, >> + }, >> + .frac = { >> + .reg_off = ANACTRL_FIXPLL_CTRL1, >> + .shift = 0, >> + .width = 19, >> + }, >> + .l = { >> + .reg_off = ANACTRL_FIXPLL_CTRL0, >> + .shift = 31, >> + .width = 1, >> + }, >> + .rst = { >> + .reg_off = ANACTRL_FIXPLL_CTRL0, >> + .shift = 29, >> + .width = 1, >> + }, >> + }, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fixed_pll_dco", >> + .ops = &meson_clk_pll_ro_ops, >> + .parent_data = &(const struct clk_parent_data){ >> + .fw_name = "xtal_fixpll", >> + }, >> + .num_parents = 1, >> + }, >> +}; >> + >> +static struct clk_regmap a1_fixed_pll = { >> + .data = &(struct clk_regmap_gate_data){ >> + .offset = ANACTRL_FIXPLL_CTRL0, >> + .bit_idx = 20, >> + }, >> + .hw.init = &(struct clk_init_data) { >> + .name = "fixed_pll", >> + .ops = &clk_regmap_gate_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fixed_pll_dco.hw >> + }, >> + .num_parents = 1, >> + /* >> + * This clock is fclk_div2/3/5's parent, >> + * However, fclk_div2/3/5 feeds AXI/APB/DDR. >> + * It is required by the platform to operate correctly. >> + */ >> + .flags = CLK_IGNORE_UNUSED, > > From the comment, it looks like this clock should be critical, not > ignored Actually having the fdiv leaf critical is enough, you should just drop the flag > >> + }, >> +}; >> + >> +static const struct pll_mult_range a1_hifi_pll_mult_range = { >> + .min = 32, >> + .max = 64, >> +}; >> + >> +static const struct reg_sequence a1_hifi_init_regs[] = { >> + { .reg = ANACTRL_HIFIPLL_CTRL1, .def = 0x01800000 }, >> + { .reg = ANACTRL_HIFIPLL_CTRL2, .def = 0x00001100 }, >> + { .reg = ANACTRL_HIFIPLL_CTRL3, .def = 0x100a1100 }, >> + { .reg = ANACTRL_HIFIPLL_CTRL4, .def = 0x00302000 }, >> + { .reg = ANACTRL_HIFIPLL_CTRL0, .def = 0x01f18440 }, >> +}; >> + >> +static struct clk_regmap a1_hifi_pll = { >> + .data = &(struct meson_clk_pll_data){ >> + .en = { >> + .reg_off = ANACTRL_HIFIPLL_CTRL0, >> + .shift = 28, >> + .width = 1, >> + }, >> + .m = { >> + .reg_off = ANACTRL_HIFIPLL_CTRL0, >> + .shift = 0, >> + .width = 8, >> + }, >> + .n = { >> + .reg_off = ANACTRL_HIFIPLL_CTRL0, >> + .shift = 10, >> + .width = 5, >> + }, >> + .frac = { >> + .reg_off = ANACTRL_HIFIPLL_CTRL1, >> + .shift = 0, >> + .width = 19, >> + }, >> + .l = { >> + .reg_off = ANACTRL_HIFIPLL_STS, >> + .shift = 31, >> + .width = 1, >> + }, >> + .current_en = { >> + .reg_off = ANACTRL_HIFIPLL_CTRL0, >> + .shift = 26, >> + .width = 1, >> + }, >> + .rst = { >> + .reg_off = ANACTRL_HIFIPLL_CTRL2, >> + .shift = 6, >> + .width = 1, >> + }, >> + .range = &a1_hifi_pll_mult_range, >> + .init_regs = a1_hifi_init_regs, >> + .init_count = ARRAY_SIZE(a1_hifi_init_regs), >> + }, >> + .hw.init = &(struct clk_init_data){ >> + .name = "hifi_pll", >> + .ops = &meson_clk_pll_ops, >> + .parent_data = &(const struct clk_parent_data){ >> + .fw_name = "xtal_hifipll", >> + }, >> + .num_parents = 1, >> + }, >> +}; >> + >> +static struct clk_fixed_factor a1_fclk_div2_div = { >> + .mult = 1, >> + .div = 2, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fclk_div2_div", >> + .ops = &clk_fixed_factor_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fixed_pll.hw >> + }, >> + .num_parents = 1, >> + }, >> +}; >> + >> +static struct clk_regmap a1_fclk_div2 = { >> + .data = &(struct clk_regmap_gate_data){ >> + .offset = ANACTRL_FIXPLL_CTRL0, >> + .bit_idx = 21, >> + }, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fclk_div2", >> + .ops = &clk_regmap_gate_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fclk_div2_div.hw >> + }, >> + .num_parents = 1, >> + /* >> + * This clock is used by DDR clock in BL2 firmware >> + * and is required by the platform to operate correctly. >> + * Until the following condition are met, we need this clock to >> + * be marked as critical: >> + * a) Mark the clock used by a firmware resource, if possible >> + * b) CCF has a clock hand-off mechanism to make the sure the >> + * clock stays on until the proper driver comes along >> + */ >> + .flags = CLK_IS_CRITICAL, >> + }, >> +}; >> + >> +static struct clk_fixed_factor a1_fclk_div3_div = { >> + .mult = 1, >> + .div = 3, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fclk_div3_div", >> + .ops = &clk_fixed_factor_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fixed_pll.hw >> + }, >> + .num_parents = 1, >> + }, >> +}; >> + >> +static struct clk_regmap a1_fclk_div3 = { >> + .data = &(struct clk_regmap_gate_data){ >> + .offset = ANACTRL_FIXPLL_CTRL0, >> + .bit_idx = 22, >> + }, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fclk_div3", >> + .ops = &clk_regmap_gate_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fclk_div3_div.hw >> + }, >> + .num_parents = 1, >> + /* >> + * This clock is used by APB bus which setted in Romcode >> + * and is required by the platform to operate correctly. > > From here, I think you replace the comment with "Refer to a1_fclk_div2" > to avoid pasting the same lines over and over again. Same for the other > clocks below. > >> + * Until the following condition are met, we need this clock to >> + * be marked as critical: >> + * a) Mark the clock used by a firmware resource, if possible >> + * b) CCF has a clock hand-off mechanism to make the sure the >> + * clock stays on until the proper driver comes along >> + */ >> + .flags = CLK_IS_CRITICAL, >> + }, >> +}; >> + >> +static struct clk_fixed_factor a1_fclk_div5_div = { >> + .mult = 1, >> + .div = 5, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fclk_div5_div", >> + .ops = &clk_fixed_factor_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fixed_pll.hw >> + }, >> + .num_parents = 1, >> + }, >> +}; >> + >> +static struct clk_regmap a1_fclk_div5 = { >> + .data = &(struct clk_regmap_gate_data){ >> + .offset = ANACTRL_FIXPLL_CTRL0, >> + .bit_idx = 23, >> + }, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fclk_div5", >> + .ops = &clk_regmap_gate_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fclk_div5_div.hw >> + }, >> + .num_parents = 1, >> + /* >> + * This clock is used by AXI bus which setted in Romcode >> + * and is required by the platform to operate correctly. >> + * Until the following condition are met, we need this clock to >> + * be marked as critical: >> + * a) Mark the clock used by a firmware resource, if possible >> + * b) CCF has a clock hand-off mechanism to make the sure the >> + * clock stays on until the proper driver comes along >> + */ >> + .flags = CLK_IS_CRITICAL, >> + }, >> +}; >> + >> +static struct clk_fixed_factor a1_fclk_div7_div = { >> + .mult = 1, >> + .div = 7, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fclk_div7_div", >> + .ops = &clk_fixed_factor_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fixed_pll.hw >> + }, >> + .num_parents = 1, >> + }, >> +}; >> + >> +static struct clk_regmap a1_fclk_div7 = { >> + .data = &(struct clk_regmap_gate_data){ >> + .offset = ANACTRL_FIXPLL_CTRL0, >> + .bit_idx = 24, >> + }, >> + .hw.init = &(struct clk_init_data){ >> + .name = "fclk_div7", >> + .ops = &clk_regmap_gate_ops, >> + .parent_hws = (const struct clk_hw *[]) { >> + &a1_fclk_div7_div.hw >> + }, >> + .num_parents = 1, >> + }, >> +}; >> + >> +/* Array of all clocks provided by this provider */ >> +static struct clk_hw_onecell_data a1_pll_hw_onecell_data = { >> + .hws = { >> + [CLKID_FIXED_PLL_DCO] = &a1_fixed_pll_dco.hw, >> + [CLKID_FIXED_PLL] = &a1_fixed_pll.hw, >> + [CLKID_HIFI_PLL] = &a1_hifi_pll.hw, >> + [CLKID_FCLK_DIV2] = &a1_fclk_div2.hw, >> + [CLKID_FCLK_DIV3] = &a1_fclk_div3.hw, >> + [CLKID_FCLK_DIV5] = &a1_fclk_div5.hw, >> + [CLKID_FCLK_DIV7] = &a1_fclk_div7.hw, >> + [CLKID_FCLK_DIV2_DIV] = &a1_fclk_div2_div.hw, >> + [CLKID_FCLK_DIV3_DIV] = &a1_fclk_div3_div.hw, >> + [CLKID_FCLK_DIV5_DIV] = &a1_fclk_div5_div.hw, >> + [CLKID_FCLK_DIV7_DIV] = &a1_fclk_div7_div.hw, >> + [NR_PLL_CLKS] = NULL, >> + }, >> + .num = NR_PLL_CLKS, >> +}; >> + >> +static struct clk_regmap *const a1_pll_regmaps[] = { >> + &a1_fixed_pll_dco, >> + &a1_fixed_pll, >> + &a1_hifi_pll, >> + &a1_fclk_div2, >> + &a1_fclk_div3, >> + &a1_fclk_div5, >> + &a1_fclk_div7, >> +}; >> + >> +static const struct meson_eeclkc_data a1_pll_data = { >> + .regmap_clks = a1_pll_regmaps, >> + .regmap_clk_num = ARRAY_SIZE(a1_pll_regmaps), >> + .hw_onecell_data = &a1_pll_hw_onecell_data, >> +}; >> +static const struct of_device_id clkc_match_table[] = { >> + { >> + .compatible = "amlogic,a1-pll-clkc", >> + .data = &a1_pll_data >> + }, >> + {} >> +}; >> + >> +static struct platform_driver a1_pll_driver = { >> + .probe = meson_clkc_probe, >> + .driver = { >> + .name = "a1-pll-clkc", >> + .of_match_table = clkc_match_table, >> + }, >> +}; >> + >> +builtin_platform_driver(a1_pll_driver); >> diff --git a/drivers/clk/meson/a1-pll.h b/drivers/clk/meson/a1-pll.h >> new file mode 100644 >> index 000000000000..8ded267061ad >> --- /dev/null >> +++ b/drivers/clk/meson/a1-pll.h >> @@ -0,0 +1,56 @@ >> +/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */ >> +/* >> + * Copyright (c) 2019 Amlogic, Inc. All rights reserved. >> + */ >> + >> +#ifndef __A1_PLL_H >> +#define __A1_PLL_H >> + >> +/* PLL register offset */ >> +#define ANACTRL_FIXPLL_CTRL0 0x0 >> +#define ANACTRL_FIXPLL_CTRL1 0x4 >> +#define ANACTRL_FIXPLL_CTRL2 0x8 >> +#define ANACTRL_FIXPLL_CTRL3 0xc >> +#define ANACTRL_FIXPLL_CTRL4 0x10 >> +#define ANACTRL_FIXPLL_STS 0x14 >> +#define ANACTRL_SYSPLL_CTRL0 0x80 >> +#define ANACTRL_SYSPLL_CTRL1 0x84 >> +#define ANACTRL_SYSPLL_CTRL2 0x88 >> +#define ANACTRL_SYSPLL_CTRL3 0x8c >> +#define ANACTRL_SYSPLL_CTRL4 0x90 >> +#define ANACTRL_SYSPLL_STS 0x94 >> +#define ANACTRL_HIFIPLL_CTRL0 0xc0 >> +#define ANACTRL_HIFIPLL_CTRL1 0xc4 >> +#define ANACTRL_HIFIPLL_CTRL2 0xc8 >> +#define ANACTRL_HIFIPLL_CTRL3 0xcc >> +#define ANACTRL_HIFIPLL_CTRL4 0xd0 >> +#define ANACTRL_HIFIPLL_STS 0xd4 >> +#define ANACTRL_AUDDDS_CTRL0 0x100 >> +#define ANACTRL_AUDDDS_CTRL1 0x104 >> +#define ANACTRL_AUDDDS_CTRL2 0x108 >> +#define ANACTRL_AUDDDS_CTRL3 0x10c >> +#define ANACTRL_AUDDDS_CTRL4 0x110 >> +#define ANACTRL_AUDDDS_STS 0x114 >> +#define ANACTRL_MISCTOP_CTRL0 0x140 >> +#define ANACTRL_POR_CNTL 0x188 >> + >> +/* >> + * CLKID index values >> + * >> + * These indices are entirely contrived and do not map onto the hardware. >> + * It has now been decided to expose everything by default in the DT header: >> + * include/dt-bindings/clock/a1-pll-clkc.h. Only the clocks ids we don't want >> + * to expose, such as the internal muxes and dividers of composite clocks, >> + * will remain defined here. >> + */ >> +#define CLKID_FIXED_PLL_DCO 0 >> +#define CLKID_FCLK_DIV2_DIV 2 >> +#define CLKID_FCLK_DIV3_DIV 3 >> +#define CLKID_FCLK_DIV5_DIV 4 >> +#define CLKID_FCLK_DIV7_DIV 5 >> +#define NR_PLL_CLKS 11 >> + >> +/* include the CLKIDs that have been made part of the DT binding */ >> +#include >> + >> +#endif /* __A1_PLL_H */