Skip to content

Commit 639e1ac

Browse files
smaeulmripard
authored andcommitted
clk: sunxi-ng: mp: Add macros using clk_parent_data and clk_hw
Referencing parents with clk_hw pointers is more efficient and removes the dependency on global clock names. clk_parent_data is needed when some parent clocks are provided from another driver. Add macros for declaring dividers that take advantage of these. Signed-off-by: Samuel Holland <[email protected]> Signed-off-by: Maxime Ripard <[email protected]> Link: https://lore.kernel.org/r/[email protected]
1 parent 3317cb1 commit 639e1ac

File tree

1 file changed

+49
-0
lines changed

1 file changed

+49
-0
lines changed

drivers/clk/sunxi-ng/ccu_mp.h

Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -82,6 +82,55 @@ struct ccu_mp {
8282
_muxshift, _muxwidth, \
8383
0, _flags)
8484

85+
#define SUNXI_CCU_MP_DATA_WITH_MUX_GATE(_struct, _name, _parents, _reg, \
86+
_mshift, _mwidth, \
87+
_pshift, _pwidth, \
88+
_muxshift, _muxwidth, \
89+
_gate, _flags) \
90+
struct ccu_mp _struct = { \
91+
.enable = _gate, \
92+
.m = _SUNXI_CCU_DIV(_mshift, _mwidth), \
93+
.p = _SUNXI_CCU_DIV(_pshift, _pwidth), \
94+
.mux = _SUNXI_CCU_MUX(_muxshift, _muxwidth), \
95+
.common = { \
96+
.reg = _reg, \
97+
.hw.init = CLK_HW_INIT_PARENTS_DATA(_name, \
98+
_parents, \
99+
&ccu_mp_ops, \
100+
_flags), \
101+
} \
102+
}
103+
104+
#define SUNXI_CCU_MP_DATA_WITH_MUX(_struct, _name, _parents, _reg, \
105+
_mshift, _mwidth, \
106+
_pshift, _pwidth, \
107+
_muxshift, _muxwidth, \
108+
_flags) \
109+
SUNXI_CCU_MP_DATA_WITH_MUX_GATE(_struct, _name, _parents, _reg, \
110+
_mshift, _mwidth, \
111+
_pshift, _pwidth, \
112+
_muxshift, _muxwidth, \
113+
0, _flags)
114+
115+
#define SUNXI_CCU_MP_HW_WITH_MUX_GATE(_struct, _name, _parents, _reg, \
116+
_mshift, _mwidth, \
117+
_pshift, _pwidth, \
118+
_muxshift, _muxwidth, \
119+
_gate, _flags) \
120+
struct ccu_mp _struct = { \
121+
.enable = _gate, \
122+
.m = _SUNXI_CCU_DIV(_mshift, _mwidth), \
123+
.p = _SUNXI_CCU_DIV(_pshift, _pwidth), \
124+
.mux = _SUNXI_CCU_MUX(_muxshift, _muxwidth), \
125+
.common = { \
126+
.reg = _reg, \
127+
.hw.init = CLK_HW_INIT_PARENTS_HW(_name, \
128+
_parents, \
129+
&ccu_mp_ops, \
130+
_flags), \
131+
} \
132+
}
133+
85134
static inline struct ccu_mp *hw_to_ccu_mp(struct clk_hw *hw)
86135
{
87136
struct ccu_common *common = hw_to_ccu_common(hw);

0 commit comments

Comments
 (0)