bb5aa08572
The VCLK and VCLK_DIV clocks have supplementary bits. The VCLK gate has a "SOFT RESET" bit to toggle after the whole VCLK sub-tree rate has been set, this is implemented in the gate enable callback. The VCLK_DIV clocks as enable and reset bits used to disable and reset the divider, associated with CLK_SET_RATE_GATE it ensures the rate is set while the divider is disabled and in reset mode. The VCLK_DIV enable bit isn't implemented as a gate since it's part of the divider logic and vendor does this exact sequence to ensure the divider is correctly set. Signed-off-by: Neil Armstrong <neil.armstrong@linaro.org> Link: https://lore.kernel.org/r/20240403-amlogic-v6-4-upstream-dsi-ccf-vim3-v12-2-99ecdfdc87fc@linaro.org Signed-off-by: Jerome Brunet <jbrunet@baylibre.com>
52 lines
1.1 KiB
C
52 lines
1.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2024 Neil Armstrong <neil.armstrong@linaro.org>
|
|
*/
|
|
|
|
#ifndef __VCLK_H
|
|
#define __VCLK_H
|
|
|
|
#include "clk-regmap.h"
|
|
#include "parm.h"
|
|
|
|
/**
|
|
* struct meson_vclk_gate_data - vclk_gate regmap backed specific data
|
|
*
|
|
* @enable: vclk enable field
|
|
* @reset: vclk reset field
|
|
* @flags: hardware-specific flags
|
|
*
|
|
* Flags:
|
|
* Same as clk_gate except CLK_GATE_HIWORD_MASK which is ignored
|
|
*/
|
|
struct meson_vclk_gate_data {
|
|
struct parm enable;
|
|
struct parm reset;
|
|
u8 flags;
|
|
};
|
|
|
|
extern const struct clk_ops meson_vclk_gate_ops;
|
|
|
|
/**
|
|
* struct meson_vclk_div_data - vclk_div regmap back specific data
|
|
*
|
|
* @div: divider field
|
|
* @enable: vclk divider enable field
|
|
* @reset: vclk divider reset field
|
|
* @table: array of value/divider pairs, last entry should have div = 0
|
|
*
|
|
* Flags:
|
|
* Same as clk_divider except CLK_DIVIDER_HIWORD_MASK which is ignored
|
|
*/
|
|
struct meson_vclk_div_data {
|
|
struct parm div;
|
|
struct parm enable;
|
|
struct parm reset;
|
|
const struct clk_div_table *table;
|
|
u8 flags;
|
|
};
|
|
|
|
extern const struct clk_ops meson_vclk_div_ops;
|
|
|
|
#endif /* __VCLK_H */
|