blob: e55a26ab8fdca81a6a83fde115364de5c26e4d2c [file] [log] [blame]
Anup Patel42fdf082019-02-25 08:14:49 +00001// SPDX-License-Identifier: GPL-2.0
2/*
3 * Copyright (c) 2019 Western Digital Corporation or its affiliates.
4 *
5 * Copyright (C) 2018 SiFive, Inc.
6 * Wesley Terpstra
7 * Paul Walmsley
Green Wanecefa5f2021-05-27 06:52:08 -07008 * Zong Li
9 * Pragnesh Patel
Anup Patel42fdf082019-02-25 08:14:49 +000010 *
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License version 2 as
13 * published by the Free Software Foundation.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
Anup Patel42fdf082019-02-25 08:14:49 +000020 * References:
21 * - SiFive FU540-C000 manual v1p0, Chapter 7 "Clocking and Reset"
22 */
23
Sean Anderson1f4d2062020-10-04 21:39:42 -040024#include <dt-bindings/clock/sifive-fu540-prci.h>
Anup Patel42fdf082019-02-25 08:14:49 +000025
Green Wanecefa5f2021-05-27 06:52:08 -070026#include "sifive-prci.h"
Anup Patel42fdf082019-02-25 08:14:49 +000027
Green Wanecefa5f2021-05-27 06:52:08 -070028/* PRCI integration data for each WRPLL instance */
Anup Patel42fdf082019-02-25 08:14:49 +000029static struct __prci_wrpll_data __prci_corepll_data = {
30 .cfg0_offs = PRCI_COREPLLCFG0_OFFSET,
Pragnesh Patel54ce0e02020-05-29 11:33:29 +053031 .cfg1_offs = PRCI_COREPLLCFG1_OFFSET,
Green Wanecefa5f2021-05-27 06:52:08 -070032 .enable_bypass = sifive_prci_coreclksel_use_hfclk,
33 .disable_bypass = sifive_prci_coreclksel_use_corepll,
Anup Patel42fdf082019-02-25 08:14:49 +000034};
35
36static struct __prci_wrpll_data __prci_ddrpll_data = {
37 .cfg0_offs = PRCI_DDRPLLCFG0_OFFSET,
Pragnesh Patel54ce0e02020-05-29 11:33:29 +053038 .cfg1_offs = PRCI_DDRPLLCFG1_OFFSET,
Green Wanecefa5f2021-05-27 06:52:08 -070039 .release_reset = sifive_prci_ddr_release_reset,
Anup Patel42fdf082019-02-25 08:14:49 +000040};
41
42static struct __prci_wrpll_data __prci_gemgxlpll_data = {
43 .cfg0_offs = PRCI_GEMGXLPLLCFG0_OFFSET,
Pragnesh Patel54ce0e02020-05-29 11:33:29 +053044 .cfg1_offs = PRCI_GEMGXLPLLCFG1_OFFSET,
Green Wanecefa5f2021-05-27 06:52:08 -070045 .release_reset = sifive_prci_ethernet_release_reset,
Anup Patel42fdf082019-02-25 08:14:49 +000046};
47
Green Wanecefa5f2021-05-27 06:52:08 -070048/* Linux clock framework integration */
49static const struct __prci_clock_ops sifive_fu540_prci_wrpll_clk_ops = {
50 .set_rate = sifive_prci_wrpll_set_rate,
51 .round_rate = sifive_prci_wrpll_round_rate,
52 .recalc_rate = sifive_prci_wrpll_recalc_rate,
53 .enable_clk = sifive_prci_clock_enable,
54};
Anup Patel42fdf082019-02-25 08:14:49 +000055
Green Wanecefa5f2021-05-27 06:52:08 -070056static const struct __prci_clock_ops sifive_fu540_prci_tlclksel_clk_ops = {
57 .recalc_rate = sifive_prci_tlclksel_recalc_rate,
58};
59
60/* List of clock controls provided by the PRCI */
Heinrich Schuchardt77d8dc62024-02-17 00:18:04 +010061static struct __prci_clock __prci_init_clocks_fu540[] = {
Anup Patel42fdf082019-02-25 08:14:49 +000062 [PRCI_CLK_COREPLL] = {
63 .name = "corepll",
64 .parent_name = "hfclk",
65 .ops = &sifive_fu540_prci_wrpll_clk_ops,
66 .pwd = &__prci_corepll_data,
67 },
68 [PRCI_CLK_DDRPLL] = {
69 .name = "ddrpll",
70 .parent_name = "hfclk",
Pragnesh Patel1790bce2020-05-29 11:33:30 +053071 .ops = &sifive_fu540_prci_wrpll_clk_ops,
Anup Patel42fdf082019-02-25 08:14:49 +000072 .pwd = &__prci_ddrpll_data,
73 },
74 [PRCI_CLK_GEMGXLPLL] = {
75 .name = "gemgxlpll",
76 .parent_name = "hfclk",
77 .ops = &sifive_fu540_prci_wrpll_clk_ops,
78 .pwd = &__prci_gemgxlpll_data,
79 },
80 [PRCI_CLK_TLCLK] = {
81 .name = "tlclk",
82 .parent_name = "corepll",
83 .ops = &sifive_fu540_prci_tlclksel_clk_ops,
84 },
85};
Heinrich Schuchardt77d8dc62024-02-17 00:18:04 +010086
87const struct prci_clk_desc prci_clk_fu540 = {
88 .clks = __prci_init_clocks_fu540,
89 .num_clks = ARRAY_SIZE(__prci_init_clocks_fu540),
90};