• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3  * Copyright (C) 2018 MediaTek Inc.
4  * Author: Ryder Lee <ryder.lee@mediatek.com>
5  */
6 
7 #ifndef __DRV_CLK_MTK_H
8 #define __DRV_CLK_MTK_H
9 
10 #define CLK_XTAL			0
11 #define MHZ				(1000 * 1000)
12 
13 #define HAVE_RST_BAR			BIT(0)
14 #define CLK_DOMAIN_SCPSYS		BIT(0)
15 
16 #define CLK_GATE_SETCLR			BIT(0)
17 #define CLK_GATE_SETCLR_INV		BIT(1)
18 #define CLK_GATE_NO_SETCLR		BIT(2)
19 #define CLK_GATE_NO_SETCLR_INV		BIT(3)
20 #define CLK_GATE_MASK			GENMASK(3, 0)
21 
22 #define CLK_PARENT_APMIXED		BIT(4)
23 #define CLK_PARENT_TOPCKGEN		BIT(5)
24 #define CLK_PARENT_MASK			GENMASK(5, 4)
25 
26 #define ETHSYS_HIFSYS_RST_CTRL_OFS	0x34
27 
28 /* struct mtk_pll_data - hardware-specific PLLs data */
29 struct mtk_pll_data {
30 	const int id;
31 	u32 reg;
32 	u32 pwr_reg;
33 	u32 en_mask;
34 	u32 pd_reg;
35 	int pd_shift;
36 	u32 flags;
37 	u32 rst_bar_mask;
38 	u64 fmax;
39 	int pcwbits;
40 	u32 pcw_reg;
41 	int pcw_shift;
42 };
43 
44 /**
45  * struct mtk_fixed_clk - fixed clocks
46  *
47  * @id:		index of clocks
48  * @parent:	index of parnet clocks
49  * @rate:	fixed rate
50  */
51 struct mtk_fixed_clk {
52 	const int id;
53 	const int parent;
54 	unsigned long rate;
55 };
56 
57 #define FIXED_CLK(_id, _parent, _rate) {		\
58 		.id = _id,				\
59 		.parent = _parent,			\
60 		.rate = _rate,				\
61 	}
62 
63 /**
64  * struct mtk_fixed_factor - fixed multiplier and divider clocks
65  *
66  * @id:		index of clocks
67  * @parent:	index of parnet clocks
68  * @mult:	multiplier
69  * @div:	divider
70  * @flag:	hardware-specific flags
71  */
72 struct mtk_fixed_factor {
73 	const int id;
74 	const int parent;
75 	u32 mult;
76 	u32 div;
77 	u32 flags;
78 };
79 
80 #define FACTOR(_id, _parent, _mult, _div, _flags) {	\
81 		.id = _id,				\
82 		.parent = _parent,			\
83 		.mult = _mult,				\
84 		.div = _div,				\
85 		.flags = _flags,			\
86 	}
87 
88 /**
89  * struct mtk_composite - aggregate clock of mux, divider and gate clocks
90  *
91  * @id:			index of clocks
92  * @parent:		index of parnet clocks
93  * @mux_reg:		hardware-specific mux register
94  * @gate_reg:		hardware-specific gate register
95  * @mux_mask:		mask to the mux bit field
96  * @mux_shift:		shift to the mux bit field
97  * @gate_shift:		shift to the gate bit field
98  * @num_parents:	number of parent clocks
99  * @flags:		hardware-specific flags
100  */
101 struct mtk_composite {
102 	const int id;
103 	const int *parent;
104 	u32 mux_reg;
105 	u32 gate_reg;
106 	u32 mux_mask;
107 	signed char mux_shift;
108 	signed char gate_shift;
109 	signed char num_parents;
110 	u16 flags;
111 };
112 
113 #define MUX_GATE_FLAGS(_id, _parents, _reg, _shift, _width, _gate,	\
114 		       _flags) {					\
115 		.id = _id,						\
116 		.mux_reg = _reg,					\
117 		.mux_shift = _shift,					\
118 		.mux_mask = BIT(_width) - 1,				\
119 		.gate_reg = _reg,					\
120 		.gate_shift = _gate,					\
121 		.parent = _parents,					\
122 		.num_parents = ARRAY_SIZE(_parents),			\
123 		.flags = _flags,					\
124 	}
125 
126 #define MUX_GATE(_id, _parents, _reg, _shift, _width, _gate)		\
127 	MUX_GATE_FLAGS(_id, _parents, _reg, _shift, _width, _gate, 0)
128 
129 #define MUX(_id, _parents, _reg, _shift, _width) {			\
130 		.id = _id,						\
131 		.mux_reg = _reg,					\
132 		.mux_shift = _shift,					\
133 		.mux_mask = BIT(_width) - 1,				\
134 		.gate_shift = -1,					\
135 		.parent = _parents,					\
136 		.num_parents = ARRAY_SIZE(_parents),			\
137 		.flags = 0,						\
138 	}
139 
140 struct mtk_gate_regs {
141 	u32 sta_ofs;
142 	u32 clr_ofs;
143 	u32 set_ofs;
144 };
145 
146 /**
147  * struct mtk_gate - gate clocks
148  *
149  * @id:		index of gate clocks
150  * @parent:	index of parnet clocks
151  * @regs:	hardware-specific mux register
152  * @shift:	shift to the gate bit field
153  * @flags:	hardware-specific flags
154  */
155 struct mtk_gate {
156 	const int id;
157 	const int parent;
158 	const struct mtk_gate_regs *regs;
159 	int shift;
160 	u32 flags;
161 };
162 
163 /* struct mtk_clk_tree - clock tree */
164 struct mtk_clk_tree {
165 	unsigned long xtal_rate;
166 	unsigned long xtal2_rate;
167 	const int fdivs_offs;
168 	const int muxes_offs;
169 	const struct mtk_pll_data *plls;
170 	const struct mtk_fixed_clk *fclks;
171 	const struct mtk_fixed_factor *fdivs;
172 	const struct mtk_composite *muxes;
173 };
174 
175 struct mtk_clk_priv {
176 	void __iomem *base;
177 	const struct mtk_clk_tree *tree;
178 };
179 
180 struct mtk_cg_priv {
181 	void __iomem *base;
182 	const struct mtk_clk_tree *tree;
183 	const struct mtk_gate *gates;
184 };
185 
186 extern const struct clk_ops mtk_clk_apmixedsys_ops;
187 extern const struct clk_ops mtk_clk_topckgen_ops;
188 extern const struct clk_ops mtk_clk_gate_ops;
189 
190 int mtk_common_clk_init(struct udevice *dev,
191 			const struct mtk_clk_tree *tree);
192 int mtk_common_clk_gate_init(struct udevice *dev,
193 			     const struct mtk_clk_tree *tree,
194 			     const struct mtk_gate *gates);
195 
196 #endif /* __DRV_CLK_MTK_H */
197