| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 |
- /*
- * Copyright (c) 2006-2022, RT-Thread Development Team
- *
- * SPDX-License-Identifier: Apache-2.0
- *
- * Change Logs:
- * Date Author Notes
- * 2022-3-08 GuEe-GUI the first version
- */
- #ifndef __CLK_RK_COMPOSITE_H__
- #define __CLK_RK_COMPOSITE_H__
- #include "clk-rk.h"
- struct rockchip_composite_clk_cell
- {
- struct rockchip_clk_cell rk_cell;
- struct rt_clk_ops ops;
- };
- #define COMPOSITE(_id, cname, pnames, f, mo, ms, mw, mf, ds, dw, df, go, gs, gf) \
- (void *)&(struct rockchip_composite_clk_cell) \
- { \
- .rk_cell.cell.name = cname, \
- .rk_cell.cell.parent_names = pnames, \
- .rk_cell.cell.parents_nr = RT_ARRAY_SIZE(pnames), \
- .rk_cell.cell.flags = f, \
- .rk_cell.id = _id, \
- .rk_cell.muxdiv_offset = mo, \
- .rk_cell.mux_shift = ms, \
- .rk_cell.mux_width = mw, \
- .rk_cell.mux_flags = mf, \
- .rk_cell.div_shift = ds, \
- .rk_cell.div_width = dw, \
- .rk_cell.div_flags = df, \
- .rk_cell.gate_offset = go, \
- .rk_cell.gate_shift = gs, \
- .rk_cell.gate_flags = gf, \
- .rk_cell.init = rockchip_composite_clk_cell_init, \
- }
- #define COMPOSITE_MUXTBL(_id, cname, pnames, f, mo, ms, mw, mf, mt, ds, dw, df, go, gs, gf) \
- (void *)&(struct rockchip_composite_clk_cell) \
- { \
- .rk_cell.cell.name = cname, \
- .rk_cell.cell.parent_names = pnames, \
- .rk_cell.cell.parents_nr = RT_ARRAY_SIZE(pnames), \
- .rk_cell.cell.flags = f, \
- .rk_cell.id = _id, \
- .rk_cell.muxdiv_offset = mo, \
- .rk_cell.mux_shift = ms, \
- .rk_cell.mux_width = mw, \
- .rk_cell.mux_flags = mf, \
- .rk_cell.mux_table = mt, \
- .rk_cell.div_shift = ds, \
- .rk_cell.div_width = dw, \
- .rk_cell.div_flags = df, \
- .rk_cell.gate_offset = go, \
- .rk_cell.gate_shift = gs, \
- .rk_cell.gate_flags = gf, \
- .rk_cell.init = rockchip_composite_clk_cell_init, \
- }
- #define COMPOSITE_DIV_OFFSET(_id, cname, pnames, f, mo, ms, mw, mf, do, ds, dw, df, go, gs, gf) \
- (void *)&(struct rockchip_composite_clk_cell) \
- { \
- .rk_cell.cell.name = cname, \
- .rk_cell.cell.parent_names = pnames, \
- .rk_cell.cell.parents_nr = RT_ARRAY_SIZE(pnames), \
- .rk_cell.cell.flags = f, \
- .rk_cell.id = _id, \
- .rk_cell.muxdiv_offset = mo, \
- .rk_cell.mux_shift = ms, \
- .rk_cell.mux_width = mw, \
- .rk_cell.mux_flags = mf, \
- .rk_cell.div_offset = do, \
- .rk_cell.div_shift = ds, \
- .rk_cell.div_width = dw, \
- .rk_cell.div_flags = df, \
- .rk_cell.gate_offset = go, \
- .rk_cell.gate_shift = gs, \
- .rk_cell.gate_flags = gf, \
- .rk_cell.init = rockchip_composite_clk_cell_init, \
- }
- #define COMPOSITE_NOMUX(_id, cname, pname, f, mo, ds, dw, df, go, gs, gf) \
- (void *)&(struct rockchip_composite_clk_cell) \
- { \
- .rk_cell.cell.name = cname, \
- .rk_cell.cell.parent_name = pname, \
- .rk_cell.cell.parents_nr = 1, \
- .rk_cell.cell.flags = f, \
- .rk_cell.id = _id, \
- .rk_cell.muxdiv_offset = mo, \
- .rk_cell.div_shift = ds, \
- .rk_cell.div_width = dw, \
- .rk_cell.div_flags = df, \
- .rk_cell.gate_offset = go, \
- .rk_cell.gate_shift = gs, \
- .rk_cell.gate_flags = gf, \
- .rk_cell.init = rockchip_composite_clk_cell_init, \
- }
- #define COMPOSITE_NOMUX_DIVTBL(_id, cname, pname, f, mo, ds, dw, df, dt, go, gs, gf) \
- (void *)&(struct rockchip_composite_clk_cell) \
- { \
- .rk_cell.cell.name = cname, \
- .rk_cell.cell.parent_name = pname, \
- .rk_cell.cell.parents_nr = 1, \
- .rk_cell.cell.flags = f, \
- .rk_cell.id = _id, \
- .rk_cell.muxdiv_offset = mo, \
- .rk_cell.div_shift = ds, \
- .rk_cell.div_width = dw, \
- .rk_cell.div_flags = df, \
- .rk_cell.div_table = dt, \
- .rk_cell.gate_offset = go, \
- .rk_cell.gate_shift = gs, \
- .rk_cell.gate_flags = gf, \
- .rk_cell.init = rockchip_composite_clk_cell_init, \
- }
- #define COMPOSITE_NODIV(_id, cname, pnames, f, mo, ms, mw, mf, go, gs, gf) \
- (void *)&(struct rockchip_composite_clk_cell) \
- { \
- .rk_cell.cell.name = cname, \
- .rk_cell.cell.parent_names = pnames, \
- .rk_cell.cell.parents_nr = RT_ARRAY_SIZE(pnames), \
- .rk_cell.cell.flags = f, \
- .rk_cell.id = _id, \
- .rk_cell.muxdiv_offset = mo, \
- .rk_cell.mux_shift = ms, \
- .rk_cell.mux_width = mw, \
- .rk_cell.mux_flags = mf, \
- .rk_cell.gate_offset = go, \
- .rk_cell.gate_shift = gs, \
- .rk_cell.gate_flags = gf, \
- .rk_cell.init = rockchip_composite_clk_cell_init, \
- }
- #define COMPOSITE_NOGATE(_id, cname, pnames, f, mo, ms, mw, mf, ds, dw, df) \
- (void *)&(struct rockchip_composite_clk_cell) \
- { \
- .rk_cell.cell.name = cname, \
- .rk_cell.cell.parent_names = pnames, \
- .rk_cell.cell.parents_nr = RT_ARRAY_SIZE(pnames), \
- .rk_cell.cell.flags = f, \
- .rk_cell.id = _id, \
- .rk_cell.muxdiv_offset = mo, \
- .rk_cell.mux_shift = ms, \
- .rk_cell.mux_width = mw, \
- .rk_cell.mux_flags = mf, \
- .rk_cell.div_shift = ds, \
- .rk_cell.div_width = dw, \
- .rk_cell.div_flags = df, \
- .rk_cell.gate_offset = -1, \
- .rk_cell.init = rockchip_composite_clk_cell_init, \
- }
- #define COMPOSITE_NOGATE_DIVTBL(_id, cname, pnames, f, mo, ms, mw, mf, ds, dw, df, dt) \
- (void *)&(struct rockchip_composite_clk_cell) \
- { \
- .rk_cell.cell.name = cname, \
- .rk_cell.cell.parent_names = pnames, \
- .rk_cell.cell.parents_nr = RT_ARRAY_SIZE(pnames), \
- .rk_cell.cell.flags = f, \
- .rk_cell.id = _id, \
- .rk_cell.muxdiv_offset = mo, \
- .rk_cell.mux_shift = ms, \
- .rk_cell.mux_width = mw, \
- .rk_cell.mux_flags = mf, \
- .rk_cell.div_shift = ds, \
- .rk_cell.div_width = dw, \
- .rk_cell.div_flags = df, \
- .rk_cell.div_table = dt, \
- .rk_cell.gate_offset = -1, \
- .rk_cell.init = rockchip_composite_clk_cell_init, \
- }
- rt_inline struct rockchip_composite_clk_cell *cell_to_rockchip_composite_cell(struct rt_clk_cell *cell)
- {
- struct rockchip_clk_cell *rk_cell = cell_to_rockchip_clk_cell(cell);
- return rt_container_of(rk_cell, struct rockchip_composite_clk_cell, rk_cell);
- }
- void rockchip_composite_clk_cell_init(struct rockchip_clk_cell *rk_cell);
- #endif /* __CLK_RK_COMPOSITE_H__ */
|